summaryrefslogtreecommitdiff
path: root/src/network/networkd-network.c
diff options
context:
space:
mode:
authorYu Watanabe <watanabe.yu+github@gmail.com>2022-06-14 15:44:42 +0900
committerDaan De Meyer <daan.j.demeyer@gmail.com>2022-06-27 15:52:31 +0200
commit54e0cfc44ef5d141ebf907ae9c85df61f6b7cf7f (patch)
tree429ffe91a1c0a4c0926a4282ee38860f215ccf57 /src/network/networkd-network.c
parentb09a5659e2c3aded7382b9c946dafd9eb528c195 (diff)
downloadsystemd-54e0cfc44ef5d141ebf907ae9c85df61f6b7cf7f.tar.gz
network: grouping elements in network_free()
Diffstat (limited to 'src/network/networkd-network.c')
-rw-r--r--src/network/networkd-network.c79
1 files changed, 46 insertions, 33 deletions
diff --git a/src/network/networkd-network.c b/src/network/networkd-network.c
index 39ea4eddd0..e090a78023 100644
--- a/src/network/networkd-network.c
+++ b/src/network/networkd-network.c
@@ -664,48 +664,83 @@ static Network *network_free(Network *network) {
if (!network)
return NULL;
+ free(network->name);
free(network->filename);
+ free(network->description);
hashmap_free(network->stats_by_path);
+ /* conditions */
net_match_clear(&network->match);
condition_free_list(network->conditions);
+ /* link settings */
+ strv_free(network->bind_carrier);
+
+ /* NTP */
+ strv_free(network->ntp);
+
+ /* DNS */
+ for (unsigned i = 0; i < network->n_dns; i++)
+ in_addr_full_free(network->dns[i]);
+ free(network->dns);
+ ordered_set_free(network->search_domains);
+ ordered_set_free(network->route_domains);
+ set_free_free(network->dnssec_negative_trust_anchors);
+
+ /* DHCP server */
free(network->dhcp_server_relay_agent_circuit_id);
free(network->dhcp_server_relay_agent_remote_id);
free(network->dhcp_server_boot_server_name);
free(network->dhcp_server_boot_filename);
+ free(network->dhcp_server_timezone);
+ free(network->dhcp_server_uplink_name);
+ for (sd_dhcp_lease_server_type_t t = 0; t < _SD_DHCP_LEASE_SERVER_TYPE_MAX; t++)
+ free(network->dhcp_server_emit[t].addresses);
+ ordered_hashmap_free(network->dhcp_server_send_options);
+ ordered_hashmap_free(network->dhcp_server_send_vendor_options);
- free(network->description);
+ /* DHCP client */
free(network->dhcp_vendor_class_identifier);
free(network->dhcp_mudurl);
- strv_free(network->dhcp_user_class);
free(network->dhcp_hostname);
free(network->dhcp_label);
set_free(network->dhcp_deny_listed_ip);
set_free(network->dhcp_allow_listed_ip);
+ strv_free(network->dhcp_user_class);
set_free(network->dhcp_request_options);
- set_free(network->dhcp6_request_options);
+ ordered_hashmap_free(network->dhcp_client_send_options);
+ ordered_hashmap_free(network->dhcp_client_send_vendor_options);
+
+ /* DHCPv6 client */
free(network->dhcp6_mudurl);
strv_free(network->dhcp6_user_class);
strv_free(network->dhcp6_vendor_class);
+ set_free(network->dhcp6_request_options);
+ ordered_hashmap_free(network->dhcp6_client_send_options);
+ ordered_hashmap_free(network->dhcp6_client_send_vendor_options);
- strv_free(network->ntp);
- for (unsigned i = 0; i < network->n_dns; i++)
- in_addr_full_free(network->dns[i]);
- free(network->dns);
- ordered_set_free(network->search_domains);
- ordered_set_free(network->route_domains);
- strv_free(network->bind_carrier);
+ /* DHCP PD */
+ free(network->dhcp_pd_uplink_name);
+ set_free(network->dhcp_pd_tokens);
+ /* Router advertisement */
ordered_set_free(network->router_search_domains);
free(network->router_dns);
+ free(network->router_uplink_name);
+
+ /* NDisc */
set_free(network->ndisc_deny_listed_router);
set_free(network->ndisc_allow_listed_router);
set_free(network->ndisc_deny_listed_prefix);
set_free(network->ndisc_allow_listed_prefix);
set_free(network->ndisc_deny_listed_route_prefix);
set_free(network->ndisc_allow_listed_route_prefix);
+ set_free(network->ndisc_tokens);
+ /* LLDP */
+ free(network->lldp_mudurl);
+
+ /* netdev */
free(network->batadv_name);
free(network->bridge_name);
free(network->bond_name);
@@ -716,6 +751,7 @@ static Network *network_free(Network *network) {
netdev_unref(network->vrf);
hashmap_free_with_destructor(network->stacked_netdevs, netdev_unref);
+ /* static configs */
set_free_free(network->ipv6_proxy_ndp_addresses);
ordered_hashmap_free_with_destructor(network->addresses_by_section, address_free);
hashmap_free_with_destructor(network->routes_by_section, route_free);
@@ -732,29 +768,6 @@ static Network *network_free(Network *network) {
hashmap_free_with_destructor(network->qdiscs_by_section, qdisc_free);
hashmap_free_with_destructor(network->tclasses_by_section, tclass_free);
- free(network->name);
-
- free(network->dhcp_server_timezone);
- free(network->dhcp_server_uplink_name);
- free(network->router_uplink_name);
- free(network->dhcp_pd_uplink_name);
-
- for (sd_dhcp_lease_server_type_t t = 0; t < _SD_DHCP_LEASE_SERVER_TYPE_MAX; t++)
- free(network->dhcp_server_emit[t].addresses);
-
- set_free_free(network->dnssec_negative_trust_anchors);
-
- free(network->lldp_mudurl);
-
- ordered_hashmap_free(network->dhcp_client_send_options);
- ordered_hashmap_free(network->dhcp_client_send_vendor_options);
- ordered_hashmap_free(network->dhcp_server_send_options);
- ordered_hashmap_free(network->dhcp_server_send_vendor_options);
- ordered_hashmap_free(network->dhcp6_client_send_options);
- ordered_hashmap_free(network->dhcp6_client_send_vendor_options);
- set_free(network->dhcp_pd_tokens);
- set_free(network->ndisc_tokens);
-
return mfree(network);
}