summaryrefslogtreecommitdiffstats
path: root/sys/netinet/if_ether.c
diff options
context:
space:
mode:
Diffstat (limited to 'sys/netinet/if_ether.c')
-rw-r--r--sys/netinet/if_ether.c13
1 files changed, 8 insertions, 5 deletions
diff --git a/sys/netinet/if_ether.c b/sys/netinet/if_ether.c
index d24b459..734dd02 100644
--- a/sys/netinet/if_ether.c
+++ b/sys/netinet/if_ether.c
@@ -96,8 +96,6 @@ static int arp_proxyall;
SYSCTL_V_INT(V_NET, vnet_inet, _net_link_ether_inet, OID_AUTO, max_age,
CTLFLAG_RW, arpt_keep, 0, "ARP entry lifetime in seconds");
-static struct ifqueue arpintrq;
-
SYSCTL_V_INT(V_NET, vnet_inet, _net_link_ether_inet, OID_AUTO, maxtries,
CTLFLAG_RW, arp_maxtries, 0,
"ARP resolution attempts before returning error");
@@ -118,6 +116,13 @@ static void arptimer(void *);
static void in_arpinput(struct mbuf *);
#endif
+static const struct netisr_handler arp_nh = {
+ .nh_name = "arp",
+ .nh_handler = arpintr,
+ .nh_proto = NETISR_ARP,
+ .nh_policy = NETISR_POLICY_SOURCE,
+};
+
#ifndef VIMAGE_GLOBALS
static const vnet_modinfo_t vnet_arp_modinfo = {
.vmi_id = VNET_MOD_ARP,
@@ -823,8 +828,6 @@ arp_init(void)
arp_iattach(NULL);
#endif
- arpintrq.ifq_maxlen = 50;
- mtx_init(&arpintrq.ifq_mtx, "arp_inq", NULL, MTX_DEF);
- netisr_register(NETISR_ARP, arpintr, &arpintrq, 0);
+ netisr_register(&arp_nh);
}
SYSINIT(arp, SI_SUB_PROTO_DOMAIN, SI_ORDER_ANY, arp_init, 0);
OpenPOWER on IntegriCloud