diff --git a/src/network/networkd-link.c b/src/network/networkd-link.c index e6a1cfd5d21..f894bb5c582 100644 --- a/src/network/networkd-link.c +++ b/src/network/networkd-link.c @@ -592,8 +592,8 @@ static void link_detach_from_manager(Link *link) { } static Link *link_free(Link *link) { + Link *carrier, *master; Address *address; - Link *carrier; Route *route; Iterator i; @@ -661,6 +661,12 @@ static Link *link_free(Link *link) { hashmap_free(link->bond_slaves); + if (link->network) { + if (link->network->bond && + link_get(link->manager, link->network->bond->ifindex, &master) >= 0) + (void) hashmap_remove(master->bond_slaves, INT_TO_PTR(link->ifindex)); + } + return mfree(link); } diff --git a/src/network/networkd-manager.c b/src/network/networkd-manager.c index 8eb6e86c337..00f6545e24f 100644 --- a/src/network/networkd-manager.c +++ b/src/network/networkd-manager.c @@ -1427,9 +1427,6 @@ void manager_free(Manager *m) { sd_netlink_unref(m->genl); sd_resolve_unref(m->resolve); - while ((network = m->networks)) - network_free(network); - while ((link = hashmap_first(m->dhcp6_prefixes))) manager_dhcp6_prefix_remove_all(m, link); hashmap_free(m->dhcp6_prefixes); @@ -1445,6 +1442,9 @@ void manager_free(Manager *m) { m->links_requesting_uuid = set_free(m->links_requesting_uuid); set_free(m->duids_requesting_uuid); + while ((network = m->networks)) + network_free(network); + hashmap_free(m->networks_by_name); m->netdevs = hashmap_free_with_destructor(m->netdevs, netdev_unref);