Module Name: src
Committed By: roy
Date: Mon Mar 9 17:57:19 UTC 2020
Modified Files:
src/sys/netinet: if_arp.c
Log Message:
arp: report RTM_MISS when removing an unresolved entry in the arp table
Otherwise we only get it when renewing and we've sent too many requests.
This mirrors INET6 behaviour.
To generate a diff of this commit:
cvs rdiff -u -r1.292 -r1.293 src/sys/netinet/if_arp.c
Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.
Modified files:
Index: src/sys/netinet/if_arp.c
diff -u src/sys/netinet/if_arp.c:1.292 src/sys/netinet/if_arp.c:1.293
--- src/sys/netinet/if_arp.c:1.292 Thu Jan 23 17:27:35 2020
+++ src/sys/netinet/if_arp.c Mon Mar 9 17:57:19 2020
@@ -1,4 +1,4 @@
-/* $NetBSD: if_arp.c,v 1.292 2020/01/23 17:27:35 roy Exp $ */
+/* $NetBSD: if_arp.c,v 1.293 2020/03/09 17:57:19 roy 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.292 2020/01/23 17:27:35 roy Exp $");
+__KERNEL_RCSID(0, "$NetBSD: if_arp.c,v 1.293 2020/03/09 17:57:19 roy Exp $");
#ifdef _KERNEL_OPT
#include "opt_ddb.h"
@@ -307,18 +307,22 @@ arptimer(void *arg)
/* Guard against race with other llentry_free(). */
if (lle->la_flags & LLE_LINKED) {
+ int rt_cmd;
+ struct in_addr *in;
+ struct sockaddr_in sin;
+ const char *lladdr;
size_t pkts_dropped;
+ in = &lle->r_l3addr.addr4;
+ sockaddr_in_init(&sin, in, 0);
if (lle->la_flags & LLE_VALID) {
- struct in_addr *in;
- struct sockaddr_in sin;
- const char *lladdr;
-
- in = &lle->r_l3addr.addr4;
- sockaddr_in_init(&sin, in, 0);
+ rt_cmd = RTM_DELETE;
lladdr = (const char *)&lle->ll_addr;
- rt_clonedmsg(RTM_DELETE, sintosa(&sin), lladdr, ifp);
+ } else {
+ rt_cmd = RTM_MISS;
+ lladdr = NULL;
}
+ rt_clonedmsg(rt_cmd, sintosa(&sin), lladdr, ifp);
LLE_REMREF(lle);
pkts_dropped = llentry_free(lle);