Source-Changes-HG archive

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

[src/trunk]: src/usr.sbin/ndp Remove in-kernel handling of Router Advertisements



details:   https://anonhg.NetBSD.org/src/rev/4c5561184091
branches:  trunk
changeset: 1010905:4c5561184091
user:      roy <roy%NetBSD.org@localhost>
date:      Fri Jun 12 11:04:44 2020 +0000

description:
Remove in-kernel handling of Router Advertisements

This is much better handled by a user-land tool.
Proposed on tech-net here:
https://mail-index.netbsd.org/tech-net/2020/04/22/msg007766.html

Note that the ioctl SIOCGIFINFO_IN6 no longer sets flags. That now
needs to be done using the pre-existing SIOCSIFINFO_FLAGS ioctl.

Compat is fully provided where it makes sense, but trying to turn on
RA handling will obviously throw an error as it no longer exists.

Note that if you use IPv6 temporary addresses, this now needs to be
turned on in dhcpcd.conf(5) rather than in sysctl.conf(5).

diffstat:

 distrib/sets/lists/tests/mi   |     4 +-
 etc/mtree/Makefile            |     8 +-
 etc/rc.d/network              |    31 +-
 sys/compat/common/if_43.c     |     9 +-
 sys/compat/netinet6/in6_var.h |    22 +-
 sys/net/if.c                  |    13 +-
 sys/net/if_vlan.c             |    10 +-
 sys/netinet/icmp6.h           |     8 +-
 sys/netinet/tcp_output.c      |     6 +-
 sys/netinet/tcp_subr.c        |    20 +-
 sys/netinet6/icmp6.c          |    44 +-
 sys/netinet6/in6.c            |   176 +--
 sys/netinet6/in6.h            |    12 +-
 sys/netinet6/in6_ifattach.c   |   238 +----
 sys/netinet6/in6_proto.c      |    16 +-
 sys/netinet6/in6_var.h        |   160 +--
 sys/netinet6/ip6_forward.c    |    15 +-
 sys/netinet6/ip6_input.c      |    94 +-
 sys/netinet6/ip6_mroute.c     |    11 +-
 sys/netinet6/ip6_output.c     |    17 +-
 sys/netinet6/ip6_var.h        |     9 +-
 sys/netinet6/nd6.c            |  1301 +++--------------------
 sys/netinet6/nd6.h            |   307 +-----
 sys/netinet6/nd6_nbr.c        |    45 +-
 sys/netinet6/nd6_rtr.c        |  2221 +----------------------------------------
 sys/rump/Makefile.rump        |     4 +-
 tests/net/ndp/Makefile        |     4 +-
 tests/net/ndp/t_ra.sh         |   866 ---------------
 usr.sbin/ndp/ndp.8            |    55 +-
 usr.sbin/ndp/ndp.c            |   619 +-----------
 30 files changed, 466 insertions(+), 5879 deletions(-)

diffs (truncated from 7890 to 300 lines):

diff -r 7c7fec33c495 -r 4c5561184091 distrib/sets/lists/tests/mi
--- a/distrib/sets/lists/tests/mi       Fri Jun 12 10:35:59 2020 +0000
+++ b/distrib/sets/lists/tests/mi       Fri Jun 12 11:04:44 2020 +0000
@@ -1,4 +1,4 @@
-# $NetBSD: mi,v 1.842 2020/06/06 21:26:00 thorpej Exp $
+# $NetBSD: mi,v 1.843 2020/06/12 11:04:44 roy Exp $
 #
 # Note: don't delete entries from here - mark them as "obsolete" instead.
 #
@@ -3884,7 +3884,7 @@
 ./usr/tests/net/ndp/Kyuafile                   tests-net-tests         atf,rump,kyua
 ./usr/tests/net/ndp/t_dad                      tests-net-tests         atf,rump
 ./usr/tests/net/ndp/t_ndp                      tests-net-tests         atf,rump
-./usr/tests/net/ndp/t_ra                       tests-net-tests         atf,rump
+./usr/tests/net/ndp/t_ra                       tests-obsolete          obsolete
 ./usr/tests/net/net                            tests-net-tests         compattestfile,atf
 ./usr/tests/net/net/Atffile                    tests-net-tests         compattestfile,atf
 ./usr/tests/net/net/Kyuafile                   tests-net-tests         compattestfile,atf,kyua
