mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-24 13:35:17 +00:00
qemu: fix ifindex array reported to systemd
Commit f7afeddc added code to report to systemd an array of interface indexes for all tap devices used by a guest. Unfortunately it not only didn't add code to report the ifindexes for macvtap interfaces (interface type='direct') or the tap devices used by type='ethernet', it ended up sending "-1" as the ifindex for each macvtap or hostdev interface. This resulted in a failure to start any domain that had a macvtap or hostdev interface (or actually any type other than "network" or "bridge"). This patch does the following with the nicindexes array: 1) Modify qemuBuildInterfaceCommandLine() to only fill in the nicindexes array if given a non-NULL pointer to an array (and modifies the test jig calls to the function to send NULL). This is because there are tests in the test suite that have type='ethernet' and still have an ifname specified, but that device of course doesn't actually exist on the test system, so attempts to call virNetDevGetIndex() will fail. 2) Even then, only add an entry to the nicindexes array for appropriate types, and to do so for all appropriate types ("network", "bridge", and "direct"), but only if the ifname is known (since that is required to call virNetDevGetIndex().
This commit is contained in:
parent
153b06c6d1
commit
4bbe1029f2
@ -289,8 +289,7 @@ qemuNetworkIfaceConnect(virDomainDefPtr def,
|
|||||||
virDomainNetDefPtr net,
|
virDomainNetDefPtr net,
|
||||||
virQEMUCapsPtr qemuCaps,
|
virQEMUCapsPtr qemuCaps,
|
||||||
int *tapfd,
|
int *tapfd,
|
||||||
size_t *tapfdSize,
|
size_t *tapfdSize)
|
||||||
int *nicindex)
|
|
||||||
{
|
{
|
||||||
const char *brname;
|
const char *brname;
|
||||||
int ret = -1;
|
int ret = -1;
|
||||||
@ -337,8 +336,6 @@ qemuNetworkIfaceConnect(virDomainDefPtr def,
|
|||||||
virDomainAuditNetDevice(def, net, tunpath, false);
|
virDomainAuditNetDevice(def, net, tunpath, false);
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
if (virNetDevGetIndex(net->ifname, nicindex) < 0)
|
|
||||||
goto cleanup;
|
|
||||||
if (virDomainNetGetActualBridgeMACTableManager(net)
|
if (virDomainNetGetActualBridgeMACTableManager(net)
|
||||||
== VIR_NETWORK_BRIDGE_MAC_TABLE_MANAGER_LIBVIRT) {
|
== VIR_NETWORK_BRIDGE_MAC_TABLE_MANAGER_LIBVIRT) {
|
||||||
/* libvirt is managing the FDB of the bridge this device
|
/* libvirt is managing the FDB of the bridge this device
|
||||||
@ -7757,7 +7754,8 @@ qemuBuildInterfaceCommandLine(virCommandPtr cmd,
|
|||||||
int bootindex,
|
int bootindex,
|
||||||
virNetDevVPortProfileOp vmop,
|
virNetDevVPortProfileOp vmop,
|
||||||
bool standalone,
|
bool standalone,
|
||||||
int *nicindex)
|
size_t *nnicindexes,
|
||||||
|
int **nicindexes)
|
||||||
{
|
{
|
||||||
int ret = -1;
|
int ret = -1;
|
||||||
char *nic = NULL, *host = NULL;
|
char *nic = NULL, *host = NULL;
|
||||||
@ -7771,8 +7769,6 @@ qemuBuildInterfaceCommandLine(virCommandPtr cmd,
|
|||||||
virNetDevBandwidthPtr actualBandwidth;
|
virNetDevBandwidthPtr actualBandwidth;
|
||||||
size_t i;
|
size_t i;
|
||||||
|
|
||||||
*nicindex = -1;
|
|
||||||
|
|
||||||
if (actualType == VIR_DOMAIN_NET_TYPE_VHOSTUSER)
|
if (actualType == VIR_DOMAIN_NET_TYPE_VHOSTUSER)
|
||||||
return qemuBuildVhostuserCommandLine(cmd, def, net, qemuCaps);
|
return qemuBuildVhostuserCommandLine(cmd, def, net, qemuCaps);
|
||||||
|
|
||||||
@ -7819,7 +7815,7 @@ qemuBuildInterfaceCommandLine(virCommandPtr cmd,
|
|||||||
|
|
||||||
if (qemuNetworkIfaceConnect(def, driver, net,
|
if (qemuNetworkIfaceConnect(def, driver, net,
|
||||||
qemuCaps, tapfd,
|
qemuCaps, tapfd,
|
||||||
&tapfdSize, nicindex) < 0)
|
&tapfdSize) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
} else if (actualType == VIR_DOMAIN_NET_TYPE_DIRECT) {
|
} else if (actualType == VIR_DOMAIN_NET_TYPE_DIRECT) {
|
||||||
if (VIR_ALLOC(tapfd) < 0 || VIR_ALLOC(tapfdName) < 0)
|
if (VIR_ALLOC(tapfd) < 0 || VIR_ALLOC(tapfdName) < 0)
|
||||||
@ -7831,6 +7827,49 @@ qemuBuildInterfaceCommandLine(virCommandPtr cmd,
|
|||||||
goto cleanup;
|
goto cleanup;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* For types whose implementations use a netdev on the host, add
|
||||||
|
* an entry to nicindexes for passing on to systemd.
|
||||||
|
*/
|
||||||
|
switch ((virDomainNetType)actualType) {
|
||||||
|
case VIR_DOMAIN_NET_TYPE_ETHERNET:
|
||||||
|
case VIR_DOMAIN_NET_TYPE_NETWORK:
|
||||||
|
case VIR_DOMAIN_NET_TYPE_BRIDGE:
|
||||||
|
case VIR_DOMAIN_NET_TYPE_DIRECT:
|
||||||
|
{
|
||||||
|
int nicindex;
|
||||||
|
|
||||||
|
/* network and bridge use a tap device, and direct uses a
|
||||||
|
* macvtap device
|
||||||
|
*/
|
||||||
|
if (nicindexes && nnicindexes && net->ifname) {
|
||||||
|
if (virNetDevGetIndex(net->ifname, &nicindex) < 0 ||
|
||||||
|
VIR_APPEND_ELEMENT(*nicindexes, *nnicindexes, nicindex) < 0)
|
||||||
|
goto cleanup;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
case VIR_DOMAIN_NET_TYPE_USER:
|
||||||
|
case VIR_DOMAIN_NET_TYPE_VHOSTUSER:
|
||||||
|
case VIR_DOMAIN_NET_TYPE_SERVER:
|
||||||
|
case VIR_DOMAIN_NET_TYPE_CLIENT:
|
||||||
|
case VIR_DOMAIN_NET_TYPE_MCAST:
|
||||||
|
case VIR_DOMAIN_NET_TYPE_INTERNAL:
|
||||||
|
case VIR_DOMAIN_NET_TYPE_HOSTDEV:
|
||||||
|
case VIR_DOMAIN_NET_TYPE_LAST:
|
||||||
|
/* These types don't use a network device on the host, but
|
||||||
|
* instead use some other type of connection to the emulated
|
||||||
|
* device in the qemu process.
|
||||||
|
*
|
||||||
|
* (Note that hostdev can't be considered as "using a network
|
||||||
|
* device", because by the time it is being used, it has been
|
||||||
|
* detached from the hostside network driver so it doesn't show
|
||||||
|
* up in the list of interfaces on the host - it's just some
|
||||||
|
* PCI device.)
|
||||||
|
*/
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
/* Set bandwidth or warn if requested and not supported. */
|
/* Set bandwidth or warn if requested and not supported. */
|
||||||
actualBandwidth = virDomainNetGetActualBandwidth(net);
|
actualBandwidth = virDomainNetGetActualBandwidth(net);
|
||||||
if (actualBandwidth) {
|
if (actualBandwidth) {
|
||||||
@ -8221,9 +8260,6 @@ qemuBuildCommandLine(virConnectPtr conn,
|
|||||||
|
|
||||||
virUUIDFormat(def->uuid, uuid);
|
virUUIDFormat(def->uuid, uuid);
|
||||||
|
|
||||||
*nnicindexes = 0;
|
|
||||||
*nicindexes = NULL;
|
|
||||||
|
|
||||||
emulator = def->emulator;
|
emulator = def->emulator;
|
||||||
|
|
||||||
if (!cfg->privileged) {
|
if (!cfg->privileged) {
|
||||||
@ -9282,13 +9318,9 @@ qemuBuildCommandLine(virConnectPtr conn,
|
|||||||
else
|
else
|
||||||
vlan = i;
|
vlan = i;
|
||||||
|
|
||||||
if (VIR_EXPAND_N(*nicindexes, *nnicindexes, 1) < 0)
|
|
||||||
goto error;
|
|
||||||
|
|
||||||
if (qemuBuildInterfaceCommandLine(cmd, driver, def, net,
|
if (qemuBuildInterfaceCommandLine(cmd, driver, def, net,
|
||||||
qemuCaps, vlan, bootNet, vmop,
|
qemuCaps, vlan, bootNet, vmop,
|
||||||
standalone,
|
standalone, nnicindexes, nicindexes) < 0)
|
||||||
&((*nicindexes)[*nnicindexes - 1])) < 0)
|
|
||||||
goto error;
|
goto error;
|
||||||
|
|
||||||
last_good_net = i;
|
last_good_net = i;
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
/*
|
/*
|
||||||
* qemu_command.h: QEMU command generation
|
* qemu_command.h: QEMU command generation
|
||||||
*
|
*
|
||||||
* Copyright (C) 2006-2014 Red Hat, Inc.
|
* Copyright (C) 2006-2015 Red Hat, Inc.
|
||||||
* Copyright (C) 2006 Daniel P. Berrange
|
* Copyright (C) 2006 Daniel P. Berrange
|
||||||
*
|
*
|
||||||
* This library is free software; you can redistribute it and/or
|
* This library is free software; you can redistribute it and/or
|
||||||
@ -208,8 +208,7 @@ int qemuNetworkIfaceConnect(virDomainDefPtr def,
|
|||||||
virDomainNetDefPtr net,
|
virDomainNetDefPtr net,
|
||||||
virQEMUCapsPtr qemuCaps,
|
virQEMUCapsPtr qemuCaps,
|
||||||
int *tapfd,
|
int *tapfd,
|
||||||
size_t *tapfdSize,
|
size_t *tapfdSize)
|
||||||
int *nicindex)
|
|
||||||
ATTRIBUTE_NONNULL(2);
|
ATTRIBUTE_NONNULL(2);
|
||||||
|
|
||||||
int qemuPhysIfaceConnect(virDomainDefPtr def,
|
int qemuPhysIfaceConnect(virDomainDefPtr def,
|
||||||
|
@ -6447,8 +6447,6 @@ static char *qemuConnectDomainXMLToNative(virConnectPtr conn,
|
|||||||
size_t i;
|
size_t i;
|
||||||
virQEMUDriverConfigPtr cfg;
|
virQEMUDriverConfigPtr cfg;
|
||||||
virCapsPtr caps = NULL;
|
virCapsPtr caps = NULL;
|
||||||
size_t nnicindexes = 0;
|
|
||||||
int *nicindexes = NULL;
|
|
||||||
|
|
||||||
virCheckFlags(0, NULL);
|
virCheckFlags(0, NULL);
|
||||||
|
|
||||||
@ -6634,14 +6632,12 @@ static char *qemuConnectDomainXMLToNative(virConnectPtr conn,
|
|||||||
&buildCommandLineCallbacks,
|
&buildCommandLineCallbacks,
|
||||||
true,
|
true,
|
||||||
qemuCheckFips(),
|
qemuCheckFips(),
|
||||||
NULL,
|
NULL, NULL, NULL)))
|
||||||
&nnicindexes, &nicindexes)))
|
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
ret = virCommandToString(cmd);
|
ret = virCommandToString(cmd);
|
||||||
|
|
||||||
cleanup:
|
cleanup:
|
||||||
VIR_FREE(nicindexes);
|
|
||||||
virObjectUnref(qemuCaps);
|
virObjectUnref(qemuCaps);
|
||||||
virCommandFree(cmd);
|
virCommandFree(cmd);
|
||||||
virDomainDefFree(def);
|
virDomainDefFree(def);
|
||||||
|
@ -846,7 +846,6 @@ int qemuDomainAttachNetDevice(virConnectPtr conn,
|
|||||||
qemuDomainObjPrivatePtr priv = vm->privateData;
|
qemuDomainObjPrivatePtr priv = vm->privateData;
|
||||||
char **tapfdName = NULL;
|
char **tapfdName = NULL;
|
||||||
int *tapfd = NULL;
|
int *tapfd = NULL;
|
||||||
int nicindex = -1;
|
|
||||||
size_t tapfdSize = 0;
|
size_t tapfdSize = 0;
|
||||||
char **vhostfdName = NULL;
|
char **vhostfdName = NULL;
|
||||||
int *vhostfd = NULL;
|
int *vhostfd = NULL;
|
||||||
@ -916,8 +915,7 @@ int qemuDomainAttachNetDevice(virConnectPtr conn,
|
|||||||
goto cleanup;
|
goto cleanup;
|
||||||
memset(vhostfd, -1, sizeof(*vhostfd) * vhostfdSize);
|
memset(vhostfd, -1, sizeof(*vhostfd) * vhostfdSize);
|
||||||
if (qemuNetworkIfaceConnect(vm->def, driver, net,
|
if (qemuNetworkIfaceConnect(vm->def, driver, net,
|
||||||
priv->qemuCaps, tapfd, &tapfdSize,
|
priv->qemuCaps, tapfd, &tapfdSize) < 0)
|
||||||
&nicindex) < 0)
|
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
iface_connected = true;
|
iface_connected = true;
|
||||||
if (qemuOpenVhostNet(vm->def, net, priv->qemuCaps, vhostfd, &vhostfdSize) < 0)
|
if (qemuOpenVhostNet(vm->def, net, priv->qemuCaps, vhostfd, &vhostfdSize) < 0)
|
||||||
|
@ -263,8 +263,6 @@ static int testCompareXMLToArgvFiles(const char *xml,
|
|||||||
char *log = NULL;
|
char *log = NULL;
|
||||||
virCommandPtr cmd = NULL;
|
virCommandPtr cmd = NULL;
|
||||||
size_t i;
|
size_t i;
|
||||||
size_t nnicindexes = 0;
|
|
||||||
int *nicindexes = NULL;
|
|
||||||
virBitmapPtr nodeset = NULL;
|
virBitmapPtr nodeset = NULL;
|
||||||
|
|
||||||
if (!(conn = virGetConnect()))
|
if (!(conn = virGetConnect()))
|
||||||
@ -355,7 +353,7 @@ static int testCompareXMLToArgvFiles(const char *xml,
|
|||||||
VIR_NETDEV_VPORT_PROFILE_OP_NO_OP,
|
VIR_NETDEV_VPORT_PROFILE_OP_NO_OP,
|
||||||
&testCallbacks, false,
|
&testCallbacks, false,
|
||||||
(flags & FLAG_FIPS),
|
(flags & FLAG_FIPS),
|
||||||
nodeset, &nnicindexes, &nicindexes))) {
|
nodeset, NULL, NULL))) {
|
||||||
if (!virtTestOOMActive() &&
|
if (!virtTestOOMActive() &&
|
||||||
(flags & FLAG_EXPECT_FAILURE)) {
|
(flags & FLAG_EXPECT_FAILURE)) {
|
||||||
ret = 0;
|
ret = 0;
|
||||||
@ -402,7 +400,6 @@ static int testCompareXMLToArgvFiles(const char *xml,
|
|||||||
ret = 0;
|
ret = 0;
|
||||||
|
|
||||||
out:
|
out:
|
||||||
VIR_FREE(nicindexes);
|
|
||||||
VIR_FREE(log);
|
VIR_FREE(log);
|
||||||
VIR_FREE(expectargv);
|
VIR_FREE(expectargv);
|
||||||
VIR_FREE(actualargv);
|
VIR_FREE(actualargv);
|
||||||
|
@ -44,8 +44,6 @@ static int testCompareXMLToArgvFiles(const char *xml,
|
|||||||
char *log = NULL;
|
char *log = NULL;
|
||||||
char *emulator = NULL;
|
char *emulator = NULL;
|
||||||
virCommandPtr cmd = NULL;
|
virCommandPtr cmd = NULL;
|
||||||
size_t nnicindexes = 0;
|
|
||||||
int *nicindexes = NULL;
|
|
||||||
|
|
||||||
if (!(conn = virGetConnect()))
|
if (!(conn = virGetConnect()))
|
||||||
goto fail;
|
goto fail;
|
||||||
@ -122,7 +120,7 @@ static int testCompareXMLToArgvFiles(const char *xml,
|
|||||||
migrateFrom, migrateFd, NULL,
|
migrateFrom, migrateFd, NULL,
|
||||||
VIR_NETDEV_VPORT_PROFILE_OP_NO_OP,
|
VIR_NETDEV_VPORT_PROFILE_OP_NO_OP,
|
||||||
&testCallbacks, false, false, NULL,
|
&testCallbacks, false, false, NULL,
|
||||||
&nnicindexes, &nicindexes)))
|
NULL, NULL)))
|
||||||
goto fail;
|
goto fail;
|
||||||
|
|
||||||
if (!virtTestOOMActive()) {
|
if (!virtTestOOMActive()) {
|
||||||
@ -158,7 +156,6 @@ static int testCompareXMLToArgvFiles(const char *xml,
|
|||||||
ret = 0;
|
ret = 0;
|
||||||
|
|
||||||
fail:
|
fail:
|
||||||
VIR_FREE(nicindexes);
|
|
||||||
VIR_FREE(log);
|
VIR_FREE(log);
|
||||||
VIR_FREE(emulator);
|
VIR_FREE(emulator);
|
||||||
VIR_FREE(expectargv);
|
VIR_FREE(expectargv);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user