summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorYu Watanabe <watanabe.yu+github@gmail.com>2020-10-28 15:07:06 +0900
committerYu Watanabe <watanabe.yu+github@gmail.com>2020-10-28 15:44:10 +0900
commita41768533f2517a1d4c4a1df483ff0a462b4604a (patch)
treebd3ce038b64a8ee9627a0cfb471fbed6312807f3
parente69642dccc19598017abf9223e3b2e5e4c92664a (diff)
downloadsystemd-a41768533f2517a1d4c4a1df483ff0a462b4604a.tar.gz
network: always enable sysctl property promote_secondaries
systemd-sysctl already enables promote_secondaries for all interface. So, networkd also enables it unconditionally.
-rw-r--r--src/network/networkd-dhcp4.c55
-rw-r--r--src/network/networkd-sysctl.c9
2 files changed, 9 insertions, 55 deletions
diff --git a/src/network/networkd-dhcp4.c b/src/network/networkd-dhcp4.c
index b9a98a56a8..55526b107c 100644
--- a/src/network/networkd-dhcp4.c
+++ b/src/network/networkd-dhcp4.c
@@ -1176,57 +1176,6 @@ static int dhcp4_set_hostname(Link *link) {
return 0;
}
-static bool promote_secondaries_enabled(const char *ifname) {
- _cleanup_free_ char *promote_secondaries_sysctl = NULL;
- char *promote_secondaries_path;
- int r;
-
- promote_secondaries_path = strjoina("net/ipv4/conf/", ifname, "/promote_secondaries");
- r = sysctl_read(promote_secondaries_path, &promote_secondaries_sysctl);
- if (r < 0) {
- log_debug_errno(r, "Cannot read sysctl %s", promote_secondaries_path);
- return false;
- }
-
- truncate_nl(promote_secondaries_sysctl);
- r = parse_boolean(promote_secondaries_sysctl);
- if (r < 0)
- log_warning_errno(r, "Cannot parse sysctl %s with content %s as boolean", promote_secondaries_path, promote_secondaries_sysctl);
- return r > 0;
-}
-
-/* dhcp4_set_promote_secondaries will ensure this interface has
- * the "promote_secondaries" option in the kernel set. If this sysctl
- * is not set DHCP will work only as long as the IP address does not
- * changes between leases. The kernel will remove all secondary IP
- * addresses of an interface otherwise. The way systemd-network works
- * is that the new IP of a lease is added as a secondary IP and when
- * the primary one expires it relies on the kernel to promote the
- * secondary IP. See also https://github.com/systemd/systemd/issues/7163
- */
-static int dhcp4_set_promote_secondaries(Link *link) {
- int r;
-
- assert(link);
-
- /* check if the kernel has promote_secondaries enabled for our
- * interface. If it is not globally enabled or enabled for the
- * specific interface we must either enable it.
- */
- if (!(promote_secondaries_enabled("all") || promote_secondaries_enabled(link->ifname))) {
- char *promote_secondaries_path = NULL;
-
- log_link_debug(link, "promote_secondaries is unset, setting it");
- promote_secondaries_path = strjoina("net/ipv4/conf/", link->ifname, "/promote_secondaries");
- r = sysctl_write(promote_secondaries_path, "1");
- if (r < 0)
- log_link_warning_errno(link, r, "Failed to set sysctl %s to 1, ignoring", promote_secondaries_path);
- return r > 0;
- }
-
- return 0;
-}
-
static int dhcp4_set_client_identifier(Link *link) {
int r;
@@ -1320,10 +1269,6 @@ int dhcp4_configure(Link *link) {
if (!link_dhcp4_enabled(link))
return 0;
- r = dhcp4_set_promote_secondaries(link);
- if (r < 0)
- return r;
-
if (!link->dhcp_client) {
r = sd_dhcp_client_new(&link->dhcp_client, link->network->dhcp_anonymize);
if (r < 0)
diff --git a/src/network/networkd-sysctl.c b/src/network/networkd-sysctl.c
index b6839f86ee..dc95d01934 100644
--- a/src/network/networkd-sysctl.c
+++ b/src/network/networkd-sysctl.c
@@ -212,6 +212,15 @@ int link_set_sysctl(Link *link) {
if (r < 0)
log_link_warning_errno(link, r, "Cannot set IPv4 accept_local flag for interface, ignoring: %m");
+ /* If promote_secondaries is not set, DHCP will work only as long as the IP address does not
+ * changes between leases. The kernel will remove all secondary IP addresses of an interface
+ * otherwise. The way systemd-networkd works is that the new IP of a lease is added as a
+ * secondary IP and when the primary one expires it relies on the kernel to promote the
+ * secondary IP. See also https://github.com/systemd/systemd/issues/7163 */
+ r = sysctl_write_ip_property_boolean(AF_INET, link->ifname, "promote_secondaries", true);
+ if (r < 0)
+ log_link_warning_errno(link, r, "Cannot enable promote_secondaries for interface, ignoring: %m");
+
return 0;
}