summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorkmacy <kmacy@FreeBSD.org>2007-12-16 06:42:33 +0000
committerkmacy <kmacy@FreeBSD.org>2007-12-16 06:42:33 +0000
commit60377b3fbd3ef0aadb9ce81f7850c10fe7a4c654 (patch)
tree41bdc4498eaba53db3724252ec020c4a67b0f7de
parent4ec9caf00c407884fc51ff18adb8ff16a5eb75c0 (diff)
downloadFreeBSD-src-60377b3fbd3ef0aadb9ce81f7850c10fe7a4c654.zip
FreeBSD-src-60377b3fbd3ef0aadb9ce81f7850c10fe7a4c654.tar.gz
Move arp update upcall to always be called for ARP replies - previous invocation
would not always get called at the appropriate times
-rw-r--r--sys/netinet/if_ether.c8
1 files changed, 4 insertions, 4 deletions
diff --git a/sys/netinet/if_ether.c b/sys/netinet/if_ether.c
index 33e7704..86544aa 100644
--- a/sys/netinet/if_ether.c
+++ b/sys/netinet/if_ether.c
@@ -668,6 +668,10 @@ match:
goto reply;
rt = arplookup(isaddr.s_addr, itaddr.s_addr == myaddr.s_addr, 0);
if (rt != NULL) {
+ sin.sin_addr.s_addr = isaddr.s_addr;
+ EVENTHANDLER_INVOKE(route_event, RTEVENT_ARP_UPDATE, rt, NULL,
+ (struct sockaddr *)&sin);
+
la = (struct llinfo_arp *)rt->rt_llinfo;
if (la == NULL) {
RT_UNLOCK(rt);
@@ -775,10 +779,6 @@ match:
la->la_preempt = arp_maxtries;
hold = la->la_hold;
la->la_hold = NULL;
-
- sin.sin_addr.s_addr = ntohl(itaddr.s_addr);
- EVENTHANDLER_INVOKE(route_event, RTEVENT_ARP_UPDATE, rt, NULL,
- (struct sockaddr *)&sin);
RT_UNLOCK(rt);
if (hold != NULL)
(*ifp->if_output)(ifp, hold, rt_key(rt), rt);
OpenPOWER on IntegriCloud