Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/netinet6 inet6: Use generic Neighor Detection rather tha...
details: https://anonhg.NetBSD.org/src/rev/e57ea29ec47b
branches: trunk
changeset: 1014073:e57ea29ec47b
user: roy <roy%NetBSD.org@localhost>
date: Fri Sep 11 15:03:33 2020 +0000
description:
inet6: Use generic Neighor Detection rather than IPv6 specific
No functional change intended.
diffstat:
sys/netinet6/icmp6.c | 48 ++--
sys/netinet6/nd6.c | 420 +++++++++++-------------------------------------
sys/netinet6/nd6.h | 43 +---
sys/netinet6/nd6_nbr.c | 39 ++--
4 files changed, 153 insertions(+), 397 deletions(-)
diffs (truncated from 876 to 300 lines):
diff -r 2d3dfdcb0828 -r e57ea29ec47b sys/netinet6/icmp6.c
--- a/sys/netinet6/icmp6.c Fri Sep 11 15:01:26 2020 +0000
+++ b/sys/netinet6/icmp6.c Fri Sep 11 15:03:33 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: icmp6.c,v 1.246 2020/07/27 14:52:55 roy Exp $ */
+/* $NetBSD: icmp6.c,v 1.247 2020/09/11 15:03:33 roy Exp $ */
/* $KAME: icmp6.c,v 1.217 2001/06/20 15:03:29 jinmei Exp $ */
/*
@@ -62,7 +62,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: icmp6.c,v 1.246 2020/07/27 14:52:55 roy Exp $");
+__KERNEL_RCSID(0, "$NetBSD: icmp6.c,v 1.247 2020/09/11 15:03:33 roy Exp $");
#ifdef _KERNEL_OPT
#include "opt_compat_netbsd.h"
@@ -87,6 +87,7 @@
#include <net/route.h>
#include <net/if_dl.h>
#include <net/if_types.h>
+#include <net/nd.h>
#include <netinet/in.h>
#include <netinet/in_var.h>
@@ -98,9 +99,9 @@
#include <netinet6/icmp6_private.h>
#include <netinet6/mld6_var.h>
#include <netinet6/in6_pcb.h>
-#include <netinet6/nd6.h>
#include <netinet6/in6_ifattach.h>
#include <netinet6/ip6protosw.h>
+#include <netinet6/nd6.h>
#include <netinet6/scope6_var.h>
#ifdef IPSEC
@@ -2953,7 +2954,6 @@
static void
sysctl_net_inet6_icmp6_setup(struct sysctllog **clog)
{
- extern int nd6_maxqueuelen; /* defined in nd6.c */
sysctl_createv(clog, 0, NULL, NULL,
CTLFLAG_PERMANENT,
@@ -3008,23 +3008,37 @@
CTLFLAG_PERMANENT|CTLFLAG_READWRITE,
CTLTYPE_INT, "nd6_delay",
SYSCTL_DESCR("First probe delay time"),
- NULL, 0, &nd6_delay, 0,
+ NULL, 0, &nd6_nd_domain.nd_delay, 0,
CTL_NET, PF_INET6, IPPROTO_ICMPV6,
ICMPV6CTL_ND6_DELAY, CTL_EOL);
sysctl_createv(clog, 0, NULL, NULL,
CTLFLAG_PERMANENT|CTLFLAG_READWRITE,
+ CTLTYPE_INT, "nd6_mmaxtries",
+ SYSCTL_DESCR("Number of multicast discovery attempts"),
+ NULL, 0, &nd6_nd_domain.nd_mmaxtries, 0,
+ CTL_NET, PF_INET6, IPPROTO_ICMPV6,
+ ICMPV6CTL_ND6_MMAXTRIES, CTL_EOL);
+ sysctl_createv(clog, 0, NULL, NULL,
+ CTLFLAG_PERMANENT|CTLFLAG_READWRITE,
CTLTYPE_INT, "nd6_umaxtries",
SYSCTL_DESCR("Number of unicast discovery attempts"),
- NULL, 0, &nd6_umaxtries, 0,
+ NULL, 0, &nd6_nd_domain.nd_umaxtries, 0,
CTL_NET, PF_INET6, IPPROTO_ICMPV6,
ICMPV6CTL_ND6_UMAXTRIES, CTL_EOL);
sysctl_createv(clog, 0, NULL, NULL,
CTLFLAG_PERMANENT|CTLFLAG_READWRITE,
- CTLTYPE_INT, "nd6_mmaxtries",
- SYSCTL_DESCR("Number of multicast discovery attempts"),
- NULL, 0, &nd6_mmaxtries, 0,
+ CTLTYPE_INT, "nd6_maxnudhint",
+ SYSCTL_DESCR("Maximum neighbor unreachable hint count"),
+ NULL, 0, &nd6_nd_domain.nd_maxnudhint, 0,
CTL_NET, PF_INET6, IPPROTO_ICMPV6,
- ICMPV6CTL_ND6_MMAXTRIES, CTL_EOL);
+ ICMPV6CTL_ND6_MAXNUDHINT, CTL_EOL);
+ sysctl_createv(clog, 0, NULL, NULL,
+ CTLFLAG_PERMANENT|CTLFLAG_READWRITE,
+ CTLTYPE_INT, "maxqueuelen",
+ SYSCTL_DESCR("max packet queue len for a unresolved ND"),
+ NULL, 1, &nd6_nd_domain.nd_maxqueuelen, 0,
+ CTL_NET, PF_INET6, IPPROTO_ICMPV6,
+ ICMPV6CTL_ND6_MAXQLEN, CTL_EOL);
sysctl_createv(clog, 0, NULL, NULL,
CTLFLAG_PERMANENT|CTLFLAG_READWRITE,
CTLTYPE_INT, "nd6_useloopback",
@@ -3056,13 +3070,6 @@
ICMPV6CTL_ERRPPSLIMIT, CTL_EOL);
sysctl_createv(clog, 0, NULL, NULL,
CTLFLAG_PERMANENT|CTLFLAG_READWRITE,
- CTLTYPE_INT, "nd6_maxnudhint",
- SYSCTL_DESCR("Maximum neighbor unreachable hint count"),
- NULL, 0, &nd6_maxnudhint, 0,
- CTL_NET, PF_INET6, IPPROTO_ICMPV6,
- ICMPV6CTL_ND6_MAXNUDHINT, CTL_EOL);
- sysctl_createv(clog, 0, NULL, NULL,
- CTLFLAG_PERMANENT|CTLFLAG_READWRITE,
CTLTYPE_INT, "mtudisc_hiwat",
SYSCTL_DESCR("Low mark on MTU Discovery route timers"),
NULL, 0, &icmp6_mtudisc_hiwat, 0,
@@ -3098,13 +3105,6 @@
CTL_NET, PF_INET6, IPPROTO_ICMPV6,
OICMPV6CTL_ND6_PRLIST, CTL_EOL);
#endif
- sysctl_createv(clog, 0, NULL, NULL,
- CTLFLAG_PERMANENT|CTLFLAG_READWRITE,
- CTLTYPE_INT, "maxqueuelen",
- SYSCTL_DESCR("max packet queue len for a unresolved ND"),
- NULL, 1, &nd6_maxqueuelen, 0,
- CTL_NET, PF_INET6, IPPROTO_ICMPV6,
- ICMPV6CTL_ND6_MAXQLEN, CTL_EOL);
}
void
diff -r 2d3dfdcb0828 -r e57ea29ec47b sys/netinet6/nd6.c
--- a/sys/netinet6/nd6.c Fri Sep 11 15:01:26 2020 +0000
+++ b/sys/netinet6/nd6.c Fri Sep 11 15:03:33 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: nd6.c,v 1.271 2020/06/12 11:04:45 roy Exp $ */
+/* $NetBSD: nd6.c,v 1.272 2020/09/11 15:03:33 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.271 2020/06/12 11:04:45 roy Exp $");
+__KERNEL_RCSID(0, "$NetBSD: nd6.c,v 1.272 2020/09/11 15:03:33 roy Exp $");
#ifdef _KERNEL_OPT
#include "opt_compat_netbsd.h"
@@ -62,6 +62,7 @@
#include <net/if_dl.h>
#include <net/if_llatbl.h>
#include <net/if_types.h>
+#include <net/nd.h>
#include <net/route.h>
#include <net/if_ether.h>
#include <net/if_arc.h>
@@ -86,19 +87,11 @@
/* timer values */
int nd6_prune = 1; /* walk list every 1 seconds */
-int nd6_delay = 5; /* delay first probe time 5 second */
-int nd6_umaxtries = 3; /* maximum unicast query */
-int nd6_mmaxtries = 3; /* maximum multicast query */
int nd6_useloopback = 1; /* use loopback interface for local traffic */
-int nd6_gctimer = (60 * 60 * 24); /* 1 day: garbage collection timer */
/* preventing too many loops in ND option parsing */
int nd6_maxndopt = 10; /* max # of ND options allowed */
-int nd6_maxnudhint = 0; /* max # of subsequent upper layer hints */
-
-int nd6_maxqueuelen = 1; /* max # of packets cached in unresolved ND entries */
-
#ifdef ND6_DEBUG
int nd6_debug = 1;
#else
@@ -111,10 +104,16 @@
static void nd6_slowtimo(void *);
static void nd6_free(struct llentry *, int);
-static void nd6_llinfo_timer(void *);
+static bool nd6_nud_enabled(struct ifnet *);
+static unsigned int nd6_llinfo_reachable(struct ifnet *);
+static unsigned int nd6_llinfo_retrans(struct ifnet *);
+static union nd_addr *nd6_llinfo_holdsrc(struct llentry *, union nd_addr *);
+static void nd6_llinfo_output(struct ifnet *, const union nd_addr *,
+ const union nd_addr *, const uint8_t *, const union nd_addr *);
+static void nd6_llinfo_missed(struct ifnet *, const union nd_addr *,
+ struct mbuf *);
static void nd6_timer(void *);
static void nd6_timer_work(struct work *, void *);
-static void clear_llinfo_pqueue(struct llentry *);
static struct nd_opt_hdr *nd6_option(union nd_opts *);
static callout_t nd6_slowtimo_ch;
@@ -122,6 +121,22 @@
static struct workqueue *nd6_timer_wq;
static struct work nd6_timer_wk;
+struct nd_domain nd6_nd_domain = {
+ .nd_family = AF_INET6,
+ .nd_delay = 5, /* delay first probe time 5 second */
+ .nd_mmaxtries = 3, /* maximum unicast query */
+ .nd_umaxtries = 3, /* maximum multicast query */
+ .nd_maxnudhint = 0, /* max # of subsequent upper layer hints */
+ .nd_maxqueuelen = 1, /* max # of packets in unresolved ND entries */
+ .nd_nud_enabled = nd6_nud_enabled,
+ .nd_reachable = nd6_llinfo_reachable,
+ .nd_retrans = nd6_llinfo_retrans,
+ .nd_holdsrc = nd6_llinfo_holdsrc,
+ .nd_output = nd6_llinfo_output,
+ .nd_missed = nd6_llinfo_missed,
+ .nd_free = nd6_free,
+};
+
MALLOC_DEFINE(M_IP6NDP, "NDP", "IPv6 Neighbour Discovery");
void
@@ -129,6 +144,7 @@
{
int error;
+ nd_attach_domain(&nd6_nd_domain);
nd6_nbr_init();
rw_init(&nd6_lock);
@@ -326,44 +342,6 @@
}
/*
- * ND6 timer routine to handle ND6 entries
- */
-void
-nd6_llinfo_settimer(struct llentry *ln, time_t xtick)
-{
-
- CTASSERT(sizeof(time_t) > sizeof(int));
- LLE_WLOCK_ASSERT(ln);
-
- KASSERT(xtick >= 0);
-
- /*
- * We have to take care of a reference leak which occurs if
- * callout_reset overwrites a pending callout schedule. Unfortunately
- * we don't have a mean to know the overwrite, so we need to know it
- * using callout_stop. We need to call callout_pending first to exclude
- * the case that the callout has never been scheduled.
- */
- if (callout_pending(&ln->la_timer)) {
- bool expired = callout_stop(&ln->la_timer);
- if (!expired)
- LLE_REMREF(ln);
- }
-
- ln->ln_expire = time_uptime + xtick / hz;
- LLE_ADDREF(ln);
- if (xtick > INT_MAX) {
- ln->ln_ntick = xtick - INT_MAX;
- callout_reset(&ln->ln_timer_ch, INT_MAX,
- nd6_llinfo_timer, ln);
- } else {
- ln->ln_ntick = 0;
- callout_reset(&ln->ln_timer_ch, xtick,
- nd6_llinfo_timer, ln);
- }
-}
-
-/*
* Gets source address of the first packet in hold queue
* and stores it in @src.
* Returns pointer to @src (if hold queue is not empty) or NULL.
@@ -389,148 +367,67 @@
return src;
}
-static void
-nd6_llinfo_timer(void *arg)
+static union nd_addr *
+nd6_llinfo_holdsrc(struct llentry *ln, union nd_addr *src)
{
- struct llentry *ln = arg;
- struct ifnet *ifp;
- struct nd_kifinfo *ndi;
- bool send_ns = false;
- const struct in6_addr *daddr6 = NULL;
- const struct in6_addr *taddr6 = &ln->r_l3addr.addr6;
- struct sockaddr_in6 dsin6, tsin6;
- struct mbuf *m = NULL;
- bool missed = false;
- SOFTNET_KERNEL_LOCK_UNLESS_NET_MPSAFE();
-
- LLE_WLOCK(ln);
- if ((ln->la_flags & LLE_LINKED) == 0)
- goto out;
- if (ln->ln_ntick > 0) {
- nd6_llinfo_settimer(ln, ln->ln_ntick);
- goto out;
- }
-
- ifp = ln->lle_tbl->llt_ifp;
- KASSERT(ifp != NULL);
-
- ndi = ND_IFINFO(ifp);
+ if (nd6_llinfo_get_holdsrc(ln, &src->nd_addr6) == NULL)
+ return NULL;
+ return src;
+}
- switch (ln->ln_state) {
- case ND6_LLINFO_WAITDELETE:
- LLE_REMREF(ln);
- nd6_free(ln, 0);
Home |
Main Index |
Thread Index |
Old Index