On 12/18/25 5:00 AM, Michal Privoznik via Devel wrote:
From: Michal Privoznik <[email protected]>

If a DNS forwarder has port specified then we ought to format it
into dnsmasq config. The correct syntax is

   server=/domain/ip-address#port

Closes: https://gitlab.com/libvirt/libvirt/-/issues/833
Signed-off-by: Michal Privoznik <[email protected]>
---
  src/network/bridge_driver.c                               | 6 +++++-
  tests/networkxml2confdata/nat-network-dns-forwarders.conf | 2 +-
  tests/networkxml2confdata/nat-network-dns-forwarders.xml  | 2 +-
  3 files changed, 7 insertions(+), 3 deletions(-)

diff --git a/src/network/bridge_driver.c b/src/network/bridge_driver.c
index 34b655e816..8b5dbb3ab7 100644
--- a/src/network/bridge_driver.c
+++ b/src/network/bridge_driver.c
@@ -1212,10 +1212,14 @@ networkDnsmasqConfContents(virNetworkObj *obj,
                  virBufferAsprintf(&configbuf, "/%s/", fwd->domain);
              if (VIR_SOCKET_ADDR_VALID(&fwd->addr)) {
                  g_autofree char *addr = virSocketAddrFormat(&fwd->addr);
+                int port = virSocketAddrGetPort(&fwd->addr);
if (!addr)
                      return -1;
-                virBufferAsprintf(&configbuf, "%s\n", addr);
+                virBufferAddStr(&configbuf, addr);
+                if (port > 0)
+                    virBufferAsprintf(&configbuf, "#%d", port);
+                virBufferAddChar(&configbuf, '\n');
                  if (!fwd->domain)
                      addNoResolv = true;
              } else {
diff --git a/tests/networkxml2confdata/nat-network-dns-forwarders.conf 
b/tests/networkxml2confdata/nat-network-dns-forwarders.conf
index 1b0c94c3fb..85d6c6ceb9 100644
--- a/tests/networkxml2confdata/nat-network-dns-forwarders.conf
+++ b/tests/networkxml2confdata/nat-network-dns-forwarders.conf
@@ -7,7 +7,7 @@
  strict-order
  server=8.8.8.8
  server=8.8.4.4
-server=/example.com/192.168.1.1
+server=/example.com/192.168.1.1#1234
  server=/www.example.com/#
  no-resolv
  except-interface=lo
diff --git a/tests/networkxml2confdata/nat-network-dns-forwarders.xml 
b/tests/networkxml2confdata/nat-network-dns-forwarders.xml
index 5d4f3fa697..98d9660b14 100644
--- a/tests/networkxml2confdata/nat-network-dns-forwarders.xml
+++ b/tests/networkxml2confdata/nat-network-dns-forwarders.xml
@@ -6,7 +6,7 @@
    <dns>
      <forwarder addr='8.8.8.8'/>
      <forwarder addr='8.8.4.4'/>
-    <forwarder domain='example.com' addr='192.168.1.1'/>
+    <forwarder domain='example.com' addr='192.168.1.1' port='1234'/>
      <forwarder domain='www.example.com'/>

The one issue with this is that by changing an existing entry rather than adding a new one, you've eliminated the test case that checks for proper operation when domain & addr are specified, but port is not.

Otherwise

Reviewed-by: Laine Stump <[email protected]>

    </dns>
    <ip address='192.168.122.1' netmask='255.255.255.0'>

Reply via email to