summaryrefslogtreecommitdiffstats
path: root/sys/netinet/in_rmx.c
diff options
context:
space:
mode:
authorru <ru@FreeBSD.org>2001-03-19 09:16:16 +0000
committerru <ru@FreeBSD.org>2001-03-19 09:16:16 +0000
commit38387221cd67a6d9b58b81feee97e876a9832d42 (patch)
tree96d2016274b574dd4e5a5aed21f96a33799eb0f9 /sys/netinet/in_rmx.c
parentdabce43c5b93b638113eb1b7059ca91b32eb3607 (diff)
downloadFreeBSD-src-38387221cd67a6d9b58b81feee97e876a9832d42.zip
FreeBSD-src-38387221cd67a6d9b58b81feee97e876a9832d42.tar.gz
Invalidate cached forwarding route (ipforward_rt) whenever a new route
is added to the routing table, otherwise we may end up using the wrong route when forwarding. PR: kern/10778 Reviewed by: silence on -net
Diffstat (limited to 'sys/netinet/in_rmx.c')
-rw-r--r--sys/netinet/in_rmx.c12
1 files changed, 12 insertions, 0 deletions
diff --git a/sys/netinet/in_rmx.c b/sys/netinet/in_rmx.c
index 51a5846..16ea5be 100644
--- a/sys/netinet/in_rmx.c
+++ b/sys/netinet/in_rmx.c
@@ -54,6 +54,7 @@
#include <net/route.h>
#include <netinet/in.h>
#include <netinet/in_var.h>
+#include <netinet/ip_var.h>
extern int in_inithead __P((void **head, int off));
@@ -137,6 +138,17 @@ in_addroute(void *v_arg, void *n_arg, struct radix_node_head *head,
RTFREE(rt2);
}
}
+
+ /*
+ * If the new route created successfully, and we are forwarding,
+ * and there is a cached route, free it. Otherwise, we may end
+ * up using the wrong route.
+ */
+ if (ret != NULL && ipforwarding && ipforward_rt.ro_rt) {
+ RTFREE(ipforward_rt.ro_rt);
+ ipforward_rt.ro_rt = 0;
+ }
+
return ret;
}
OpenPOWER on IntegriCloud