1
1
mirror of https://github.com/systemd/systemd-stable.git synced 2025-01-11 05:17:44 +03:00

Merge pull request #18320 from yuwata/network-reduce-trigger-network-events

network: do not trigger unnecessary network events
This commit is contained in:
Zbigniew Jędrzejewski-Szmek 2021-01-30 15:30:17 +01:00 committed by GitHub
commit ea3640ac96
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
12 changed files with 75 additions and 152 deletions

View File

@ -1614,7 +1614,7 @@ int path_is_encrypted(const char *path) {
return blockdev_is_encrypted(p, 10 /* safety net: maximum recursion depth */); return blockdev_is_encrypted(p, 10 /* safety net: maximum recursion depth */);
} }
int conservative_rename( int conservative_renameat(
int olddirfd, const char *oldpath, int olddirfd, const char *oldpath,
int newdirfd, const char *newpath) { int newdirfd, const char *newpath) {

View File

@ -143,4 +143,7 @@ int open_parent(const char *path, int flags, mode_t mode);
int path_is_encrypted(const char *path); int path_is_encrypted(const char *path);
int conservative_rename(int olddirfd, const char *oldpath, int newdirfd, const char *newpath); int conservative_renameat(int olddirfd, const char *oldpath, int newdirfd, const char *newpath);
static inline int conservative_rename(const char *oldpath, const char *newpath) {
return conservative_renameat(AT_FDCWD, oldpath, AT_FDCWD, newpath);
}

View File

@ -19,6 +19,7 @@
#include "env-file.h" #include "env-file.h"
#include "fd-util.h" #include "fd-util.h"
#include "fileio.h" #include "fileio.h"
#include "fs-util.h"
#include "hexdecoct.h" #include "hexdecoct.h"
#include "hostname-util.h" #include "hostname-util.h"
#include "in-addr-util.h" #include "in-addr-util.h"
@ -1023,10 +1024,9 @@ int dhcp_lease_save(sd_dhcp_lease *lease, const char *lease_file) {
if (r < 0) if (r < 0)
goto fail; goto fail;
if (rename(temp_path, lease_file) < 0) { r = conservative_rename(temp_path, lease_file);
r = -errno; if (r < 0)
goto fail; goto fail;
}
return 0; return 0;

View File

@ -36,8 +36,6 @@ static int dhcp4_release_old_lease(Link *link) {
log_link_debug(link, "Removing old DHCPv4 address and routes."); log_link_debug(link, "Removing old DHCPv4 address and routes.");
link_dirty(link);
SET_FOREACH(route, link->dhcp_routes_old) { SET_FOREACH(route, link->dhcp_routes_old) {
k = route_remove(route, NULL, link, NULL); k = route_remove(route, NULL, link, NULL);
if (k < 0) if (k < 0)

View File

@ -160,8 +160,6 @@ static int dhcp6_pd_remove_old(Link *link, bool force) {
log_link_debug(link, "Removing old DHCPv6 Prefix Delegation addresses and routes."); log_link_debug(link, "Removing old DHCPv6 Prefix Delegation addresses and routes.");
link_dirty(link);
SET_FOREACH(route, link->dhcp6_pd_routes_old) { SET_FOREACH(route, link->dhcp6_pd_routes_old) {
k = route_remove(route, NULL, link, NULL); k = route_remove(route, NULL, link, NULL);
if (k < 0) if (k < 0)
@ -204,8 +202,6 @@ int dhcp6_pd_remove(Link *link) {
log_link_debug(link, "Removing DHCPv6 Prefix Delegation addresses and routes."); log_link_debug(link, "Removing DHCPv6 Prefix Delegation addresses and routes.");
link_dirty(link);
SET_FOREACH(route, link->dhcp6_pd_routes) { SET_FOREACH(route, link->dhcp6_pd_routes) {
k = route_remove(route, NULL, link, NULL); k = route_remove(route, NULL, link, NULL);
if (k < 0) if (k < 0)
@ -352,12 +348,6 @@ static int dhcp6_pd_address_handler(sd_netlink *rtnl, sd_netlink_message *m, Lin
link_enter_failed(link); link_enter_failed(link);
return 1; return 1;
} }
r = link_set_routes(link);
if (r < 0) {
link_enter_failed(link);
return 1;
}
} }
return 1; return 1;
@ -585,8 +575,6 @@ static int dhcp6_pd_prepare(Link *link) {
if (!link_dhcp6_pd_is_enabled(link)) if (!link_dhcp6_pd_is_enabled(link))
return 0; return 0;
link_dirty(link);
link->dhcp6_pd_address_configured = false; link->dhcp6_pd_address_configured = false;
link->dhcp6_pd_route_configured = false; link->dhcp6_pd_route_configured = false;
link->dhcp6_pd_prefixes_assigned = true; link->dhcp6_pd_prefixes_assigned = true;
@ -618,14 +606,8 @@ static int dhcp6_pd_finalize(Link *link) {
if (link->dhcp6_pd_address_messages == 0) { if (link->dhcp6_pd_address_messages == 0) {
if (link->dhcp6_pd_prefixes_assigned) if (link->dhcp6_pd_prefixes_assigned)
link->dhcp6_pd_address_configured = true; link->dhcp6_pd_address_configured = true;
} else { } else
log_link_debug(link, "Setting DHCPv6 PD addresses"); log_link_debug(link, "Setting DHCPv6 PD addresses");
/* address_handler calls link_set_routes() and link_set_nexthop(). Before they are
* called, the related flags must be cleared. Otherwise, the link becomes configured
* state before routes are configured. */
link->static_routes_configured = false;
link->static_nexthops_configured = false;
}
if (link->dhcp6_pd_route_messages == 0) { if (link->dhcp6_pd_route_messages == 0) {
if (link->dhcp6_pd_prefixes_assigned) if (link->dhcp6_pd_prefixes_assigned)
@ -708,8 +690,6 @@ static int dhcp6_remove_old(Link *link, bool force) {
log_link_debug(link, "Removing old DHCPv6 addresses and routes."); log_link_debug(link, "Removing old DHCPv6 addresses and routes.");
link_dirty(link);
SET_FOREACH(route, link->dhcp6_routes_old) { SET_FOREACH(route, link->dhcp6_routes_old) {
k = route_remove(route, NULL, link, NULL); k = route_remove(route, NULL, link, NULL);
if (k < 0) if (k < 0)
@ -744,8 +724,6 @@ static int dhcp6_remove(Link *link) {
log_link_debug(link, "Removing DHCPv6 addresses and routes."); log_link_debug(link, "Removing DHCPv6 addresses and routes.");
link_dirty(link);
SET_FOREACH(route, link->dhcp6_routes) { SET_FOREACH(route, link->dhcp6_routes) {
k = route_remove(route, NULL, link, NULL); k = route_remove(route, NULL, link, NULL);
if (k < 0) if (k < 0)
@ -962,12 +940,6 @@ static int dhcp6_address_handler(sd_netlink *rtnl, sd_netlink_message *m, Link *
link_enter_failed(link); link_enter_failed(link);
return 1; return 1;
} }
r = link_set_routes(link);
if (r < 0) {
link_enter_failed(link);
return 1;
}
} }
return 1; return 1;
@ -1114,8 +1086,6 @@ static int dhcp6_lease_ip_acquired(sd_dhcp6_client *client, Link *link) {
link->dhcp6_address_configured = false; link->dhcp6_address_configured = false;
link->dhcp6_route_configured = false; link->dhcp6_route_configured = false;
link_dirty(link);
while ((a = set_steal_first(link->dhcp6_addresses))) { while ((a = set_steal_first(link->dhcp6_addresses))) {
r = set_ensure_put(&link->dhcp6_addresses_old, &address_hash_ops, a); r = set_ensure_put(&link->dhcp6_addresses_old, &address_hash_ops, a);
if (r < 0) if (r < 0)
@ -1149,14 +1119,8 @@ static int dhcp6_lease_ip_acquired(sd_dhcp6_client *client, Link *link) {
if (link->dhcp6_address_messages == 0) if (link->dhcp6_address_messages == 0)
link->dhcp6_address_configured = true; link->dhcp6_address_configured = true;
else { else
log_link_debug(link, "Setting DHCPv6 addresses"); log_link_debug(link, "Setting DHCPv6 addresses");
/* address_handler calls link_set_routes() and link_set_nexthop(). Before they are
* called, the related flags must be cleared. Otherwise, the link becomes configured
* state before routes are configured. */
link->static_routes_configured = false;
link->static_nexthops_configured = false;
}
if (link->dhcp6_route_messages == 0) if (link->dhcp6_route_messages == 0)
link->dhcp6_route_configured = true; link->dhcp6_route_configured = true;

View File

@ -16,6 +16,7 @@
#include "ethtool-util.h" #include "ethtool-util.h"
#include "fd-util.h" #include "fd-util.h"
#include "fileio.h" #include "fileio.h"
#include "fs-util.h"
#include "ipvlan.h" #include "ipvlan.h"
#include "missing_network.h" #include "missing_network.h"
#include "netlink-util.h" #include "netlink-util.h"
@ -596,14 +597,13 @@ void link_set_state(Link *link, LinkState state) {
link->state = state; link->state = state;
link_send_changed(link, "AdministrativeState", NULL); link_send_changed(link, "AdministrativeState", NULL);
link_dirty(link);
} }
static void link_enter_unmanaged(Link *link) { static void link_enter_unmanaged(Link *link) {
assert(link); assert(link);
link_set_state(link, LINK_STATE_UNMANAGED); link_set_state(link, LINK_STATE_UNMANAGED);
link_dirty(link);
} }
int link_stop_engines(Link *link, bool may_keep_dhcp) { int link_stop_engines(Link *link, bool may_keep_dhcp) {
@ -675,8 +675,6 @@ void link_enter_failed(Link *link) {
link_set_state(link, LINK_STATE_FAILED); link_set_state(link, LINK_STATE_FAILED);
(void) link_stop_engines(link, false); (void) link_stop_engines(link, false);
link_dirty(link);
} }
static int link_join_netdevs_after_configured(Link *link) { static int link_join_netdevs_after_configured(Link *link) {
@ -717,8 +715,6 @@ static void link_enter_configured(Link *link) {
link_set_state(link, LINK_STATE_CONFIGURED); link_set_state(link, LINK_STATE_CONFIGURED);
(void) link_join_netdevs_after_configured(link); (void) link_join_netdevs_after_configured(link);
link_dirty(link);
} }
void link_check_ready(Link *link) { void link_check_ready(Link *link) {
@ -1605,6 +1601,8 @@ static int link_put_carrier(Link *link, Link *carrier, Hashmap **h) {
if (r < 0) if (r < 0)
return r; return r;
link_dirty(link);
return 0; return 0;
} }
@ -1612,7 +1610,6 @@ static int link_new_bound_by_list(Link *link) {
Manager *m; Manager *m;
Link *carrier; Link *carrier;
int r; int r;
bool list_updated = false;
assert(link); assert(link);
assert(link->manager); assert(link->manager);
@ -1630,20 +1627,13 @@ static int link_new_bound_by_list(Link *link) {
r = link_put_carrier(link, carrier, &link->bound_by_links); r = link_put_carrier(link, carrier, &link->bound_by_links);
if (r < 0) if (r < 0)
return r; return r;
list_updated = true;
} }
} }
if (list_updated)
link_dirty(link);
HASHMAP_FOREACH(carrier, link->bound_by_links) { HASHMAP_FOREACH(carrier, link->bound_by_links) {
r = link_put_carrier(carrier, link, &carrier->bound_to_links); r = link_put_carrier(carrier, link, &carrier->bound_to_links);
if (r < 0) if (r < 0)
return r; return r;
link_dirty(carrier);
} }
return 0; return 0;
@ -1653,7 +1643,6 @@ static int link_new_bound_to_list(Link *link) {
Manager *m; Manager *m;
Link *carrier; Link *carrier;
int r; int r;
bool list_updated = false;
assert(link); assert(link);
assert(link->manager); assert(link->manager);
@ -1671,20 +1660,13 @@ static int link_new_bound_to_list(Link *link) {
r = link_put_carrier(link, carrier, &link->bound_to_links); r = link_put_carrier(link, carrier, &link->bound_to_links);
if (r < 0) if (r < 0)
return r; return r;
list_updated = true;
} }
} }
if (list_updated)
link_dirty(link);
HASHMAP_FOREACH (carrier, link->bound_to_links) { HASHMAP_FOREACH (carrier, link->bound_to_links) {
r = link_put_carrier(carrier, link, &carrier->bound_by_links); r = link_put_carrier(carrier, link, &carrier->bound_by_links);
if (r < 0) if (r < 0)
return r; return r;
link_dirty(carrier);
} }
return 0; return 0;
@ -1713,23 +1695,32 @@ static int link_new_carrier_maps(Link *link) {
} }
static void link_free_bound_to_list(Link *link) { static void link_free_bound_to_list(Link *link) {
bool updated = false;
Link *bound_to; Link *bound_to;
HASHMAP_FOREACH (bound_to, link->bound_to_links) { assert(link);
hashmap_remove(link->bound_to_links, INT_TO_PTR(bound_to->ifindex));
while ((bound_to = hashmap_steal_first(link->bound_to_links))) {
updated = true;
if (hashmap_remove(bound_to->bound_by_links, INT_TO_PTR(link->ifindex))) if (hashmap_remove(bound_to->bound_by_links, INT_TO_PTR(link->ifindex)))
link_dirty(bound_to); link_dirty(bound_to);
} }
if (updated)
link_dirty(link);
return; return;
} }
static void link_free_bound_by_list(Link *link) { static void link_free_bound_by_list(Link *link) {
bool updated = false;
Link *bound_by; Link *bound_by;
HASHMAP_FOREACH (bound_by, link->bound_by_links) { assert(link);
hashmap_remove(link->bound_by_links, INT_TO_PTR(bound_by->ifindex));
while ((bound_by = hashmap_steal_first(link->bound_by_links))) {
updated = true;
if (hashmap_remove(bound_by->bound_to_links, INT_TO_PTR(link->ifindex))) { if (hashmap_remove(bound_by->bound_to_links, INT_TO_PTR(link->ifindex))) {
link_dirty(bound_by); link_dirty(bound_by);
@ -1737,26 +1728,17 @@ static void link_free_bound_by_list(Link *link) {
} }
} }
if (updated)
link_dirty(link);
return; return;
} }
static void link_free_carrier_maps(Link *link) { static void link_free_carrier_maps(Link *link) {
bool list_updated = false;
assert(link); assert(link);
if (!hashmap_isempty(link->bound_to_links)) { link_free_bound_to_list(link);
link_free_bound_to_list(link); link_free_bound_by_list(link);
list_updated = true;
}
if (!hashmap_isempty(link->bound_by_links)) {
link_free_bound_by_list(link);
list_updated = true;
}
if (list_updated)
link_dirty(link);
return; return;
} }
@ -1943,7 +1925,6 @@ static int link_enter_join_netdev(Link *link) {
link_set_state(link, LINK_STATE_CONFIGURING); link_set_state(link, LINK_STATE_CONFIGURING);
link_dirty(link);
link->enslaving = 0; link->enslaving = 0;
if (link->network->bond) { if (link->network->bond) {
@ -2266,9 +2247,8 @@ static int link_reconfigure_internal(Link *link, sd_netlink_message *m, bool for
link_unref(set_remove(link->manager->links_requesting_uuid, link)); link_unref(set_remove(link->manager->links_requesting_uuid, link));
/* Then, apply new .network file */ /* Then, apply new .network file */
r = network_apply(network, link); link->network = network_ref(network);
if (r < 0) link_dirty(link);
return r;
r = link_new_carrier_maps(link); r = link_new_carrier_maps(link);
if (r < 0) if (r < 0)
@ -2276,7 +2256,6 @@ static int link_reconfigure_internal(Link *link, sd_netlink_message *m, bool for
link_set_state(link, LINK_STATE_INITIALIZED); link_set_state(link, LINK_STATE_INITIALIZED);
link->activated = false; link->activated = false;
link_dirty(link);
/* link_configure_duid() returns 0 if it requests product UUID. In that case, /* link_configure_duid() returns 0 if it requests product UUID. In that case,
* link_configure() is called later asynchronously. */ * link_configure() is called later asynchronously. */
@ -2390,9 +2369,8 @@ static int link_initialized_and_synced(Link *link) {
log_link_debug(link, "Ignoring DHCP server for loopback link"); log_link_debug(link, "Ignoring DHCP server for loopback link");
} }
r = network_apply(network, link); link->network = network_ref(network);
if (r < 0) link_dirty(link);
return r;
} }
r = link_new_bound_to_list(link); r = link_new_bound_to_list(link);
@ -3198,10 +3176,9 @@ int link_save(Link *link) {
if (r < 0) if (r < 0)
goto fail; goto fail;
if (rename(temp_path, link->state_file) < 0) { r = conservative_rename(temp_path, link->state_file);
r = -errno; if (r < 0)
goto fail; goto fail;
}
return 0; return 0;

View File

@ -23,6 +23,7 @@
#include "fd-util.h" #include "fd-util.h"
#include "fileio.h" #include "fileio.h"
#include "firewall-util.h" #include "firewall-util.h"
#include "fs-util.h"
#include "local-addresses.h" #include "local-addresses.h"
#include "netlink-util.h" #include "netlink-util.h"
#include "network-internal.h" #include "network-internal.h"
@ -709,10 +710,9 @@ static int manager_save(Manager *m) {
if (r < 0) if (r < 0)
goto fail; goto fail;
if (rename(temp_path, m->state_file) < 0) { r = conservative_rename(temp_path, m->state_file);
r = -errno; if (r < 0)
goto fail; goto fail;
}
if (m->operational_state != operstate) { if (m->operational_state != operstate) {
m->operational_state = operstate; m->operational_state = operstate;

View File

@ -118,6 +118,7 @@ static int ndisc_remove_old_one(Link *link, const struct in6_addr *router, bool
NDiscDNSSL *dnssl; NDiscDNSSL *dnssl;
NDiscRDNSS *rdnss; NDiscRDNSS *rdnss;
int k, r = 0; int k, r = 0;
bool updated = false;
assert(link); assert(link);
assert(router); assert(router);
@ -182,12 +183,19 @@ static int ndisc_remove_old_one(Link *link, const struct in6_addr *router, bool
} }
SET_FOREACH(rdnss, link->ndisc_rdnss) SET_FOREACH(rdnss, link->ndisc_rdnss)
if (rdnss->marked && IN6_ARE_ADDR_EQUAL(&rdnss->router, router)) if (rdnss->marked && IN6_ARE_ADDR_EQUAL(&rdnss->router, router)) {
free(set_remove(link->ndisc_rdnss, rdnss)); free(set_remove(link->ndisc_rdnss, rdnss));
updated = true;
}
SET_FOREACH(dnssl, link->ndisc_dnssl) SET_FOREACH(dnssl, link->ndisc_dnssl)
if (dnssl->marked && IN6_ARE_ADDR_EQUAL(&dnssl->router, router)) if (dnssl->marked && IN6_ARE_ADDR_EQUAL(&dnssl->router, router)) {
free(set_remove(link->ndisc_dnssl, dnssl)); free(set_remove(link->ndisc_dnssl, dnssl));
updated = true;
}
if (updated)
link_dirty(link);
return r; return r;
} }
@ -412,12 +420,6 @@ static int ndisc_address_handler(sd_netlink *rtnl, sd_netlink_message *m, Link *
link_enter_failed(link); link_enter_failed(link);
return 1; return 1;
} }
r = link_set_routes(link);
if (r < 0) {
link_enter_failed(link);
return 1;
}
} }
return 1; return 1;
@ -932,6 +934,7 @@ static int ndisc_router_process_rdnss(Link *link, sd_ndisc_router *rt) {
struct in6_addr router; struct in6_addr router;
NDiscRDNSS *rdnss; NDiscRDNSS *rdnss;
usec_t time_now; usec_t time_now;
bool updated = false;
int n, r; int n, r;
assert(link); assert(link);
@ -993,8 +996,13 @@ static int ndisc_router_process_rdnss(Link *link, sd_ndisc_router *rt) {
if (r < 0) if (r < 0)
return log_oom(); return log_oom();
assert(r > 0); assert(r > 0);
updated = true;
} }
if (updated)
link_dirty(link);
return 0; return 0;
} }
@ -1019,6 +1027,7 @@ static int ndisc_router_process_dnssl(Link *link, sd_ndisc_router *rt) {
uint32_t lifetime; uint32_t lifetime;
usec_t time_now; usec_t time_now;
NDiscDNSSL *dnssl; NDiscDNSSL *dnssl;
bool updated = false;
char **j; char **j;
int r; int r;
@ -1078,8 +1087,13 @@ static int ndisc_router_process_dnssl(Link *link, sd_ndisc_router *rt) {
if (r < 0) if (r < 0)
return log_oom(); return log_oom();
assert(r > 0); assert(r > 0);
updated = true;
} }
if (updated)
link_dirty(link);
return 0; return 0;
} }
@ -1204,8 +1218,6 @@ static int ndisc_router_handler(Link *link, sd_ndisc_router *rt) {
link->ndisc_addresses_configured = false; link->ndisc_addresses_configured = false;
link->ndisc_routes_configured = false; link->ndisc_routes_configured = false;
link_dirty(link);
SET_FOREACH(na, link->ndisc_addresses) SET_FOREACH(na, link->ndisc_addresses)
if (IN6_ARE_ADDR_EQUAL(&na->router, &router.in6)) if (IN6_ARE_ADDR_EQUAL(&na->router, &router.in6))
na->marked = true; na->marked = true;
@ -1244,16 +1256,9 @@ static int ndisc_router_handler(Link *link, sd_ndisc_router *rt) {
if (link->ndisc_addresses_messages == 0) if (link->ndisc_addresses_messages == 0)
link->ndisc_addresses_configured = true; link->ndisc_addresses_configured = true;
else { else
log_link_debug(link, "Setting SLAAC addresses."); log_link_debug(link, "Setting SLAAC addresses.");
/* address_handler calls link_set_routes() and link_set_nexthop(). Before they are
* called, the related flags must be cleared. Otherwise, the link becomes configured
* state before routes are configured. */
link->static_routes_configured = false;
link->static_nexthops_configured = false;
}
if (link->ndisc_routes_messages == 0) if (link->ndisc_routes_messages == 0)
link->ndisc_routes_configured = true; link->ndisc_routes_configured = true;
else else
@ -1340,7 +1345,6 @@ void ndisc_vacuum(Link *link) {
NDiscRDNSS *r; NDiscRDNSS *r;
NDiscDNSSL *d; NDiscDNSSL *d;
usec_t time_now; usec_t time_now;
bool updated = false;
assert(link); assert(link);
@ -1349,19 +1353,12 @@ void ndisc_vacuum(Link *link) {
time_now = now(clock_boottime_or_monotonic()); time_now = now(clock_boottime_or_monotonic());
SET_FOREACH(r, link->ndisc_rdnss) SET_FOREACH(r, link->ndisc_rdnss)
if (r->valid_until < time_now) { if (r->valid_until < time_now)
free(set_remove(link->ndisc_rdnss, r)); free(set_remove(link->ndisc_rdnss, r));
updated = true;
}
SET_FOREACH(d, link->ndisc_dnssl) SET_FOREACH(d, link->ndisc_dnssl)
if (d->valid_until < time_now) { if (d->valid_until < time_now)
free(set_remove(link->ndisc_dnssl, d)); free(set_remove(link->ndisc_dnssl, d));
updated = true;
}
if (updated)
link_dirty(link);
} }
void ndisc_flush(Link *link) { void ndisc_flush(Link *link) {

View File

@ -736,21 +736,6 @@ int network_get(Manager *manager, unsigned short iftype, sd_device *device,
return -ENOENT; return -ENOENT;
} }
int network_apply(Network *network, Link *link) {
assert(network);
assert(link);
link->network = network_ref(network);
if (network->n_dns > 0 ||
!strv_isempty(network->ntp) ||
!ordered_set_isempty(network->search_domains) ||
!ordered_set_isempty(network->route_domains))
link_dirty(link);
return 0;
}
bool network_has_static_ipv6_configurations(Network *network) { bool network_has_static_ipv6_configurations(Network *network) {
Address *address; Address *address;
Route *route; Route *route;

View File

@ -329,7 +329,6 @@ int network_get(Manager *manager, unsigned short iftype, sd_device *device,
const struct ether_addr *mac, const struct ether_addr *permanent_mac, const struct ether_addr *mac, const struct ether_addr *permanent_mac,
enum nl80211_iftype wlan_iftype, const char *ssid, const struct ether_addr *bssid, enum nl80211_iftype wlan_iftype, const char *ssid, const struct ether_addr *bssid,
Network **ret); Network **ret);
int network_apply(Network *network, Link *link);
void network_apply_anonymize_if_set(Network *network); void network_apply_anonymize_if_set(Network *network);
bool network_has_static_ipv6_configurations(Network *network); bool network_has_static_ipv6_configurations(Network *network);

View File

@ -360,7 +360,7 @@ int manager_write_resolv_conf(Manager *m) {
goto fail; goto fail;
} }
r = conservative_rename(AT_FDCWD, temp_path_stub, AT_FDCWD, PRIVATE_STUB_RESOLV_CONF); r = conservative_rename(temp_path_stub, PRIVATE_STUB_RESOLV_CONF);
if (r < 0) if (r < 0)
log_error_errno(r, "Failed to move new %s into place: %m", PRIVATE_STUB_RESOLV_CONF); log_error_errno(r, "Failed to move new %s into place: %m", PRIVATE_STUB_RESOLV_CONF);
@ -370,7 +370,7 @@ int manager_write_resolv_conf(Manager *m) {
log_error_errno(r, "Failed to symlink %s: %m", PRIVATE_STUB_RESOLV_CONF); log_error_errno(r, "Failed to symlink %s: %m", PRIVATE_STUB_RESOLV_CONF);
} }
r = conservative_rename(AT_FDCWD, temp_path_uplink, AT_FDCWD, PRIVATE_UPLINK_RESOLV_CONF); r = conservative_rename(temp_path_uplink, PRIVATE_UPLINK_RESOLV_CONF);
if (r < 0) if (r < 0)
log_error_errno(r, "Failed to move new %s into place: %m", PRIVATE_UPLINK_RESOLV_CONF); log_error_errno(r, "Failed to move new %s into place: %m", PRIVATE_UPLINK_RESOLV_CONF);

View File

@ -847,37 +847,37 @@ static void test_conservative_rename(void) {
/* Check that the hardlinked "copy" is detected */ /* Check that the hardlinked "copy" is detected */
assert_se(link(p, q) >= 0); assert_se(link(p, q) >= 0);
assert_se(conservative_rename(AT_FDCWD, q, AT_FDCWD, p) == 0); assert_se(conservative_renameat(AT_FDCWD, q, AT_FDCWD, p) == 0);
assert_se(access(q, F_OK) < 0 && errno == ENOENT); assert_se(access(q, F_OK) < 0 && errno == ENOENT);
/* Check that a manual copy is detected */ /* Check that a manual copy is detected */
assert_se(copy_file(p, q, 0, (mode_t) -1, 0, 0, COPY_REFLINK) >= 0); assert_se(copy_file(p, q, 0, (mode_t) -1, 0, 0, COPY_REFLINK) >= 0);
assert_se(conservative_rename(AT_FDCWD, q, AT_FDCWD, p) == 0); assert_se(conservative_renameat(AT_FDCWD, q, AT_FDCWD, p) == 0);
assert_se(access(q, F_OK) < 0 && errno == ENOENT); assert_se(access(q, F_OK) < 0 && errno == ENOENT);
/* Check that a manual new writeout is also detected */ /* Check that a manual new writeout is also detected */
assert_se(write_string_file(q, "this is a test", WRITE_STRING_FILE_CREATE) >= 0); assert_se(write_string_file(q, "this is a test", WRITE_STRING_FILE_CREATE) >= 0);
assert_se(conservative_rename(AT_FDCWD, q, AT_FDCWD, p) == 0); assert_se(conservative_renameat(AT_FDCWD, q, AT_FDCWD, p) == 0);
assert_se(access(q, F_OK) < 0 && errno == ENOENT); assert_se(access(q, F_OK) < 0 && errno == ENOENT);
/* Check that a minimally changed version is detected */ /* Check that a minimally changed version is detected */
assert_se(write_string_file(q, "this is a_test", WRITE_STRING_FILE_CREATE) >= 0); assert_se(write_string_file(q, "this is a_test", WRITE_STRING_FILE_CREATE) >= 0);
assert_se(conservative_rename(AT_FDCWD, q, AT_FDCWD, p) > 0); assert_se(conservative_renameat(AT_FDCWD, q, AT_FDCWD, p) > 0);
assert_se(access(q, F_OK) < 0 && errno == ENOENT); assert_se(access(q, F_OK) < 0 && errno == ENOENT);
/* Check that this really is new updated version */ /* Check that this really is new updated version */
assert_se(write_string_file(q, "this is a_test", WRITE_STRING_FILE_CREATE) >= 0); assert_se(write_string_file(q, "this is a_test", WRITE_STRING_FILE_CREATE) >= 0);
assert_se(conservative_rename(AT_FDCWD, q, AT_FDCWD, p) == 0); assert_se(conservative_renameat(AT_FDCWD, q, AT_FDCWD, p) == 0);
assert_se(access(q, F_OK) < 0 && errno == ENOENT); assert_se(access(q, F_OK) < 0 && errno == ENOENT);
/* Make sure we detect extended files */ /* Make sure we detect extended files */
assert_se(write_string_file(q, "this is a_testx", WRITE_STRING_FILE_CREATE) >= 0); assert_se(write_string_file(q, "this is a_testx", WRITE_STRING_FILE_CREATE) >= 0);
assert_se(conservative_rename(AT_FDCWD, q, AT_FDCWD, p) > 0); assert_se(conservative_renameat(AT_FDCWD, q, AT_FDCWD, p) > 0);
assert_se(access(q, F_OK) < 0 && errno == ENOENT); assert_se(access(q, F_OK) < 0 && errno == ENOENT);
/* Make sure we detect truncated files */ /* Make sure we detect truncated files */
assert_se(write_string_file(q, "this is a_test", WRITE_STRING_FILE_CREATE) >= 0); assert_se(write_string_file(q, "this is a_test", WRITE_STRING_FILE_CREATE) >= 0);
assert_se(conservative_rename(AT_FDCWD, q, AT_FDCWD, p) > 0); assert_se(conservative_renameat(AT_FDCWD, q, AT_FDCWD, p) > 0);
assert_se(access(q, F_OK) < 0 && errno == ENOENT); assert_se(access(q, F_OK) < 0 && errno == ENOENT);
} }