From: Yu Watanabe Date: Sat, 17 Apr 2021 17:49:15 +0000 (+0900) Subject: network: radv: add RouteMetric= setting in [IPv6Prefix] X-Git-Tag: v249-rc1~375^2~3 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=0e1fb1d09ac6c7507c8485ccd8cd0628454268f7;p=thirdparty%2Fsystemd.git network: radv: add RouteMetric= setting in [IPv6Prefix] --- diff --git a/man/systemd.network.xml b/man/systemd.network.xml index 7a47132336d..128ade5b34e 100644 --- a/man/systemd.network.xml +++ b/man/systemd.network.xml @@ -2582,6 +2582,15 @@ IPv6Token=prefixstable:2002:da8:1:: Takes a boolean. When true, adds an address from the prefix. Default to false. + + + RouteMetric= + + The metric of the prefix route. Takes an unsigned integer in the range 0…4294967295. + When unset or set to 0, the kernel's default value is used. This setting is ignored when + Assign= is false. + + diff --git a/src/network/networkd-address.c b/src/network/networkd-address.c index 145bc25190a..e589fff150d 100644 --- a/src/network/networkd-address.c +++ b/src/network/networkd-address.c @@ -1095,6 +1095,7 @@ int link_set_addresses(Link *link) { return log_link_warning_errno(link, r, "Could not generate EUI64 address: %m"); address->family = AF_INET6; + address->route_metric = p->route_metric; r = static_address_configure(address, link); if (r < 0) return r; diff --git a/src/network/networkd-network-gperf.gperf b/src/network/networkd-network-gperf.gperf index 50aab8de6d1..568c34f51bd 100644 --- a/src/network/networkd-network-gperf.gperf +++ b/src/network/networkd-network-gperf.gperf @@ -325,6 +325,7 @@ IPv6Prefix.AddressAutoconfiguration, config_parse_prefix_flags, IPv6Prefix.ValidLifetimeSec, config_parse_prefix_lifetime, 0, 0 IPv6Prefix.PreferredLifetimeSec, config_parse_prefix_lifetime, 0, 0 IPv6Prefix.Assign, config_parse_prefix_assign, 0, 0 +IPv6Prefix.RouteMetric, config_parse_prefix_metric, 0, 0 IPv6RoutePrefix.Route, config_parse_route_prefix, 0, 0 IPv6RoutePrefix.LifetimeSec, config_parse_route_prefix_lifetime, 0, 0 LLDP.MUDURL, config_parse_lldp_mud, 0, 0 diff --git a/src/network/networkd-radv.c b/src/network/networkd-radv.c index 19f75e01da5..52c9afcc5e3 100644 --- a/src/network/networkd-radv.c +++ b/src/network/networkd-radv.c @@ -382,6 +382,45 @@ int config_parse_prefix_assign( return 0; } +int config_parse_prefix_metric( + const char *unit, + const char *filename, + unsigned line, + const char *section, + unsigned section_line, + const char *lvalue, + int ltype, + const char *rvalue, + void *data, + void *userdata) { + + Network *network = userdata; + _cleanup_(prefix_free_or_set_invalidp) Prefix *p = NULL; + int r; + + assert(filename); + assert(section); + assert(lvalue); + assert(rvalue); + assert(data); + + r = prefix_new_static(network, filename, section_line, &p); + if (r < 0) + return log_oom(); + + r = safe_atou32(rvalue, &p->route_metric); + if (r < 0) { + log_syntax(unit, LOG_WARNING, filename, line, r, + "Failed to parse %s=, ignoring assignment: %s", + lvalue, rvalue); + return 0; + } + + TAKE_PTR(p); + + return 0; +} + int config_parse_route_prefix( const char *unit, const char *filename, diff --git a/src/network/networkd-radv.h b/src/network/networkd-radv.h index 73d2f245452..f6efd326979 100644 --- a/src/network/networkd-radv.h +++ b/src/network/networkd-radv.h @@ -33,6 +33,7 @@ typedef struct Prefix { sd_radv_prefix *radv_prefix; bool assign; + uint32_t route_metric; } Prefix; typedef struct RoutePrefix { @@ -64,6 +65,7 @@ CONFIG_PARSER_PROTOTYPE(config_parse_prefix); CONFIG_PARSER_PROTOTYPE(config_parse_prefix_flags); CONFIG_PARSER_PROTOTYPE(config_parse_prefix_lifetime); CONFIG_PARSER_PROTOTYPE(config_parse_prefix_assign); +CONFIG_PARSER_PROTOTYPE(config_parse_prefix_metric); CONFIG_PARSER_PROTOTYPE(config_parse_radv_dns); CONFIG_PARSER_PROTOTYPE(config_parse_radv_search_domains); CONFIG_PARSER_PROTOTYPE(config_parse_route_prefix); diff --git a/test/fuzz/fuzz-network-parser/directives.network b/test/fuzz/fuzz-network-parser/directives.network index 467854728e2..e5acc5d67d2 100644 --- a/test/fuzz/fuzz-network-parser/directives.network +++ b/test/fuzz/fuzz-network-parser/directives.network @@ -237,6 +237,7 @@ PreferredLifetimeSec= AddressAutoconfiguration= ValidLifetimeSec= Assign= +RouteMetric= [IPv6RoutePrefix] Route= LifetimeSec=