diff options
author | Yu Watanabe <watanabe.yu+github@gmail.com> | 2021-04-28 19:34:17 +0200 |
---|---|---|
committer | Yu Watanabe <watanabe.yu+github@gmail.com> | 2021-04-29 02:08:55 +0200 |
commit | c3fa1257da36522563c568524ba2a5113b1d90e9 (patch) | |
tree | 2c7bf9ee43b0795924ccdd625bc7740a1e0b3475 /src/network/networkd-route.c | |
parent | network: unify log_link_message_full_errno() and log_message_warning_errno() (diff) | |
download | systemd-c3fa1257da36522563c568524ba2a5113b1d90e9.tar.xz systemd-c3fa1257da36522563c568524ba2a5113b1d90e9.zip |
network: do not set route type on specific route removal
Diffstat (limited to '')
-rw-r--r-- | src/network/networkd-route.c | 24 |
1 files changed, 20 insertions, 4 deletions
diff --git a/src/network/networkd-route.c b/src/network/networkd-route.c index 9ed30d69ed..22e19cc146 100644 --- a/src/network/networkd-route.c +++ b/src/network/networkd-route.c @@ -717,10 +717,6 @@ static int route_set_netlink_message(const Route *route, sd_netlink_message *req } } - r = sd_rtnl_message_route_set_type(req, route->type); - if (r < 0) - return log_link_error_errno(link, r, "Could not set route type: %m"); - if (!route_type_is_reject(route) && route->nexthop_id == 0) { assert(link); /* Those routes must be attached to a specific link */ @@ -769,6 +765,7 @@ int route_remove( link_netlink_message_handler_t callback) { _cleanup_(sd_netlink_message_unrefp) sd_netlink_message *req = NULL; + unsigned char type; int r; assert(link || manager); @@ -786,6 +783,21 @@ int route_remove( if (r < 0) return log_link_error_errno(link, r, "Could not create RTM_DELROUTE message: %m"); + if (route->family == AF_INET && route->nexthop_id > 0 && route->type == RTN_BLACKHOLE) + /* When IPv4 route has nexthop id and the nexthop type is blackhole, even though kernel + * sends RTM_NEWROUTE netlink message with blackhole type, kernel's internal route type + * fib_rt_info::type may not be blackhole. Thus, we cannot know the internal value. + * Moreover, on route removal, the matching is done with the hidden value if we set + * non-zero type in RTM_DELROUTE message. Note, sd_rtnl_message_new_route() sets + * RTN_UNICAST by default. So, we need to clear the type here. */ + type = RTN_UNSPEC; + else + type = route->type; + + r = sd_rtnl_message_route_set_type(req, type); + if (r < 0) + return log_link_error_errno(link, r, "Could not set route type: %m"); + r = route_set_netlink_message(route, req, link); if (r < 0) return r; @@ -1106,6 +1118,10 @@ int route_configure( if (r < 0) return log_link_error_errno(link, r, "Could not create RTM_NEWROUTE message: %m"); + r = sd_rtnl_message_route_set_type(req, route->type); + if (r < 0) + return log_link_error_errno(link, r, "Could not set route type: %m"); + r = route_set_netlink_message(route, req, link); if (r < 0) return r; |