diff options
author | kmacy <kmacy@FreeBSD.org> | 2007-12-16 06:42:33 +0000 |
---|---|---|
committer | kmacy <kmacy@FreeBSD.org> | 2007-12-16 06:42:33 +0000 |
commit | 60377b3fbd3ef0aadb9ce81f7850c10fe7a4c654 (patch) | |
tree | 41bdc4498eaba53db3724252ec020c4a67b0f7de | |
parent | 4ec9caf00c407884fc51ff18adb8ff16a5eb75c0 (diff) | |
download | FreeBSD-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.c | 8 |
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); |