slirp/arp: do not special-case bogus IP addresses
Do not special-case addresses with zero host part, as we do not necessarily know how big it is, and the guest can fake them anyway. Silently avoid having 0.0.0.0 as a destination, however. Signed-off-by: Samuel Thibault <samuel.thibault@ens-lyon.org> [Edgar: Minor change to subject] Reviewed-by: Edgar E. Iglesias <edgar.iglesias@xilinx.com> Signed-off-by: Edgar E. Iglesias <edgar.iglesias@xilinx.com>
This commit is contained in:
parent
37654d9e6a
commit
959e41473f
@ -37,12 +37,7 @@ void arp_table_add(Slirp *slirp, uint32_t ip_addr, uint8_t ethaddr[ETH_ALEN])
|
|||||||
ethaddr[0], ethaddr[1], ethaddr[2],
|
ethaddr[0], ethaddr[1], ethaddr[2],
|
||||||
ethaddr[3], ethaddr[4], ethaddr[5]));
|
ethaddr[3], ethaddr[4], ethaddr[5]));
|
||||||
|
|
||||||
/* Check 0.0.0.0/8 invalid source-only addresses */
|
if (ip_addr == 0 || ip_addr == 0xffffffff || ip_addr == broadcast_addr) {
|
||||||
if ((ip_addr & htonl(~(0xfU << 28))) == 0) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (ip_addr == 0xffffffff || ip_addr == broadcast_addr) {
|
|
||||||
/* Do not register broadcast addresses */
|
/* Do not register broadcast addresses */
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -73,9 +68,6 @@ bool arp_table_search(Slirp *slirp, uint32_t ip_addr,
|
|||||||
DEBUG_CALL("arp_table_search");
|
DEBUG_CALL("arp_table_search");
|
||||||
DEBUG_ARG("ip = 0x%x", ip_addr);
|
DEBUG_ARG("ip = 0x%x", ip_addr);
|
||||||
|
|
||||||
/* Check 0.0.0.0/8 invalid source-only addresses */
|
|
||||||
assert((ip_addr & htonl(~(0xfU << 28))) != 0);
|
|
||||||
|
|
||||||
/* If broadcast address */
|
/* If broadcast address */
|
||||||
if (ip_addr == 0xffffffff || ip_addr == broadcast_addr) {
|
if (ip_addr == 0xffffffff || ip_addr == broadcast_addr) {
|
||||||
/* return Ethernet broadcast address */
|
/* return Ethernet broadcast address */
|
||||||
|
@ -778,6 +778,11 @@ int if_encap(Slirp *slirp, struct mbuf *ifm)
|
|||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (iph->ip_dst.s_addr == 0) {
|
||||||
|
/* 0.0.0.0 can not be a destination address, something went wrong,
|
||||||
|
* avoid making it worse */
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
if (!arp_table_search(slirp, iph->ip_dst.s_addr, ethaddr)) {
|
if (!arp_table_search(slirp, iph->ip_dst.s_addr, ethaddr)) {
|
||||||
uint8_t arp_req[ETH_HLEN + sizeof(struct arphdr)];
|
uint8_t arp_req[ETH_HLEN + sizeof(struct arphdr)];
|
||||||
struct ethhdr *reh = (struct ethhdr *)arp_req;
|
struct ethhdr *reh = (struct ethhdr *)arp_req;
|
||||||
|
Loading…
Reference in New Issue
Block a user