From: Yu Watanabe Date: Sat, 6 Nov 2021 05:12:30 +0000 (+0900) Subject: ether-addr-util: make hw_addr_is_null() return true also for all zero address X-Git-Tag: v250-rc1~327^2 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=refs%2Fpull%2F21271%2Fhead;p=thirdparty%2Fsystemd.git ether-addr-util: make hw_addr_is_null() return true also for all zero address This fixes the following error: --- systemd-networkd[1449490]: ip6tnl0: Saved hardware address: 00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00 systemd-networkd[1449490]: ip6tnl0: Failed to manage link by its new hardware address, ignoring: File exists --- --- diff --git a/src/basic/ether-addr-util.h b/src/basic/ether-addr-util.h index a7f42ccd1af..c5cfdb4233f 100644 --- a/src/basic/ether-addr-util.h +++ b/src/basic/ether-addr-util.h @@ -37,7 +37,8 @@ static inline bool hw_addr_equal(const struct hw_addr_data *a, const struct hw_a return hw_addr_compare(a, b) == 0; } static inline bool hw_addr_is_null(const struct hw_addr_data *addr) { - return hw_addr_equal(addr, &HW_ADDR_NULL); + assert(addr); + return addr->length == 0 || memeqzero(addr->bytes, addr->length); } extern const struct hash_ops hw_addr_hash_ops; diff --git a/src/network/networkctl.c b/src/network/networkctl.c index 6dd05145c95..bb6e0f6b5b7 100644 --- a/src/network/networkctl.c +++ b/src/network/networkctl.c @@ -553,7 +553,7 @@ static int decode_link(sd_netlink_message *m, LinkInfo *info, char **patterns, b info->has_mac_address = netlink_message_read_hw_addr(m, IFLA_ADDRESS, &info->hw_address) >= 0 && - !hw_addr_is_null(&info->hw_address); + info->hw_address.length > 0; info->has_permanent_mac_address = ethtool_get_permanent_macaddr(NULL, info->name, &info->permanent_mac_address) >= 0 && diff --git a/src/network/networkd-link.c b/src/network/networkd-link.c index ab2d42a4820..5136a8820e3 100644 --- a/src/network/networkd-link.c +++ b/src/network/networkd-link.c @@ -2036,7 +2036,7 @@ static int link_update_hardware_address(Link *link, sd_netlink_message *message) if (hw_addr_equal(&link->hw_addr, &addr)) return 0; - if (hw_addr_is_null(&link->hw_addr)) + if (link->hw_addr.length == 0) log_link_debug(link, "Saved hardware address: %s", HW_ADDR_TO_STR(&addr)); else { log_link_debug(link, "Hardware address is changed: %s → %s",