From aba930af151da948ee39f896b7af84110c2b97db Mon Sep 17 00:00:00 2001 From: John Ferlan <jferlan@redhat.com> Date: Mon, 15 Feb 2016 12:01:21 -0500 Subject: [PATCH] qemu: Move qemuNetworkPrepareDevices Move function to qemu_process.c, rename to qemuProcessNetworkPrepareDevices and make it static. Signed-off-by: John Ferlan <jferlan@redhat.com> --- src/qemu/qemu_command.c | 49 ------------------------------------ src/qemu/qemu_process.c | 55 ++++++++++++++++++++++++++++++++++++++++- 2 files changed, 54 insertions(+), 50 deletions(-) diff --git a/src/qemu/qemu_command.c b/src/qemu/qemu_command.c index b44b431698..d4da5880c9 100644 --- a/src/qemu/qemu_command.c +++ b/src/qemu/qemu_command.c @@ -258,55 +258,6 @@ qemuBuildObjectCommandlineFromJSON(const char *type, } -int -qemuNetworkPrepareDevices(virDomainDefPtr def) -{ - int ret = -1; - size_t i; - - for (i = 0; i < def->nnets; i++) { - virDomainNetDefPtr net = def->nets[i]; - int actualType; - - /* If appropriate, grab a physical device from the configured - * network's pool of devices, or resolve bridge device name - * to the one defined in the network definition. - */ - if (networkAllocateActualDevice(def, net) < 0) - goto cleanup; - - actualType = virDomainNetGetActualType(net); - if (actualType == VIR_DOMAIN_NET_TYPE_HOSTDEV && - net->type == VIR_DOMAIN_NET_TYPE_NETWORK) { - /* Each type='hostdev' network device must also have a - * corresponding entry in the hostdevs array. For netdevs - * that are hardcoded as type='hostdev', this is already - * done by the parser, but for those allocated from a - * network / determined at runtime, we need to do it - * separately. - */ - virDomainHostdevDefPtr hostdev = virDomainNetGetActualHostdev(net); - virDomainHostdevSubsysPCIPtr pcisrc = &hostdev->source.subsys.u.pci; - - if (virDomainHostdevFind(def, hostdev, NULL) >= 0) { - virReportError(VIR_ERR_INTERNAL_ERROR, - _("PCI device %04x:%02x:%02x.%x " - "allocated from network %s is already " - "in use by domain %s"), - pcisrc->addr.domain, pcisrc->addr.bus, - pcisrc->addr.slot, pcisrc->addr.function, - net->data.network.name, def->name); - goto cleanup; - } - if (virDomainHostdevInsert(def, hostdev) < 0) - goto cleanup; - } - } - ret = 0; - cleanup: - return ret; -} - static int qemuDomainDeviceAliasIndex(const virDomainDeviceInfo *info, const char *prefix) { diff --git a/src/qemu/qemu_process.c b/src/qemu/qemu_process.c index ce065d2f8f..67f303a237 100644 --- a/src/qemu/qemu_process.c +++ b/src/qemu/qemu_process.c @@ -4401,6 +4401,59 @@ qemuProcessInit(virQEMUDriverPtr driver, } +/** + * qemuProcessNetworkPrepareDevices + */ +static int +qemuProcessNetworkPrepareDevices(virDomainDefPtr def) +{ + int ret = -1; + size_t i; + + for (i = 0; i < def->nnets; i++) { + virDomainNetDefPtr net = def->nets[i]; + int actualType; + + /* If appropriate, grab a physical device from the configured + * network's pool of devices, or resolve bridge device name + * to the one defined in the network definition. + */ + if (networkAllocateActualDevice(def, net) < 0) + goto cleanup; + + actualType = virDomainNetGetActualType(net); + if (actualType == VIR_DOMAIN_NET_TYPE_HOSTDEV && + net->type == VIR_DOMAIN_NET_TYPE_NETWORK) { + /* Each type='hostdev' network device must also have a + * corresponding entry in the hostdevs array. For netdevs + * that are hardcoded as type='hostdev', this is already + * done by the parser, but for those allocated from a + * network / determined at runtime, we need to do it + * separately. + */ + virDomainHostdevDefPtr hostdev = virDomainNetGetActualHostdev(net); + virDomainHostdevSubsysPCIPtr pcisrc = &hostdev->source.subsys.u.pci; + + if (virDomainHostdevFind(def, hostdev, NULL) >= 0) { + virReportError(VIR_ERR_INTERNAL_ERROR, + _("PCI device %04x:%02x:%02x.%x " + "allocated from network %s is already " + "in use by domain %s"), + pcisrc->addr.domain, pcisrc->addr.bus, + pcisrc->addr.slot, pcisrc->addr.function, + net->data.network.name, def->name); + goto cleanup; + } + if (virDomainHostdevInsert(def, hostdev) < 0) + goto cleanup; + } + } + ret = 0; + cleanup: + return ret; +} + + /** * qemuProcessSetupVcpu: * @vm: domain object @@ -4727,7 +4780,7 @@ qemuProcessLaunch(virConnectPtr conn, * will need to be setup. */ VIR_DEBUG("Preparing network devices"); - if (qemuNetworkPrepareDevices(vm->def) < 0) + if (qemuProcessNetworkPrepareDevices(vm->def) < 0) goto cleanup; /* Must be run before security labelling */ -- GitLab