]> git.ipfire.org Git - thirdparty/libvirt.git/commitdiff
qemu: Enable slirp-helper iff dbus-vmstate present
authorMichal Privoznik <mprivozn@redhat.com>
Tue, 10 Sep 2019 08:12:24 +0000 (10:12 +0200)
committerMichal Privoznik <mprivozn@redhat.com>
Thu, 19 Sep 2019 09:36:44 +0000 (11:36 +0200)
The fact that qemu is capable -netdev socket is not enough to
start a migratable domain. It also needs dbus-vmstate capability.
Since there are already some qemu releases which have
net-socket-dgram capability and don't have dbus-vmstate we need
to check for dbus-vmstate.

Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
Reviewed-by: Ján Tomko <jtomko@redhat.com>
src/qemu/qemu_hotplug.c
src/qemu/qemu_process.c
tests/qemuxml2argvdata/net-user.x86_64-4.0.0.args
tests/qemuxml2argvtest.c

index 62e505b77932bc99763afcc3919ba76d6a4f0545..d765d2a6f56747d571b7393b8b90b16dc2b2abca 100644 (file)
@@ -1308,7 +1308,7 @@ qemuDomainAttachNetDevice(virQEMUDriverPtr driver,
 
     case VIR_DOMAIN_NET_TYPE_USER:
         if (!priv->disableSlirp &&
-            virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_NET_SOCKET_DGRAM)) {
+            virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_DBUS_VMSTATE)) {
             qemuSlirpPtr slirp = qemuInterfacePrepareSlirp(driver, net);
 
             if (!slirp)
index 955ba4de4ce2035669feb9c1688a241ef68b9152..0b2afe6841a5514539700cdf35fca6d02a959fb7 100644 (file)
@@ -5756,7 +5756,7 @@ qemuProcessNetworkPrepareDevices(virQEMUDriverPtr driver,
                 goto cleanup;
         } else if (actualType == VIR_DOMAIN_NET_TYPE_USER &&
                    !priv->disableSlirp &&
-                   virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_NET_SOCKET_DGRAM)) {
+                   virQEMUCapsGet(priv->qemuCaps, QEMU_CAPS_DBUS_VMSTATE)) {
             qemuSlirpPtr slirp = qemuInterfacePrepareSlirp(driver, net);
 
             QEMU_DOMAIN_NETWORK_PRIVATE(net)->slirp = slirp;
index d51653dcdddf86d250da45e1c89fcba15d745336..3fb745c2127658ef3cef7331918f695832b3a361 100644 (file)
@@ -29,7 +29,7 @@ file=/tmp/lib/domain--1-QEMUGuest1/master-key.aes \
 -device piix3-usb-uhci,id=usb,bus=pci.0,addr=0x1.0x2 \
 -drive file=/dev/HostVG/QEMUGuest1,format=raw,if=none,id=drive-ide0-0-0 \
 -device ide-hd,bus=ide.0,unit=0,drive=drive-ide0-0-0,id=ide0-0-0,bootindex=1 \
--netdev socket,fd=42,id=hostnet0 \
+-netdev user,id=hostnet0 \
 -device rtl8139,netdev=hostnet0,id=net0,mac=00:11:22:33:44:55,bus=pci.0,\
 addr=0x2 \
 -sandbox on,obsolete=deny,elevateprivileges=deny,spawn=deny,\
index abff3d1c61655f7b13ee440f010b90c48d899972..a8fd371674200a6dd6cad98b0b082086f83d60ac 100644 (file)
@@ -533,7 +533,7 @@ testCompareXMLToArgv(const void *data)
             virDomainNetDefPtr net = vm->def->nets[i];
 
             if (net->type == VIR_DOMAIN_NET_TYPE_USER &&
-                virQEMUCapsGet(info->qemuCaps, QEMU_CAPS_NET_SOCKET_DGRAM)) {
+                virQEMUCapsGet(info->qemuCaps, QEMU_CAPS_DBUS_VMSTATE)) {
                 qemuSlirpPtr slirp = qemuSlirpNew();
                 slirp->fd[0] = 42;
                 QEMU_DOMAIN_NETWORK_PRIVATE(net)->slirp = slirp;