From: Yu Watanabe Date: Fri, 24 Jan 2025 19:48:00 +0000 (+0900) Subject: resolved: do not disable mdns/llmnr globally if it's enabled on any link X-Git-Tag: v258-rc1~1485^2~1 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=962b757d9b62e42df2513577d717d730b619c80c;p=thirdparty%2Fsystemd.git resolved: do not disable mdns/llmnr globally if it's enabled on any link Fixes a regression caused by 2976730a4d34749bfb7a88da341464f1834ab1c6. Fixes #36078. Fixes #36126. Co-authored-by: Luca Boccassi --- diff --git a/src/resolve/resolved-link.c b/src/resolve/resolved-link.c index 067a0813ec1..928137b967a 100644 --- a/src/resolve/resolved-link.c +++ b/src/resolve/resolved-link.c @@ -651,16 +651,13 @@ int link_update(Link *l) { r = manager_llmnr_start(l->manager); if (r < 0) return r; - } else - manager_llmnr_stop(l->manager); - + } if (link_get_mdns_support(l) != RESOLVE_SUPPORT_NO) { r = manager_mdns_start(l->manager); if (r < 0) return r; - } else - manager_mdns_stop(l->manager); + } link_allocate_scopes(l); link_add_rrs(l, false); diff --git a/src/resolve/resolved-llmnr.c b/src/resolve/resolved-llmnr.c index 9469bdac869..abb9c469604 100644 --- a/src/resolve/resolved-llmnr.c +++ b/src/resolve/resolved-llmnr.c @@ -25,6 +25,19 @@ void manager_llmnr_stop(Manager *m) { m->llmnr_ipv6_tcp_fd = safe_close(m->llmnr_ipv6_tcp_fd); } +void manager_llmnr_maybe_stop(Manager *m) { + assert(m); + + /* This stops LLMNR only when no interface enables LLMNR. */ + + Link *l; + HASHMAP_FOREACH(l, m->links) + if (link_get_llmnr_support(l) != RESOLVE_SUPPORT_NO) + return; + + manager_llmnr_stop(m); +} + int manager_llmnr_start(Manager *m) { int r; diff --git a/src/resolve/resolved-llmnr.h b/src/resolve/resolved-llmnr.h index 4cdd2606e6d..358201b5df8 100644 --- a/src/resolve/resolved-llmnr.h +++ b/src/resolve/resolved-llmnr.h @@ -11,4 +11,5 @@ int manager_llmnr_ipv4_tcp_fd(Manager *m); int manager_llmnr_ipv6_tcp_fd(Manager *m); void manager_llmnr_stop(Manager *m); +void manager_llmnr_maybe_stop(Manager *m); int manager_llmnr_start(Manager *m); diff --git a/src/resolve/resolved-manager.c b/src/resolve/resolved-manager.c index dbaad81734b..5ec946717f2 100644 --- a/src/resolve/resolved-manager.c +++ b/src/resolve/resolved-manager.c @@ -105,6 +105,9 @@ static int manager_process_link(sd_netlink *rtnl, sd_netlink_message *mm, void * break; } + /* Now check all the links, and if mDNS/llmr are disabled everywhere, stop them globally too. */ + manager_llmnr_maybe_stop(m); + manager_mdns_maybe_stop(m); return 0; fail: @@ -287,6 +290,9 @@ static int on_network_event(sd_event_source *s, int fd, uint32_t revents, void * (void) manager_write_resolv_conf(m); (void) manager_send_changed(m, "DNS"); + /* Now check all the links, and if mDNS/llmr are disabled everywhere, stop them globally too. */ + manager_llmnr_maybe_stop(m); + manager_mdns_maybe_stop(m); return 0; } diff --git a/src/resolve/resolved-mdns.c b/src/resolve/resolved-mdns.c index 7e9bb693afe..4e6aade7265 100644 --- a/src/resolve/resolved-mdns.c +++ b/src/resolve/resolved-mdns.c @@ -22,6 +22,19 @@ void manager_mdns_stop(Manager *m) { m->mdns_ipv6_fd = safe_close(m->mdns_ipv6_fd); } +void manager_mdns_maybe_stop(Manager *m) { + assert(m); + + /* This stops mDNS only when no interface enables mDNS. */ + + Link *l; + HASHMAP_FOREACH(l, m->links) + if (link_get_mdns_support(l) != RESOLVE_SUPPORT_NO) + return; + + manager_mdns_stop(m); +} + int manager_mdns_start(Manager *m) { int r; diff --git a/src/resolve/resolved-mdns.h b/src/resolve/resolved-mdns.h index 38ef1808dfb..c52bce10691 100644 --- a/src/resolve/resolved-mdns.h +++ b/src/resolve/resolved-mdns.h @@ -10,4 +10,5 @@ int manager_mdns_ipv4_fd(Manager *m); int manager_mdns_ipv6_fd(Manager *m); void manager_mdns_stop(Manager *m); +void manager_mdns_maybe_stop(Manager *m); int manager_mdns_start(Manager *m);