aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSamuel Thibault <samuel.thibault@ens-lyon.org>2021-05-09 08:57:38 +0000
committerSamuel Thibault <samuel.thibault@ens-lyon.org>2021-05-09 08:57:38 +0000
commitf23fd3f0fbaecc75d083abf7a6124b3a21b961e1 (patch)
tree40a511ae1b3255eb0d7b7c291c2e04bc67401425
parent61b287a16053172601e88bf99ede5e759fe1842b (diff)
parent1d6a89cc86292e1cda346751f55bd8c7b38d0d29 (diff)
downloadslirp-f23fd3f0fbaecc75d083abf7a6124b3a21b961e1.zip
slirp-f23fd3f0fbaecc75d083abf7a6124b3a21b961e1.tar.gz
slirp-f23fd3f0fbaecc75d083abf7a6124b3a21b961e1.tar.bz2
Merge branch 'master' into 'master'
ndp_table: For unspecified address, return broadcast ethernet address See merge request slirp/libslirp!86
-rw-r--r--src/ndp_table.c7
1 files changed, 6 insertions, 1 deletions
diff --git a/src/ndp_table.c b/src/ndp_table.c
index 41481ca..fdb189d 100644
--- a/src/ndp_table.c
+++ b/src/ndp_table.c
@@ -62,7 +62,12 @@ bool ndp_table_search(Slirp *slirp, struct in6_addr ip_addr,
DEBUG_CALL("ndp_table_search");
DEBUG_ARG("ip = %s", addrstr);
- assert(!in6_zero(&ip_addr));
+ /* If unspecified address */
+ if (in6_zero(&ip_addr)) {
+ /* return Ethernet broadcast address */
+ memset(out_ethaddr, 0xff, ETH_ALEN);
+ return 1;
+ }
/* Multicast address: fec0::abcd:efgh/8 -> 33:33:ab:cd:ef:gh */
if (IN6_IS_ADDR_MULTICAST(&ip_addr)) {