From: Yu Watanabe Date: Mon, 16 Mar 2020 09:55:10 +0000 (+0900) Subject: network: add a flag to ignore gateway provided by DHCP server X-Git-Tag: archive/raspbian/246.1-1+rpi1~1^2^2~30 X-Git-Url: https://dgit.raspbian.org/?a=commitdiff_plain;h=63a32d32d7abc39d221808daef43a95510cb691a;p=systemd.git network: add a flag to ignore gateway provided by DHCP server Closes #15117. (cherry picked from commit b453122789ec4c6f39e6ceb9900e0e80a6abeb99) Gbp-Pq: Name network-add-a-flag-to-ignore-gateway-provided-by-DHCP-ser.patch --- diff --git a/man/systemd.network.xml b/man/systemd.network.xml index bd19b766..120347d2 100644 --- a/man/systemd.network.xml +++ b/man/systemd.network.xml @@ -1474,7 +1474,13 @@ "link" scope will be used. For anything else, scope defaults to "global". - + + UseGateway= + + When true (the default), the gateway will be requested from the DHCP server and added to the + routing table with a metric of 1024, and a scope of "link". + + UseTimezone= diff --git a/src/network/networkd-dhcp4.c b/src/network/networkd-dhcp4.c index 13e3e32f..3f658042 100644 --- a/src/network/networkd-dhcp4.c +++ b/src/network/networkd-dhcp4.c @@ -323,6 +323,9 @@ static int link_set_dhcp_routes(Link *link) { } } + if (!link->network->dhcp_use_gateway) + return 0; + r = sd_dhcp_lease_get_router(link->dhcp_lease, &router); if (IN_SET(r, 0, -ENODATA)) log_link_info(link, "DHCP: No gateway received from DHCP server."); @@ -451,7 +454,7 @@ static int dhcp_remove_router(Link *link, sd_dhcp_lease *lease, const struct in_ assert(link); assert(address); - if (!link->network->dhcp_use_routes) + if (!link->network->dhcp_use_gateway) return 0; r = sd_dhcp_lease_get_router(lease, &router); diff --git a/src/network/networkd-network-gperf.gperf b/src/network/networkd-network-gperf.gperf index 920ac41b..f3c73771 100644 --- a/src/network/networkd-network-gperf.gperf +++ b/src/network/networkd-network-gperf.gperf @@ -162,6 +162,7 @@ DHCPv4.UseMTU, config_parse_bool, DHCPv4.UseHostname, config_parse_bool, 0, offsetof(Network, dhcp_use_hostname) DHCPv4.UseDomains, config_parse_dhcp_use_domains, 0, offsetof(Network, dhcp_use_domains) DHCPv4.UseRoutes, config_parse_bool, 0, offsetof(Network, dhcp_use_routes) +DHCPv4.UseGateway, config_parse_bool, 0, offsetof(Network, dhcp_use_gateway) DHCPv4.RequestOptions, config_parse_dhcp_request_options, 0, 0 DHCPv4.Anonymize, config_parse_bool, 0, offsetof(Network, dhcp_anonymize) DHCPv4.SendHostname, config_parse_bool, 0, offsetof(Network, dhcp_send_hostname) diff --git a/src/network/networkd-network.c b/src/network/networkd-network.c index 255aaed5..6b0d74c8 100644 --- a/src/network/networkd-network.c +++ b/src/network/networkd-network.c @@ -384,6 +384,7 @@ int network_load_one(Manager *manager, OrderedHashmap **networks, const char *fi .dhcp_use_dns = true, .dhcp_use_hostname = true, .dhcp_use_routes = true, + .dhcp_use_gateway = true, /* NOTE: this var might be overwritten by network_apply_anonymize_if_set */ .dhcp_send_hostname = true, .dhcp_send_release = true, diff --git a/src/network/networkd-network.h b/src/network/networkd-network.h index 4738a18b..a2b9cd9c 100644 --- a/src/network/networkd-network.h +++ b/src/network/networkd-network.h @@ -110,6 +110,7 @@ struct Network { bool dhcp_use_sip; bool dhcp_use_mtu; bool dhcp_use_routes; + bool dhcp_use_gateway; bool dhcp_use_timezone; bool rapid_commit; bool dhcp_use_hostname; diff --git a/test/fuzz/fuzz-network-parser/directives.network b/test/fuzz/fuzz-network-parser/directives.network index 2b41239b..107ad06b 100644 --- a/test/fuzz/fuzz-network-parser/directives.network +++ b/test/fuzz/fuzz-network-parser/directives.network @@ -73,6 +73,7 @@ UseDNS= RoutesToDNS= UseDomains= UseRoutes= +UseGateway= IAID= UserClass= UseNTP=