Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/netinet6 Report route additions/changes/deletions for ca...



details:   https://anonhg.NetBSD.org/src/rev/0a11c6bc807f
branches:  trunk
changeset: 334940:0a11c6bc807f
user:      roy <roy%NetBSD.org@localhost>
date:      Tue Dec 16 11:42:27 2014 +0000

description:
Report route additions/changes/deletions for cached neighbours to userland.

diffstat:

 sys/netinet6/nd6.c     |  18 +++++++++++++++---
 sys/netinet6/nd6.h     |   3 ++-
 sys/netinet6/nd6_nbr.c |  13 +++++++++----
 sys/netinet6/nd6_rtr.c |   7 +++----
 4 files changed, 29 insertions(+), 12 deletions(-)

diffs (170 lines):

diff -r ef8509a4202c -r 0a11c6bc807f sys/netinet6/nd6.c
--- a/sys/netinet6/nd6.c        Tue Dec 16 11:34:17 2014 +0000
+++ b/sys/netinet6/nd6.c        Tue Dec 16 11:42:27 2014 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: nd6.c,v 1.155 2014/12/03 01:32:11 christos Exp $       */
+/*     $NetBSD: nd6.c,v 1.156 2014/12/16 11:42:27 roy 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.155 2014/12/03 01:32:11 christos Exp $");
+__KERNEL_RCSID(0, "$NetBSD: nd6.c,v 1.156 2014/12/16 11:42:27 roy Exp $");
 
 #include "bridge.h"
 #include "carp.h"
@@ -1037,6 +1037,7 @@
        struct llinfo_nd6 *ln = (struct llinfo_nd6 *)rt->rt_llinfo, *next;
        struct in6_addr in6 = satocsin6(rt_getkey(rt))->sin6_addr;
        struct nd_defrouter *dr;
+       struct rtentry *oldrt;
 
        /*
         * we used to have pfctlinput(PRC_HOSTDEAD) here.
@@ -1129,7 +1130,15 @@
         * caches, and disable the route entry not to be used in already
         * cached routes.
         */
-       rtrequest(RTM_DELETE, rt_getkey(rt), NULL, rt_mask(rt), 0, NULL);
+       oldrt = NULL;
+       rtrequest(RTM_DELETE, rt_getkey(rt), NULL, rt_mask(rt), 0, &oldrt);
+       if (oldrt) {
+               nd6_rtmsg(RTM_DELETE, oldrt); /* tell user process */
+               if (oldrt->rt_refcnt <= 0) {
+                       oldrt->rt_refcnt++;
+                       rtfree(oldrt);
+               }
+       }
 
        return next;
 }
@@ -2059,6 +2068,9 @@
                break;
        }
 
