Historically arp(8) did a route lookup for the entry it is
about to add, and failed if it exist and had invalid data link type. Later on, in r201282, this check morphed to other code, but message "proxy entry exists for non 802 device" still left, and now it is printed in a case if route prefix found is equal to current address being added. In other words, when we are trying to add ARP entry for a network address. The message is absolutely unrelated and disappointing in this case. I don't see anything bad with setting ARP entries for network addresses. While useless in usual network, in a /31 RFC3021 it may be necessary. This, remove this code.
This commit is contained in:
parent
4563ba7a0d
commit
120a742b86
@ -387,10 +387,6 @@ set(int argc, char **argv)
|
||||
}
|
||||
addr = (struct sockaddr_inarp *)(rtm + 1);
|
||||
sdl = (struct sockaddr_dl *)(SA_SIZE(addr) + (char *)addr);
|
||||
if (addr->sin_addr.s_addr == dst->sin_addr.s_addr) {
|
||||
printf("set: proxy entry exists for non 802 device\n");
|
||||
return (1);
|
||||
}
|
||||
|
||||
if ((sdl->sdl_family != AF_LINK) ||
|
||||
(rtm->rtm_flags & RTF_GATEWAY) ||
|
||||
|
Loading…
x
Reference in New Issue
Block a user