1
0
mirror of https://gitlab.com/libvirt/libvirt.git synced 2025-01-11 09:17:52 +03:00

qemu: clean up qemuDomainAttachNetDevice

Now that we assume -netdev support, we no longer set the VLAN
or need the hostPlugged bool.

Signed-off-by: Ján Tomko <jtomko@redhat.com>
Reviewed-by: Andrea Bolognani <abologna@redhat.com>
This commit is contained in:
Ján Tomko 2018-03-29 01:25:00 +02:00
parent ad8a7c4f85
commit 773577fca7

View File

@ -825,7 +825,6 @@ qemuDomainAttachNetDevice(virQEMUDriverPtr driver,
char *nicstr = NULL; char *nicstr = NULL;
char *netstr = NULL; char *netstr = NULL;
int ret = -1; int ret = -1;
int vlan;
bool releaseaddr = false; bool releaseaddr = false;
bool iface_connected = false; bool iface_connected = false;
virDomainNetType actualType; virDomainNetType actualType;
@ -836,7 +835,7 @@ qemuDomainAttachNetDevice(virQEMUDriverPtr driver,
char *charDevAlias = NULL; char *charDevAlias = NULL;
bool charDevPlugged = false; bool charDevPlugged = false;
bool netdevPlugged = false; bool netdevPlugged = false;
bool hostPlugged = false; char *netdev_name;
/* preallocate new slot for device */ /* preallocate new slot for device */
if (VIR_REALLOC_N(vm->def->nets, vm->def->nnets + 1) < 0) if (VIR_REALLOC_N(vm->def->nets, vm->def->nnets + 1) < 0)
@ -1029,7 +1028,6 @@ qemuDomainAttachNetDevice(virQEMUDriverPtr driver,
releaseaddr = true; releaseaddr = true;
vlan = -1;
if (VIR_ALLOC_N(tapfdName, tapfdSize) < 0 || if (VIR_ALLOC_N(tapfdName, tapfdSize) < 0 ||
VIR_ALLOC_N(vhostfdName, vhostfdSize) < 0) VIR_ALLOC_N(vhostfdName, vhostfdSize) < 0)
goto cleanup; goto cleanup;
@ -1078,7 +1076,7 @@ qemuDomainAttachNetDevice(virQEMUDriverPtr driver,
for (i = 0; i < vhostfdSize; i++) for (i = 0; i < vhostfdSize; i++)
VIR_FORCE_CLOSE(vhostfd[i]); VIR_FORCE_CLOSE(vhostfd[i]);
if (!(nicstr = qemuBuildNicDevStr(vm->def, net, vlan, 0, if (!(nicstr = qemuBuildNicDevStr(vm->def, net, -1, 0,
queueSize, priv->qemuCaps))) queueSize, priv->qemuCaps)))
goto try_remove; goto try_remove;
@ -1169,31 +1167,17 @@ qemuDomainAttachNetDevice(virQEMUDriverPtr driver,
goto cleanup; goto cleanup;
virErrorPreserveLast(&originalError); virErrorPreserveLast(&originalError);
if (vlan < 0) { if (virAsprintf(&netdev_name, "host%s", net->info.alias) >= 0) {
char *netdev_name; qemuDomainObjEnterMonitor(driver, vm);
if (virAsprintf(&netdev_name, "host%s", net->info.alias) >= 0) { if (charDevPlugged &&
qemuDomainObjEnterMonitor(driver, vm); qemuMonitorDetachCharDev(priv->mon, charDevAlias) < 0)
if (charDevPlugged && VIR_WARN("Failed to remove associated chardev %s", charDevAlias);
qemuMonitorDetachCharDev(priv->mon, charDevAlias) < 0) if (netdevPlugged &&
VIR_WARN("Failed to remove associated chardev %s", charDevAlias); qemuMonitorRemoveNetdev(priv->mon, netdev_name) < 0)
if (netdevPlugged && VIR_WARN("Failed to remove network backend for netdev %s",
qemuMonitorRemoveNetdev(priv->mon, netdev_name) < 0) netdev_name);
VIR_WARN("Failed to remove network backend for netdev %s", ignore_value(qemuDomainObjExitMonitor(driver, vm));
netdev_name); VIR_FREE(netdev_name);
ignore_value(qemuDomainObjExitMonitor(driver, vm));
VIR_FREE(netdev_name);
}
} else {
char *hostnet_name;
if (virAsprintf(&hostnet_name, "host%s", net->info.alias) >= 0) {
qemuDomainObjEnterMonitor(driver, vm);
if (hostPlugged &&
qemuMonitorRemoveHostNetwork(priv->mon, vlan, hostnet_name) < 0)
VIR_WARN("Failed to remove network backend for vlan %d, net %s",
vlan, hostnet_name);
ignore_value(qemuDomainObjExitMonitor(driver, vm));
VIR_FREE(hostnet_name);
}
} }
virErrorRestore(&originalError); virErrorRestore(&originalError);
goto cleanup; goto cleanup;