+       if (do_update)
+               nd6_rtmsg(RTM_CHANGE, rt);  /* tell user process */
+
        /*
         * When the link-layer address of a router changes, select the
         * best router again.  In particular, when the neighbor entry is newly
diff -r ef8509a4202c -r 0a11c6bc807f sys/netinet6/nd6.h
--- a/sys/netinet6/nd6.h        Tue Dec 16 11:34:17 2014 +0000
+++ b/sys/netinet6/nd6.h        Tue Dec 16 11:42:27 2014 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: nd6.h,v 1.60 2014/09/05 06:08:15 matt Exp $    */
+/*     $NetBSD: nd6.h,v 1.61 2014/12/16 11:42:27 roy Exp $     */
 /*     $KAME: nd6.h,v 1.95 2002/06/08 11:31:06 itojun Exp $    */
 
 /*
@@ -413,6 +413,7 @@
 struct nd_opt_hdr *nd6_option(union nd_opts *);
 int nd6_options(union nd_opts *);
 struct rtentry *nd6_lookup(const struct in6_addr *, int, struct ifnet *);
+void nd6_rtmsg(int, struct rtentry *);
 void nd6_setmtu(struct ifnet *);
 void nd6_llinfo_settimer(struct llinfo_nd6 *, long);
 void nd6_timer(void *);
diff -r ef8509a4202c -r 0a11c6bc807f sys/netinet6/nd6_nbr.c
--- a/sys/netinet6/nd6_nbr.c    Tue Dec 16 11:34:17 2014 +0000
+++ b/sys/netinet6/nd6_nbr.c    Tue Dec 16 11:42:27 2014 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: nd6_nbr.c,v 1.102 2014/10/12 20:05:50 roy Exp $        */
+/*     $NetBSD: nd6_nbr.c,v 1.103 2014/12/16 11:42:27 roy Exp $        */
 /*     $KAME: nd6_nbr.c,v 1.61 2001/02/10 16:06:14 jinmei Exp $        */
 
 /*
@@ -31,7 +31,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: nd6_nbr.c,v 1.102 2014/10/12 20:05:50 roy Exp $");
+__KERNEL_RCSID(0, "$NetBSD: nd6_nbr.c,v 1.103 2014/12/16 11:42:27 roy Exp $");
 
 #include "opt_inet.h"
 #include "opt_ipsec.h"
@@ -567,6 +567,7 @@
        struct sockaddr_dl *sdl;
        union nd_opts ndopts;
        struct sockaddr_in6 ssin6;
+       int rt_announce;
 
        if (ip6->ip6_hlim != 255) {
                nd6log((LOG_ERR,
@@ -669,6 +670,7 @@
           ((sdl = satosdl(rt->rt_gateway)) == NULL))
                goto freeit;
 
+       rt_announce = 0;
        if (ln->ln_state == ND6_LLINFO_INCOMPLETE) {
                /*
                 * If the link-layer has address, and no lladdr option came,
@@ -682,6 +684,7 @@
                 */
                (void)sockaddr_dl_setaddr(sdl, sdl->sdl_len, lladdr,
                    ifp->if_addrlen);
+               rt_announce = 1;
                if (is_solicited) {
                        ln->ln_state = ND6_LLINFO_REACHABLE;
                        ln->ln_byhint = 0;
@@ -712,11 +715,11 @@
                else {
                        if (sdl->sdl_alen) {
                                if (memcmp(lladdr, CLLADDR(sdl), ifp->if_addrlen))
-                                       llchange = 1;
+                                       llchange = rt_announce = 1;
                                else
                                        llchange = 0;
                        } else
-                               llchange = 1;
+                               llchange = rt_announce = 1;
                }
 
                /*
@@ -819,6 +822,8 @@
        rt->rt_flags &= ~RTF_REJECT;
        ln->ln_asked = 0;
        nd6_llinfo_release_pkts(ln, ifp, rt);
+       if (rt_announce) /* tell user process about any new lladdr */
+               nd6_rtmsg(RTM_CHANGE, rt);
 
  freeit:
        m_freem(m);
diff -r ef8509a4202c -r 0a11c6bc807f sys/netinet6/nd6_rtr.c
--- a/sys/netinet6/nd6_rtr.c    Tue Dec 16 11:34:17 2014 +0000
+++ b/sys/netinet6/nd6_rtr.c    Tue Dec 16 11:42:27 2014 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: nd6_rtr.c,v 1.94 2014/09/05 06:08:15 matt Exp $        */
+/*     $NetBSD: nd6_rtr.c,v 1.95 2014/12/16 11:42:27 roy Exp $ */
 /*     $KAME: nd6_rtr.c,v 1.95 2001/02/07 08:09:47 itojun Exp $        */
 
 /*
@@ -31,7 +31,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: nd6_rtr.c,v 1.94 2014/09/05 06:08:15 matt Exp $");
+__KERNEL_RCSID(0, "$NetBSD: nd6_rtr.c,v 1.95 2014/12/16 11:42:27 roy Exp $");
 
 #include <sys/param.h>
 #include <sys/systm.h>
@@ -76,7 +76,6 @@
 static struct nd_pfxrouter *find_pfxlist_reachable_router
        (struct nd_prefix *);
 static void defrouter_delreq(struct nd_defrouter *);
-static void nd6_rtmsg(int, struct rtentry *);
 
 static int in6_init_prefix_ltimes(struct nd_prefix *);
 static void in6_init_address_ltimes(struct nd_prefix *,
@@ -416,7 +415,7 @@
  */
 
 /* tell the change to user processes watching the routing socket. */
-static void
+void
 nd6_rtmsg(int cmd, struct rtentry *rt)
 {
        struct rt_addrinfo info;



Home | Main Index | Thread Index | Old Index