summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorClaudio Jeker <claudio@cvs.openbsd.org>2010-02-09 16:31:15 +0000
committerClaudio Jeker <claudio@cvs.openbsd.org>2010-02-09 16:31:15 +0000
commit7e81f6b4ab8d0ee488afcd022730b1bf49ef7b75 (patch)
tree00cc06bbe34890577f088dea7ab7e4db5d86a290
parent43b4c81c86e26b76534d4c78da506f0f2db80ffb (diff)
Correctly track RTF_UP on RTM_CHANGE. Since the interface can change
rt_if_linkstate_change() needs to be rerun for this route and the resulting rt_flags need to copied to the rtm_flags for userland. Problem found and diagnosed by Doran Mori. OK henning@, jsing@
-rw-r--r--sys/net/route.c5
-rw-r--r--sys/net/route.h3
-rw-r--r--sys/net/rtsock.c8
3 files changed, 10 insertions, 6 deletions
diff --git a/sys/net/route.c b/sys/net/route.c
index 9a798e2fbf3..9bea0705605 100644
--- a/sys/net/route.c
+++ b/sys/net/route.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: route.c,v 1.114 2009/11/03 10:59:04 claudio Exp $ */
+/* $OpenBSD: route.c,v 1.115 2010/02/09 16:31:14 claudio Exp $ */
/* $NetBSD: route.c,v 1.14 1996/02/13 22:00:46 christos Exp $ */
/*
@@ -152,9 +152,6 @@ int okaytoclone(u_int, int);
int rtflushclone1(struct radix_node *, void *);
void rtflushclone(struct radix_node_head *, struct rtentry *);
int rt_if_remove_rtdelete(struct radix_node *, void *);
-#ifndef SMALL_KERNEL
-int rt_if_linkstate_change(struct radix_node *, void *);
-#endif
#define LABELID_MAX 50000
diff --git a/sys/net/route.h b/sys/net/route.h
index 954331a2b21..ca4940d16e7 100644
--- a/sys/net/route.h
+++ b/sys/net/route.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: route.h,v 1.65 2009/11/03 10:59:04 claudio Exp $ */
+/* $OpenBSD: route.h,v 1.66 2010/02/09 16:31:14 claudio Exp $ */
/* $NetBSD: route.h,v 1.9 1996/02/13 22:00:49 christos Exp $ */
/*
@@ -394,6 +394,7 @@ int rtrequest1(int, struct rt_addrinfo *, u_int8_t, struct rtentry **,
void rt_if_remove(struct ifnet *);
#ifndef SMALL_KERNEL
void rt_if_track(struct ifnet *);
+int rt_if_linkstate_change(struct radix_node *, void *);
#endif
int rtdeletemsg(struct rtentry *, u_int);
diff --git a/sys/net/rtsock.c b/sys/net/rtsock.c
index d162048c049..fae0a622d6b 100644
--- a/sys/net/rtsock.c
+++ b/sys/net/rtsock.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: rtsock.c,v 1.95 2009/11/03 10:59:04 claudio Exp $ */
+/* $OpenBSD: rtsock.c,v 1.96 2010/02/09 16:31:14 claudio Exp $ */
/* $NetBSD: rtsock.c,v 1.18 1996/03/29 00:32:10 cgd Exp $ */
/*
@@ -638,6 +638,11 @@ report:
rt->rt_ifa = ifa;
ifa->ifa_refcnt++;
rt->rt_ifp = ifp;
+#ifndef SMALL_KERNEL
+ /* recheck link state after ifp change */
+ rt_if_linkstate_change(
+ (struct radix_node *)rt, ifp);
+#endif
}
}
@@ -651,6 +656,7 @@ report:
&rt->rt_rmx);
rtm->rtm_index = rt->rt_ifp->if_index;
rtm->rtm_priority = rt->rt_priority & RTP_MASK;
+ rtm->rtm_flags = rt->rt_flags;
if (rt->rt_ifa && rt->rt_ifa->ifa_rtrequest)
rt->rt_ifa->ifa_rtrequest(RTM_ADD, rt, &info);
if (genmask)