diff -r 7c7fec33c495 -r 4c5561184091 etc/mtree/Makefile
--- a/etc/mtree/Makefile        Fri Jun 12 10:35:59 2020 +0000
+++ b/etc/mtree/Makefile        Fri Jun 12 11:04:44 2020 +0000
@@ -1,4 +1,4 @@
-#      $NetBSD: Makefile,v 1.42 2020/05/18 21:19:34 jmcneill Exp $
+#      $NetBSD: Makefile,v 1.43 2020/06/12 11:04:44 roy Exp $
 
 .include <bsd.own.mk>
 
@@ -57,9 +57,9 @@
 .endif
 .endif
 
-.if ${MKDTB} != "no"
-EXTRA_DIST_FILES+=     NetBSD.dist.dtb
-.endif
+#.if ${MKDTB} != "no"
+#EXTRA_DIST_FILES+=    NetBSD.dist.dtb
+#.endif
 
 .if ${MKDTRACE} != "no"
 EXTRA_DIST_FILES+=     NetBSD.dist.dtrace
diff -r 7c7fec33c495 -r 4c5561184091 etc/rc.d/network
--- a/etc/rc.d/network  Fri Jun 12 10:35:59 2020 +0000
+++ b/etc/rc.d/network  Fri Jun 12 11:04:44 2020 +0000
@@ -1,6 +1,6 @@
 #!/bin/sh
 #
-# $NetBSD: network,v 1.78 2020/04/15 20:31:57 kim Exp $
+# $NetBSD: network,v 1.79 2020/06/12 11:04:45 roy Exp $
 #
 
 # PROVIDE: network
@@ -50,7 +50,6 @@
        network_start_defaultroute
        network_start_defaultroute6
        have_inet6 &&
-       network_start_ipv6_autoconf
        network_wait_dad
        network_start_resolv
        network_start_local
@@ -171,7 +170,6 @@
        /sbin/route -q add -inet6 ::0.0.0.0 -prefixlen 96 ::1 -reject
 
        /sbin/sysctl -qw net.inet6.ip6.forwarding=0
-       /sbin/sysctl -qw net.inet6.ip6.accept_rtadv=0
 
        case $ip6mode in
        router)
@@ -187,8 +185,10 @@
                ;;
 
        autohost)
-               echo 'IPv6 mode: autoconfigured host'
-               /sbin/sysctl -qw net.inet6.ip6.accept_rtadv=1
+               if ! checkyesno dhcpcd; then
+                       warn "rtsol and kernel ra handling have been removed"
+                       warn "please configure dhcpcd in its place."
+               fi
                ;;
 
        host)   
@@ -319,15 +319,14 @@
                                ;;
                        dhcp)
                                if ! checkyesno dhcpcd; then
-                                       /sbin/dhcpcd -n \
+                                       /sbin/dhcpcd -n --dhcp \
                                                ${dhcpcd_flags} $int
                                fi
                                ;;
                        rtsol)
                                if ! checkyesno dhcpcd; then
-                                       /sbin/sysctl -qw \
-                                               net.inet6.ip6.accept_rtadv=1
-                                       /sbin/dhcpcd -q6T --nodhcp6 $int
+                                       /sbin/dhcpcd -n --ipv6rs \
+                                               ${dhcpcd_flags} $int
                                fi
                                ;;
                        *)
@@ -439,20 +438,6 @@
        fi
 }
 
