Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys Sending a routing message (RTM_ADD) on adding an llentry
details: https://anonhg.NetBSD.org/src/rev/0e70efc9261a
branches: trunk
changeset: 354429:0e70efc9261a
user: ozaki-r <ozaki-r%NetBSD.org@localhost>
date: Fri Jun 16 02:24:54 2017 +0000
description:
Sending a routing message (RTM_ADD) on adding an llentry
A message used to be sent on adding a cloned route. Restore the
behavior for backward compatibility.
Requested by ryo@
diffstat:
sys/net/route.h | 6 +++++-
sys/net/rtsock.c | 42 ++++++++++++++++++++++++++++++++++++++++--
sys/netinet/if_arp.c | 11 ++++++++---
sys/netinet6/nd6.c | 9 +++++++--
4 files changed, 60 insertions(+), 8 deletions(-)
diffs (153 lines):
diff -r 94068f0c7cb6 -r 0e70efc9261a sys/net/route.h
--- a/sys/net/route.h Fri Jun 16 02:01:10 2017 +0000
+++ b/sys/net/route.h Fri Jun 16 02:24:54 2017 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: route.h,v 1.112 2017/04/11 13:55:54 roy Exp $ */
+/* $NetBSD: route.h,v 1.113 2017/06/16 02:24:54 ozaki-r Exp $ */
/*
* Copyright (c) 1980, 1986, 1993
@@ -500,6 +500,10 @@
void rt_newaddrmsg(int, struct ifaddr *, int, struct rtentry *);
void route_enqueue(struct mbuf *, int);
+struct llentry;
+void rt_clonedmsg(const struct sockaddr *, const struct ifnet *,
+ const struct rtentry *);
+
/* rtbl */
int rt_addaddr(rtbl_t *, struct rtentry *, const struct sockaddr *);
void rt_assert_inactive(const struct rtentry *);
diff -r 94068f0c7cb6 -r 0e70efc9261a sys/net/rtsock.c
--- a/sys/net/rtsock.c Fri Jun 16 02:01:10 2017 +0000
+++ b/sys/net/rtsock.c Fri Jun 16 02:24:54 2017 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: rtsock.c,v 1.214 2017/06/15 02:51:45 ozaki-r Exp $ */
+/* $NetBSD: rtsock.c,v 1.215 2017/06/16 02:24:54 ozaki-r Exp $ */
/*
* Copyright (C) 1995, 1996, 1997, and 1998 WIDE Project.
@@ -61,7 +61,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: rtsock.c,v 1.214 2017/06/15 02:51:45 ozaki-r Exp $");
+__KERNEL_RCSID(0, "$NetBSD: rtsock.c,v 1.215 2017/06/16 02:24:54 ozaki-r Exp $");
#ifdef _KERNEL_OPT
#include "opt_inet.h"
@@ -1628,6 +1628,44 @@
COMPATNAME(route_enqueue)(m, 0);
}
+#ifndef COMPAT_RTSOCK
+/*
+ * Send a routing message as mimicing that a cloned route is added.
+ */
+void
+rt_clonedmsg(const struct sockaddr *dst, const struct ifnet *ifp,
+ const struct rtentry *rt)
+{
+ struct rt_addrinfo info;
+ /* Mimic flags exactly */
+#define RTF_LLINFO 0x400
+#define RTF_CLONED 0x2000
+ int flags = RTF_UP | RTF_HOST | RTF_DONE | RTF_LLINFO | RTF_CLONED;
+ union {
+ struct sockaddr sa;
+ struct sockaddr_storage ss;
+ struct sockaddr_dl sdl;
+ } u;
+ uint8_t namelen = strlen(ifp->if_xname);
+ uint8_t addrlen = ifp->if_addrlen;
+
+ if (rt == NULL)
+ return; /* XXX */
+
+ memset(&info, 0, sizeof(info));
+ info.rti_info[RTAX_DST] = dst;
+ sockaddr_dl_init(&u.sdl, sizeof(u.ss), ifp->if_index, ifp->if_type,
+ NULL, namelen, NULL, addrlen);
+ info.rti_info[RTAX_GATEWAY] = &u.sa;
+ info.rti_info[RTAX_IFP] = rt->rt_ifp->if_dl->ifa_addr;
+ info.rti_info[RTAX_IFA] = rt->rt_ifa->ifa_addr;
+
+ rt_missmsg(RTM_ADD, &info, flags, 0);
+#undef RTF_LLINFO
+#undef RTF_CLONED
+}
+#endif /* COMPAT_RTSOCK */
+
/*
* This is used in dumping the kernel table via sysctl().
*/
diff -r 94068f0c7cb6 -r 0e70efc9261a sys/netinet/if_arp.c
--- a/sys/netinet/if_arp.c Fri Jun 16 02:01:10 2017 +0000
+++ b/sys/netinet/if_arp.c Fri Jun 16 02:24:54 2017 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: if_arp.c,v 1.250 2017/05/18 06:33:11 ozaki-r Exp $ */
+/* $NetBSD: if_arp.c,v 1.251 2017/06/16 02:24:54 ozaki-r Exp $ */
/*-
* Copyright (c) 1998, 2000, 2008 The NetBSD Foundation, Inc.
@@ -68,7 +68,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: if_arp.c,v 1.250 2017/05/18 06:33:11 ozaki-r Exp $");
+__KERNEL_RCSID(0, "$NetBSD: if_arp.c,v 1.251 2017/06/16 02:24:54 ozaki-r Exp $");
#ifdef _KERNEL_OPT
#include "opt_ddb.h"
@@ -760,8 +760,13 @@
IF_AFDATA_WUNLOCK(ifp);
if (la == NULL)
ARP_STATINC(ARP_STAT_ALLOCFAIL);
- else
+ else {
+ struct sockaddr_in sin;
+
arp_init_llentry(ifp, la);
+ sockaddr_in_init(&sin, &la->r_l3addr.addr4, 0);
+ rt_clonedmsg(sintosa(&sin), ifp, rt);
+ }
} else if (LLE_TRY_UPGRADE(la) == 0) {
create_lookup = "lookup";
LLE_RUNLOCK(la);
diff -r 94068f0c7cb6 -r 0e70efc9261a sys/netinet6/nd6.c
--- a/sys/netinet6/nd6.c Fri Jun 16 02:01:10 2017 +0000
+++ b/sys/netinet6/nd6.c Fri Jun 16 02:24:54 2017 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: nd6.c,v 1.232 2017/06/01 02:45:14 chs Exp $ */
+/* $NetBSD: nd6.c,v 1.233 2017/06/16 02:24:54 ozaki-r Exp $ */
/* $KAME: nd6.c,v 1.279 2002/06/08 11:16:51 itojun Exp $ */
/*
@@ -31,7 +31,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: nd6.c,v 1.232 2017/06/01 02:45:14 chs Exp $");
+__KERNEL_RCSID(0, "$NetBSD: nd6.c,v 1.233 2017/06/16 02:24:54 ozaki-r Exp $");
#ifdef _KERNEL_OPT
#include "opt_net_mpsafe.h"
@@ -2298,6 +2298,7 @@
/* Slow path */
ln = nd6_lookup(&dst->sin6_addr, ifp, true);
if (ln == NULL && nd6_is_addr_neighbor(dst, ifp)) {
+ struct sockaddr_in6 sin6;
/*
* Since nd6_is_addr_neighbor() internally calls nd6_lookup(),
* the condition below is not very efficient. But we believe
@@ -2313,6 +2314,10 @@
m_freem(m);
return ENOBUFS;
}
+
+ sockaddr_in6_init(&sin6, &ln->r_l3addr.addr6, 0, 0, 0);
+ rt_clonedmsg(sin6tosa(&sin6), ifp, rt);
+
created = true;
}
Home |
Main Index |
Thread Index |
Old Index