-network_start_ipv6_autoconf()
-{
-       # IPv6 interface autoconfiguration.
-
-       # dhcpcd will ensure DAD completes before forking
-       if checkyesnox rtsol && ! checkyesno dhcpcd; then
-               if [ "$ip6mode" = "autohost" ]; then
-                       echo
-                       warn "rtsol has been removed, " \
-                           "please configure dhcpcd in its place."
-               fi
-       fi
-}
-
 network_wait_dad()
 {
        # Wait for the DAD flags to clear from all addresses.
diff -r 7c7fec33c495 -r 4c5561184091 sys/compat/common/if_43.c
--- a/sys/compat/common/if_43.c Fri Jun 12 10:35:59 2020 +0000
+++ b/sys/compat/common/if_43.c Fri Jun 12 11:04:44 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: if_43.c,v 1.24 2019/12/12 02:15:42 pgoyette Exp $      */
+/*     $NetBSD: if_43.c,v 1.25 2020/06/12 11:04:45 roy Exp $   */
 
 /*
  * Copyright (c) 1982, 1986, 1989, 1990, 1993
@@ -32,7 +32,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: if_43.c,v 1.24 2019/12/12 02:15:42 pgoyette Exp $");
+__KERNEL_RCSID(0, "$NetBSD: if_43.c,v 1.25 2020/06/12 11:04:45 roy Exp $");
 
 #if defined(_KERNEL_OPT)
 #include "opt_compat_netbsd.h"
@@ -164,7 +164,6 @@
                case SIOCDIFADDR:
                case SIOCDIFADDR_IN6:
                case SIOCDIFPHYADDR:
-               case SIOCGDEFIFACE_IN6:
                case SIOCG80211NWID:
                case SIOCG80211STATS:
                case SIOCG80211ZSTATS:
@@ -192,7 +191,6 @@
                case SIOCIFCREATE:
                case SIOCIFDESTROY:
                case SIOCS80211NWID:
-               case SIOCSDEFIFACE_IN6:
                case SIOCSIFADDR:
                case SIOCSIFADDR_IN6:
                case SIOCSIFBRDADDR:
@@ -205,9 +203,6 @@
                case SIOCSIFMTU:
                case SIOCSIFNETMASK:
                case SIOCSIFNETMASK_IN6:
-               case SIOCSNDFLUSH_IN6:
-               case SIOCSPFXFLUSH_IN6:
-               case SIOCSRTRFLUSH_IN6:
                case SIOCSVH:
                case TAPGIFNAME:
                        return ncmd;
diff -r 7c7fec33c495 -r 4c5561184091 sys/compat/netinet6/in6_var.h
--- a/sys/compat/netinet6/in6_var.h     Fri Jun 12 10:35:59 2020 +0000
+++ b/sys/compat/netinet6/in6_var.h     Fri Jun 12 11:04:44 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: in6_var.h,v 1.5 2019/12/15 16:48:26 tsutsui Exp $      */
+/*     $NetBSD: in6_var.h,v 1.6 2020/06/12 11:04:45 roy Exp $  */
 
 /*-
  * Copyright (c) 2008 The NetBSD Foundation, Inc.
@@ -49,9 +49,27 @@
        struct in6_addrlifetime50 ifra_lifetime;
 };
 
-#define OSIOCGIFALIFETIME_IN6  _IOWR('i', 81, struct in6_ifreq)
+struct prf_ra {
+       u_int32_t onlink : 1;
+       u_int32_t autonomous : 1;
+       u_int32_t router : 1;
+       u_int32_t reserved : 5;
+};
+
 #define OSIOCAIFADDR_IN6       _IOW('i', 26, struct in6_aliasreq50)
 #define OSIOCSIFPHYADDR_IN6    _IOW('i', 70, struct in6_aliasreq50)
+#define OSIOCGDRLST_IN6                _IOWR('i', 74, struct in6_drlist)
+#define OSIOCGPRLST_IN6                _IOWR('i', 75, struct in6_oprlist)
+#define OSIOCGIFINFO_IN6       _IOWR('i', 76, struct in6_ondireq)
+#define OSIOCSNDFLUSH_IN6      _IOWR('i', 77, struct in6_ifreq)
+#define OSIOCSPFXFLUSH_IN6     _IOWR('i', 79, struct in6_ifreq)
+#define OSIOCSRTRFLUSH_IN6     _IOWR('i', 80, struct in6_ifreq)
+#define OSIOCGIFALIFETIME_IN6  _IOWR('i', 81, struct in6_ifreq)
+#define OSIOCSDEFIFACE_IN6     _IOWR('i', 85, struct in6_ndifreq90)
+#define OSIOCGDEFIFACE_IN6     _IOWR('i', 86, struct in6_ndifreq90)
+#define OSIOCSIFINFO_FLAGS_90  _IOWR('i', 87, struct in6_ndireq90)
+#define OSIOCGIFINFO_IN6_90    _IOWR('i', 108, struct in6_ndireq90)
+#define OSIOCSIFINFO_IN6_90    _IOWR('i', 109, struct in6_ndireq90)
 
 static __inline void in6_addrlifetime_to_in6_addrlifetime50(
     struct in6_addrlifetime *al)
diff -r 7c7fec33c495 -r 4c5561184091 sys/net/if.c
--- a/sys/net/if.c      Fri Jun 12 10:35:59 2020 +0000
+++ b/sys/net/if.c      Fri Jun 12 11:04:44 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: if.c,v 1.477 2020/05/05 09:26:29 jdolecek Exp $        */
+/*     $NetBSD: if.c,v 1.478 2020/06/12 11:04:45 roy Exp $     */
 
 /*-
  * Copyright (c) 1999, 2000, 2001, 2008 The NetBSD Foundation, Inc.
@@ -90,7 +90,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: if.c,v 1.477 2020/05/05 09:26:29 jdolecek Exp $");
+__KERNEL_RCSID(0, "$NetBSD: if.c,v 1.478 2020/06/12 11:04:45 roy Exp $");
 
 #if defined(_KERNEL_OPT)
 #include "opt_inet.h"
@@ -3139,15 +3139,6 @@
                if (ifp->if_mtu == ifr->ifr_mtu)
                        break;
                ifp->if_mtu = ifr->ifr_mtu;
-               /*
-                * If the link MTU changed, do network layer specific procedure.
-                */
-#ifdef INET6
-               KERNEL_LOCK_UNLESS_NET_MPSAFE();
-               if (in6_present)
-                       nd6_setmtu(ifp);
-               KERNEL_UNLOCK_UNLESS_NET_MPSAFE();
-#endif
                return ENETRESET;
        case SIOCSIFDESCR:
                error = kauth_authorize_network(curlwp->l_cred,
diff -r 7c7fec33c495 -r 4c5561184091 sys/net/if_vlan.c
--- a/sys/net/if_vlan.c Fri Jun 12 10:35:59 2020 +0000
+++ b/sys/net/if_vlan.c Fri Jun 12 11:04:44 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: if_vlan.c,v 1.151 2020/02/01 02:58:15 riastradh Exp $  */
+/*     $NetBSD: if_vlan.c,v 1.152 2020/06/12 11:04:45 roy Exp $        */
 
 /*
  * Copyright (c) 2000, 2001 The NetBSD Foundation, Inc.
@@ -78,7 +78,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: if_vlan.c,v 1.151 2020/02/01 02:58:15 riastradh Exp $");
+__KERNEL_RCSID(0, "$NetBSD: if_vlan.c,v 1.152 2020/06/12 11:04:45 roy Exp $");
 
 #ifdef _KERNEL_OPT
 #include "opt_inet.h"
@@ -541,12 +541,6 @@
        nmib->ifvm_p = p;
        nmib->ifvm_tag = vid;
        ifv->ifv_if.if_mtu = p->if_mtu - nmib->ifvm_mtufudge;
-#ifdef INET6
-       KERNEL_LOCK_UNLESS_NET_MPSAFE();
-       if (in6_present)
-               nd6_setmtu(ifp);
-       KERNEL_UNLOCK_UNLESS_NET_MPSAFE();
-#endif
        ifv->ifv_if.if_flags = p->if_flags &
            (IFF_UP | IFF_BROADCAST | IFF_SIMPLEX | IFF_MULTICAST);
 
diff -r 7c7fec33c495 -r 4c5561184091 sys/netinet/icmp6.h
--- a/sys/netinet/icmp6.h       Fri Jun 12 10:35:59 2020 +0000
+++ b/sys/netinet/icmp6.h       Fri Jun 12 11:04:44 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: icmp6.h,v 1.53 2020/03/09 21:20:55 roy Exp $   */
+/*     $NetBSD: icmp6.h,v 1.54 2020/06/12 11:04:45 roy Exp $   */
 /*     $KAME: icmp6.h,v 1.84 2003/04/23 10:26:51 itojun Exp $  */
 
 
@@ -633,8 +633,10 @@
 #define ICMPV6CTL_MTUDISC_HIWAT        16
 #define ICMPV6CTL_MTUDISC_LOWAT        17
 #define ICMPV6CTL_ND6_DEBUG    18
-#define ICMPV6CTL_ND6_DRLIST   19
-#define ICMPV6CTL_ND6_PRLIST   20
+#ifdef _KERNEL
+#define OICMPV6CTL_ND6_DRLIST  19
+#define OICMPV6CTL_ND6_PRLIST  20
+#endif
 #define        ICMPV6CTL_ND6_MAXQLEN   24
 
 #ifdef _KERNEL
diff -r 7c7fec33c495 -r 4c5561184091 sys/netinet/tcp_output.c
--- a/sys/netinet/tcp_output.c  Fri Jun 12 10:35:59 2020 +0000
+++ b/sys/netinet/tcp_output.c  Fri Jun 12 11:04:44 2020 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: tcp_output.c,v 1.212 2019/11/17 08:21:25 mlelstv Exp $ */
+/*     $NetBSD: tcp_output.c,v 1.213 2020/06/12 11:04:45 roy Exp $     */
 
 /*
  * Copyright (C) 1995, 1996, 1997, and 1998 WIDE Project.
@@ -135,7 +135,7 @@
  */



Home | Main Index | Thread Index | Old Index