Rename all PCI device functions to have a standard name prefix

Rename all the pciDeviceXXX and pciXXXDevice APIs to have a
fixed virPCIDevice name prefix
This commit is contained in:
Daniel P. Berrange 2013-01-14 22:11:44 +00:00
parent b46f7f4a0b
commit 202535601c
20 changed files with 704 additions and 693 deletions

View File

@ -36,7 +36,6 @@
#include "virutil.h" #include "virutil.h"
#include "virbuffer.h" #include "virbuffer.h"
#include "viruuid.h" #include "viruuid.h"
#include "virpci.h"
#include "virrandom.h" #include "virrandom.h"
#define VIR_FROM_THIS VIR_FROM_NODEDEV #define VIR_FROM_THIS VIR_FROM_NODEDEV

View File

@ -28,6 +28,7 @@
# include "internal.h" # include "internal.h"
# include "virutil.h" # include "virutil.h"
# include "virthread.h" # include "virthread.h"
# include "virpci.h"
# include <libxml/tree.h> # include <libxml/tree.h>
@ -111,8 +112,8 @@ struct _virNodeDevCapsDef {
unsigned int class; unsigned int class;
char *product_name; char *product_name;
char *vendor_name; char *vendor_name;
struct pci_config_address *physical_function; virPCIDeviceAddressPtr physical_function;
struct pci_config_address **virtual_functions; virPCIDeviceAddressPtr *virtual_functions;
unsigned int num_virtual_functions; unsigned int num_virtual_functions;
unsigned int flags; unsigned int flags;
} pci_dev; } pci_dev;

View File

@ -992,43 +992,43 @@ virNWFilterVarValueGetSimple;
# pci.h # pci.h
pciConfigAddressToSysfsFile; virPCIDeviceAddressGetSysfsFile;
pciDettachDevice; virPCIDeviceDetach;
pciDeviceFileIterate; virPCIDeviceFileIterate;
pciDeviceGetManaged; virPCIDeviceFree;
pciDeviceGetName; virPCIDeviceGetManaged;
pciDeviceGetRemoveSlot; virPCIDeviceGetName;
pciDeviceGetReprobe; virPCIDeviceGetRemoveSlot;
pciDeviceGetUnbindFromStub; virPCIDeviceGetReprobe;
pciDeviceGetUsedBy; virPCIDeviceGetUnbindFromStub;
pciDeviceGetVirtualFunctionInfo; virPCIDeviceGetUsedBy;
pciDeviceIsAssignable; virPCIDeviceIsAssignable;
pciDeviceIsVirtualFunction; virPCIDeviceListAdd;
pciDeviceListAdd; virPCIDeviceListCount;
pciDeviceListCount; virPCIDeviceListDel;
pciDeviceListDel; virPCIDeviceListFind;
pciDeviceListFind; virPCIDeviceListFindIndex;
pciDeviceListFindIndex; virPCIDeviceListFree;
pciDeviceListFree; virPCIDeviceListGet;
pciDeviceListGet; virPCIDeviceListNew;
pciDeviceListNew; virPCIDeviceListSteal;
pciDeviceListSteal; virPCIDeviceListStealIndex;
pciDeviceListStealIndex; virPCIDeviceNew;
pciDeviceNetName; virPCIDeviceReattach;
pciDeviceReAttachInit; virPCIDeviceReattachInit;
pciDeviceSetManaged; virPCIDeviceReset;
pciDeviceSetRemoveSlot; virPCIDeviceSetManaged;
pciDeviceSetReprobe; virPCIDeviceSetRemoveSlot;
pciDeviceSetUnbindFromStub; virPCIDeviceSetReprobe;
pciDeviceSetUsedBy; virPCIDeviceSetUnbindFromStub;
pciFreeDevice; virPCIDeviceSetUsedBy;
pciGetDevice; virPCIDeviceWaitForCleanup;
pciGetPhysicalFunction; virPCIGetNetName;
pciGetVirtualFunctionIndex; virPCIGetPhysicalFunction;
pciGetVirtualFunctions; virPCIGetVirtualFunctionIndex;
pciReAttachDevice; virPCIGetVirtualFunctionInfo;
pciResetDevice; virPCIGetVirtualFunctions;
pciWaitForDeviceCleanup; virPCIIsVirtualFunction;
# secret_conf.h # secret_conf.h

View File

@ -3622,7 +3622,7 @@ static int
networkCreateInterfacePool(virNetworkDefPtr netdef) { networkCreateInterfacePool(virNetworkDefPtr netdef) {
unsigned int num_virt_fns = 0; unsigned int num_virt_fns = 0;
char **vfname = NULL; char **vfname = NULL;
struct pci_config_address **virt_fns; virPCIDeviceAddressPtr *virt_fns;
int ret = -1, ii = 0; int ret = -1, ii = 0;
if ((virNetDevGetVirtualFunctions(netdef->forward.pfs->dev, if ((virNetDevGetVirtualFunctions(netdef->forward.pfs->dev,

View File

@ -481,10 +481,10 @@ static int udevProcessPCI(struct udev_device *device,
goto out; goto out;
} }
if (!pciGetPhysicalFunction(syspath, &data->pci_dev.physical_function)) if (!virPCIGetPhysicalFunction(syspath, &data->pci_dev.physical_function))
data->pci_dev.flags |= VIR_NODE_DEV_CAP_FLAG_PCI_PHYSICAL_FUNCTION; data->pci_dev.flags |= VIR_NODE_DEV_CAP_FLAG_PCI_PHYSICAL_FUNCTION;
if (!pciGetVirtualFunctions(syspath, &data->pci_dev.virtual_functions, if (!virPCIGetVirtualFunctions(syspath, &data->pci_dev.virtual_functions,
&data->pci_dev.num_virtual_functions) || &data->pci_dev.num_virtual_functions) ||
data->pci_dev.num_virtual_functions > 0) data->pci_dev.num_virtual_functions > 0)
data->pci_dev.flags |= VIR_NODE_DEV_CAP_FLAG_PCI_VIRTUAL_FUNCTION; data->pci_dev.flags |= VIR_NODE_DEV_CAP_FLAG_PCI_VIRTUAL_FUNCTION;

View File

@ -33,7 +33,6 @@
#include <sys/time.h> #include <sys/time.h>
#include "qemu_agent.h" #include "qemu_agent.h"
#include "qemu_command.h"
#include "viralloc.h" #include "viralloc.h"
#include "virlog.h" #include "virlog.h"
#include "virerror.h" #include "virerror.h"

View File

@ -181,11 +181,10 @@ struct _virQEMUDriver {
virSecurityManagerPtr securityManager; virSecurityManagerPtr securityManager;
pciDeviceList *activePciHostdevs; virPCIDeviceListPtr activePciHostdevs;
virPCIDeviceListPtr inactivePciHostdevs;
usbDeviceList *activeUsbHostdevs; usbDeviceList *activeUsbHostdevs;
pciDeviceList *inactivePciHostdevs;
virHashTablePtr sharedDisks; virHashTablePtr sharedDisks;
virPortAllocatorPtr remotePorts; virPortAllocatorPtr remotePorts;

View File

@ -774,13 +774,13 @@ qemuStartup(bool privileged,
if (qemuSecurityInit(qemu_driver) < 0) if (qemuSecurityInit(qemu_driver) < 0)
goto error; goto error;
if ((qemu_driver->activePciHostdevs = pciDeviceListNew()) == NULL) if ((qemu_driver->activePciHostdevs = virPCIDeviceListNew()) == NULL)
goto error; goto error;
if ((qemu_driver->activeUsbHostdevs = usbDeviceListNew()) == NULL) if ((qemu_driver->activeUsbHostdevs = usbDeviceListNew()) == NULL)
goto error; goto error;
if ((qemu_driver->inactivePciHostdevs = pciDeviceListNew()) == NULL) if ((qemu_driver->inactivePciHostdevs = virPCIDeviceListNew()) == NULL)
goto error; goto error;
if (!(qemu_driver->sharedDisks = virHashCreate(30, NULL))) if (!(qemu_driver->sharedDisks = virHashCreate(30, NULL)))
@ -1047,8 +1047,8 @@ qemuShutdown(void) {
qemuDriverLock(qemu_driver); qemuDriverLock(qemu_driver);
virNWFilterUnRegisterCallbackDriver(&qemuCallbackDriver); virNWFilterUnRegisterCallbackDriver(&qemuCallbackDriver);
pciDeviceListFree(qemu_driver->activePciHostdevs); virPCIDeviceListFree(qemu_driver->activePciHostdevs);
pciDeviceListFree(qemu_driver->inactivePciHostdevs); virPCIDeviceListFree(qemu_driver->inactivePciHostdevs);
usbDeviceListFree(qemu_driver->activeUsbHostdevs); usbDeviceListFree(qemu_driver->activeUsbHostdevs);
virHashFree(qemu_driver->sharedDisks); virHashFree(qemu_driver->sharedDisks);
virCapabilitiesFree(qemu_driver->caps); virCapabilitiesFree(qemu_driver->caps);
@ -10021,7 +10021,7 @@ static int
qemuNodeDeviceDettach(virNodeDevicePtr dev) qemuNodeDeviceDettach(virNodeDevicePtr dev)
{ {
virQEMUDriverPtr driver = dev->conn->privateData; virQEMUDriverPtr driver = dev->conn->privateData;
pciDevice *pci; virPCIDevicePtr pci;
unsigned domain, bus, slot, function; unsigned domain, bus, slot, function;
int ret = -1; int ret = -1;
bool in_inactive_list = false; bool in_inactive_list = false;
@ -10029,22 +10029,22 @@ qemuNodeDeviceDettach(virNodeDevicePtr dev)
if (qemuNodeDeviceGetPciInfo(dev, &domain, &bus, &slot, &function) < 0) if (qemuNodeDeviceGetPciInfo(dev, &domain, &bus, &slot, &function) < 0)
return -1; return -1;
pci = pciGetDevice(domain, bus, slot, function); pci = virPCIDeviceNew(domain, bus, slot, function);
if (!pci) if (!pci)
return -1; return -1;
qemuDriverLock(driver); qemuDriverLock(driver);
in_inactive_list = pciDeviceListFind(driver->inactivePciHostdevs, pci); in_inactive_list = virPCIDeviceListFind(driver->inactivePciHostdevs, pci);
if (pciDettachDevice(pci, driver->activePciHostdevs, if (virPCIDeviceDetach(pci, driver->activePciHostdevs,
driver->inactivePciHostdevs, "pci-stub") < 0) driver->inactivePciHostdevs, "pci-stub") < 0)
goto out; goto out;
ret = 0; ret = 0;
out: out:
qemuDriverUnlock(driver); qemuDriverUnlock(driver);
if (in_inactive_list) if (in_inactive_list)
pciFreeDevice(pci); virPCIDeviceFree(pci);
return ret; return ret;
} }
@ -10052,43 +10052,43 @@ static int
qemuNodeDeviceReAttach(virNodeDevicePtr dev) qemuNodeDeviceReAttach(virNodeDevicePtr dev)
{ {
virQEMUDriverPtr driver = dev->conn->privateData; virQEMUDriverPtr driver = dev->conn->privateData;
pciDevice *pci; virPCIDevicePtr pci;
pciDevice *other; virPCIDevicePtr other;
unsigned domain, bus, slot, function; unsigned domain, bus, slot, function;
int ret = -1; int ret = -1;
if (qemuNodeDeviceGetPciInfo(dev, &domain, &bus, &slot, &function) < 0) if (qemuNodeDeviceGetPciInfo(dev, &domain, &bus, &slot, &function) < 0)
return -1; return -1;
pci = pciGetDevice(domain, bus, slot, function); pci = virPCIDeviceNew(domain, bus, slot, function);
if (!pci) if (!pci)
return -1; return -1;
other = pciDeviceListFind(driver->activePciHostdevs, pci); other = virPCIDeviceListFind(driver->activePciHostdevs, pci);
if (other) { if (other) {
const char *other_name = pciDeviceGetUsedBy(other); const char *other_name = virPCIDeviceGetUsedBy(other);
if (other_name) if (other_name)
virReportError(VIR_ERR_OPERATION_INVALID, virReportError(VIR_ERR_OPERATION_INVALID,
_("PCI device %s is still in use by domain %s"), _("PCI device %s is still in use by domain %s"),
pciDeviceGetName(pci), other_name); virPCIDeviceGetName(pci), other_name);
else else
virReportError(VIR_ERR_OPERATION_INVALID, virReportError(VIR_ERR_OPERATION_INVALID,
_("PCI device %s is still in use"), _("PCI device %s is still in use"),
pciDeviceGetName(pci)); virPCIDeviceGetName(pci));
} }
pciDeviceReAttachInit(pci); virPCIDeviceReattachInit(pci);
qemuDriverLock(driver); qemuDriverLock(driver);
if (pciReAttachDevice(pci, driver->activePciHostdevs, if (virPCIDeviceReattach(pci, driver->activePciHostdevs,
driver->inactivePciHostdevs, "pci-stub") < 0) driver->inactivePciHostdevs, "pci-stub") < 0)
goto out; goto out;
ret = 0; ret = 0;
out: out:
qemuDriverUnlock(driver); qemuDriverUnlock(driver);
pciFreeDevice(pci); virPCIDeviceFree(pci);
return ret; return ret;
} }
@ -10096,27 +10096,27 @@ static int
qemuNodeDeviceReset(virNodeDevicePtr dev) qemuNodeDeviceReset(virNodeDevicePtr dev)
{ {
virQEMUDriverPtr driver = dev->conn->privateData; virQEMUDriverPtr driver = dev->conn->privateData;
pciDevice *pci; virPCIDevicePtr pci;
unsigned domain, bus, slot, function; unsigned domain, bus, slot, function;
int ret = -1; int ret = -1;
if (qemuNodeDeviceGetPciInfo(dev, &domain, &bus, &slot, &function) < 0) if (qemuNodeDeviceGetPciInfo(dev, &domain, &bus, &slot, &function) < 0)
return -1; return -1;
pci = pciGetDevice(domain, bus, slot, function); pci = virPCIDeviceNew(domain, bus, slot, function);
if (!pci) if (!pci)
return -1; return -1;
qemuDriverLock(driver); qemuDriverLock(driver);
if (pciResetDevice(pci, driver->activePciHostdevs, if (virPCIDeviceReset(pci, driver->activePciHostdevs,
driver->inactivePciHostdevs) < 0) driver->inactivePciHostdevs) < 0)
goto out; goto out;
ret = 0; ret = 0;
out: out:
qemuDriverUnlock(driver); qemuDriverUnlock(driver);
pciFreeDevice(pci); virPCIDeviceFree(pci);
return ret; return ret;
} }

View File

@ -33,84 +33,84 @@
#define VIR_FROM_THIS VIR_FROM_QEMU #define VIR_FROM_THIS VIR_FROM_QEMU
static pciDeviceList * static virPCIDeviceListPtr
qemuGetPciHostDeviceList(virDomainHostdevDefPtr *hostdevs, int nhostdevs) qemuGetPciHostDeviceList(virDomainHostdevDefPtr *hostdevs, int nhostdevs)
{ {
pciDeviceList *list; virPCIDeviceListPtr list;
int i; int i;
if (!(list = pciDeviceListNew())) if (!(list = virPCIDeviceListNew()))
return NULL; return NULL;
for (i = 0 ; i < nhostdevs ; i++) { for (i = 0 ; i < nhostdevs ; i++) {
virDomainHostdevDefPtr hostdev = hostdevs[i]; virDomainHostdevDefPtr hostdev = hostdevs[i];
pciDevice *dev; virPCIDevicePtr dev;
if (hostdev->mode != VIR_DOMAIN_HOSTDEV_MODE_SUBSYS) if (hostdev->mode != VIR_DOMAIN_HOSTDEV_MODE_SUBSYS)
continue; continue;
if (hostdev->source.subsys.type != VIR_DOMAIN_HOSTDEV_SUBSYS_TYPE_PCI) if (hostdev->source.subsys.type != VIR_DOMAIN_HOSTDEV_SUBSYS_TYPE_PCI)
continue; continue;
dev = pciGetDevice(hostdev->source.subsys.u.pci.domain, dev = virPCIDeviceNew(hostdev->source.subsys.u.pci.domain,
hostdev->source.subsys.u.pci.bus, hostdev->source.subsys.u.pci.bus,
hostdev->source.subsys.u.pci.slot, hostdev->source.subsys.u.pci.slot,
hostdev->source.subsys.u.pci.function); hostdev->source.subsys.u.pci.function);
if (!dev) { if (!dev) {
pciDeviceListFree(list); virPCIDeviceListFree(list);
return NULL; return NULL;
} }
if (pciDeviceListAdd(list, dev) < 0) { if (virPCIDeviceListAdd(list, dev) < 0) {
pciFreeDevice(dev); virPCIDeviceFree(dev);
pciDeviceListFree(list); virPCIDeviceListFree(list);
return NULL; return NULL;
} }
pciDeviceSetManaged(dev, hostdev->managed); virPCIDeviceSetManaged(dev, hostdev->managed);
} }
return list; return list;
} }
static pciDeviceList * static virPCIDeviceListPtr
qemuGetActivePciHostDeviceList(virQEMUDriverPtr driver, qemuGetActivePciHostDeviceList(virQEMUDriverPtr driver,
virDomainHostdevDefPtr *hostdevs, virDomainHostdevDefPtr *hostdevs,
int nhostdevs) int nhostdevs)
{ {
pciDeviceList *list; virPCIDeviceListPtr list;
int i; int i;
if (!(list = pciDeviceListNew())) if (!(list = virPCIDeviceListNew()))
return NULL; return NULL;
for (i = 0 ; i < nhostdevs ; i++) { for (i = 0 ; i < nhostdevs ; i++) {
virDomainHostdevDefPtr hostdev = hostdevs[i]; virDomainHostdevDefPtr hostdev = hostdevs[i];
pciDevice *dev; virPCIDevicePtr dev;
pciDevice *activeDev; virPCIDevicePtr activeDev;
if (hostdev->mode != VIR_DOMAIN_HOSTDEV_MODE_SUBSYS) if (hostdev->mode != VIR_DOMAIN_HOSTDEV_MODE_SUBSYS)
continue; continue;
if (hostdev->source.subsys.type != VIR_DOMAIN_HOSTDEV_SUBSYS_TYPE_PCI) if (hostdev->source.subsys.type != VIR_DOMAIN_HOSTDEV_SUBSYS_TYPE_PCI)
continue; continue;
dev = pciGetDevice(hostdev->source.subsys.u.pci.domain, dev = virPCIDeviceNew(hostdev->source.subsys.u.pci.domain,
hostdev->source.subsys.u.pci.bus, hostdev->source.subsys.u.pci.bus,
hostdev->source.subsys.u.pci.slot, hostdev->source.subsys.u.pci.slot,
hostdev->source.subsys.u.pci.function); hostdev->source.subsys.u.pci.function);
if (!dev) { if (!dev) {
pciDeviceListFree(list); virPCIDeviceListFree(list);
return NULL; return NULL;
} }
if ((activeDev = pciDeviceListFind(driver->activePciHostdevs, dev))) { if ((activeDev = virPCIDeviceListFind(driver->activePciHostdevs, dev))) {
if (pciDeviceListAdd(list, activeDev) < 0) { if (virPCIDeviceListAdd(list, activeDev) < 0) {
pciFreeDevice(dev); virPCIDeviceFree(dev);
pciDeviceListFree(list); virPCIDeviceListFree(list);
return NULL; return NULL;
} }
} }
pciFreeDevice(dev); virPCIDeviceFree(dev);
} }
return list; return list;
@ -126,7 +126,7 @@ int qemuUpdateActivePciHostdevs(virQEMUDriverPtr driver,
return 0; return 0;
for (i = 0; i < def->nhostdevs; i++) { for (i = 0; i < def->nhostdevs; i++) {
pciDevice *dev = NULL; virPCIDevicePtr dev = NULL;
hostdev = def->hostdevs[i]; hostdev = def->hostdevs[i];
if (hostdev->mode != VIR_DOMAIN_HOSTDEV_MODE_SUBSYS) if (hostdev->mode != VIR_DOMAIN_HOSTDEV_MODE_SUBSYS)
@ -134,24 +134,24 @@ int qemuUpdateActivePciHostdevs(virQEMUDriverPtr driver,
if (hostdev->source.subsys.type != VIR_DOMAIN_HOSTDEV_SUBSYS_TYPE_PCI) if (hostdev->source.subsys.type != VIR_DOMAIN_HOSTDEV_SUBSYS_TYPE_PCI)
continue; continue;
dev = pciGetDevice(hostdev->source.subsys.u.pci.domain, dev = virPCIDeviceNew(hostdev->source.subsys.u.pci.domain,
hostdev->source.subsys.u.pci.bus, hostdev->source.subsys.u.pci.bus,
hostdev->source.subsys.u.pci.slot, hostdev->source.subsys.u.pci.slot,
hostdev->source.subsys.u.pci.function); hostdev->source.subsys.u.pci.function);
if (!dev) if (!dev)
return -1; return -1;
pciDeviceSetManaged(dev, hostdev->managed); virPCIDeviceSetManaged(dev, hostdev->managed);
pciDeviceSetUsedBy(dev, def->name); virPCIDeviceSetUsedBy(dev, def->name);
/* Setup the original states for the PCI device */ /* Setup the original states for the PCI device */
pciDeviceSetUnbindFromStub(dev, hostdev->origstates.states.pci.unbind_from_stub); virPCIDeviceSetUnbindFromStub(dev, hostdev->origstates.states.pci.unbind_from_stub);
pciDeviceSetRemoveSlot(dev, hostdev->origstates.states.pci.remove_slot); virPCIDeviceSetRemoveSlot(dev, hostdev->origstates.states.pci.remove_slot);
pciDeviceSetReprobe(dev, hostdev->origstates.states.pci.reprobe); virPCIDeviceSetReprobe(dev, hostdev->origstates.states.pci.reprobe);
if (pciDeviceListAdd(driver->activePciHostdevs, dev) < 0) { if (virPCIDeviceListAdd(driver->activePciHostdevs, dev) < 0) {
pciFreeDevice(dev); virPCIDeviceFree(dev);
return -1; return -1;
} }
} }
@ -203,14 +203,14 @@ qemuUpdateActiveUsbHostdevs(virQEMUDriverPtr driver,
static int static int
qemuDomainHostdevPciSysfsPath(virDomainHostdevDefPtr hostdev, char **sysfs_path) qemuDomainHostdevPciSysfsPath(virDomainHostdevDefPtr hostdev, char **sysfs_path)
{ {
struct pci_config_address config_address; virPCIDeviceAddress config_address;
config_address.domain = hostdev->source.subsys.u.pci.domain; config_address.domain = hostdev->source.subsys.u.pci.domain;
config_address.bus = hostdev->source.subsys.u.pci.bus; config_address.bus = hostdev->source.subsys.u.pci.bus;
config_address.slot = hostdev->source.subsys.u.pci.slot; config_address.slot = hostdev->source.subsys.u.pci.slot;
config_address.function = hostdev->source.subsys.u.pci.function; config_address.function = hostdev->source.subsys.u.pci.function;
return pciConfigAddressToSysfsFile(&config_address, sysfs_path); return virPCIDeviceAddressGetSysfsFile(&config_address, sysfs_path);
} }
int int
@ -222,7 +222,7 @@ qemuDomainHostdevIsVirtualFunction(virDomainHostdevDefPtr hostdev)
if (qemuDomainHostdevPciSysfsPath(hostdev, &sysfs_path) < 0) if (qemuDomainHostdevPciSysfsPath(hostdev, &sysfs_path) < 0)
return ret; return ret;
ret = pciDeviceIsVirtualFunction(sysfs_path); ret = virPCIIsVirtualFunction(sysfs_path);
VIR_FREE(sysfs_path); VIR_FREE(sysfs_path);
@ -239,12 +239,12 @@ qemuDomainHostdevNetDevice(virDomainHostdevDefPtr hostdev, char **linkdev,
if (qemuDomainHostdevPciSysfsPath(hostdev, &sysfs_path) < 0) if (qemuDomainHostdevPciSysfsPath(hostdev, &sysfs_path) < 0)
return ret; return ret;
if (pciDeviceIsVirtualFunction(sysfs_path) == 1) { if (virPCIIsVirtualFunction(sysfs_path) == 1) {
if (pciDeviceGetVirtualFunctionInfo(sysfs_path, linkdev, if (virPCIGetVirtualFunctionInfo(sysfs_path, linkdev,
vf) < 0) vf) < 0)
goto cleanup; goto cleanup;
} else { } else {
if (pciDeviceNetName(sysfs_path, linkdev) < 0) if (virPCIGetNetName(sysfs_path, linkdev) < 0)
goto cleanup; goto cleanup;
*vf = -1; *vf = -1;
} }
@ -406,7 +406,7 @@ int qemuPrepareHostdevPCIDevices(virQEMUDriverPtr driver,
virDomainHostdevDefPtr *hostdevs, virDomainHostdevDefPtr *hostdevs,
int nhostdevs) int nhostdevs)
{ {
pciDeviceList *pcidevs; virPCIDeviceListPtr pcidevs;
int last_processed_hostdev_vf = -1; int last_processed_hostdev_vf = -1;
int i; int i;
int ret = -1; int ret = -1;
@ -427,48 +427,48 @@ int qemuPrepareHostdevPCIDevices(virQEMUDriverPtr driver,
* to pci-stub.ko * to pci-stub.ko
*/ */
for (i = 0; i < pciDeviceListCount(pcidevs); i++) { for (i = 0; i < virPCIDeviceListCount(pcidevs); i++) {
pciDevice *dev = pciDeviceListGet(pcidevs, i); virPCIDevicePtr dev = virPCIDeviceListGet(pcidevs, i);
pciDevice *other; virPCIDevicePtr other;
if (!pciDeviceIsAssignable(dev, !cfg->relaxedACS)) { if (!virPCIDeviceIsAssignable(dev, !cfg->relaxedACS)) {
virReportError(VIR_ERR_OPERATION_INVALID, virReportError(VIR_ERR_OPERATION_INVALID,
_("PCI device %s is not assignable"), _("PCI device %s is not assignable"),
pciDeviceGetName(dev)); virPCIDeviceGetName(dev));
goto cleanup; goto cleanup;
} }
/* The device is in use by other active domain if /* The device is in use by other active domain if
* the dev is in list driver->activePciHostdevs. * the dev is in list driver->activePciHostdevs.
*/ */
if ((other = pciDeviceListFind(driver->activePciHostdevs, dev))) { if ((other = virPCIDeviceListFind(driver->activePciHostdevs, dev))) {
const char *other_name = pciDeviceGetUsedBy(other); const char *other_name = virPCIDeviceGetUsedBy(other);
if (other_name) if (other_name)
virReportError(VIR_ERR_OPERATION_INVALID, virReportError(VIR_ERR_OPERATION_INVALID,
_("PCI device %s is in use by domain %s"), _("PCI device %s is in use by domain %s"),
pciDeviceGetName(dev), other_name); virPCIDeviceGetName(dev), other_name);
else else
virReportError(VIR_ERR_OPERATION_INVALID, virReportError(VIR_ERR_OPERATION_INVALID,
_("PCI device %s is already in use"), _("PCI device %s is already in use"),
pciDeviceGetName(dev)); virPCIDeviceGetName(dev));
goto cleanup; goto cleanup;
} }
} }
/* Loop 2: detach managed devices */ /* Loop 2: detach managed devices */
for (i = 0; i < pciDeviceListCount(pcidevs); i++) { for (i = 0; i < virPCIDeviceListCount(pcidevs); i++) {
pciDevice *dev = pciDeviceListGet(pcidevs, i); virPCIDevicePtr dev = virPCIDeviceListGet(pcidevs, i);
if (pciDeviceGetManaged(dev) && if (virPCIDeviceGetManaged(dev) &&
pciDettachDevice(dev, driver->activePciHostdevs, NULL, "pci-stub") < 0) virPCIDeviceDetach(dev, driver->activePciHostdevs, NULL, "pci-stub") < 0)
goto reattachdevs; goto reattachdevs;
} }
/* Loop 3: Now that all the PCI hostdevs have been detached, we /* Loop 3: Now that all the PCI hostdevs have been detached, we
* can safely reset them */ * can safely reset them */
for (i = 0; i < pciDeviceListCount(pcidevs); i++) { for (i = 0; i < virPCIDeviceListCount(pcidevs); i++) {
pciDevice *dev = pciDeviceListGet(pcidevs, i); virPCIDevicePtr dev = virPCIDeviceListGet(pcidevs, i);
if (pciResetDevice(dev, driver->activePciHostdevs, if (virPCIDeviceReset(dev, driver->activePciHostdevs,
driver->inactivePciHostdevs) < 0) driver->inactivePciHostdevs) < 0)
goto reattachdevs; goto reattachdevs;
} }
@ -491,35 +491,35 @@ int qemuPrepareHostdevPCIDevices(virQEMUDriverPtr driver,
} }
/* Loop 5: Now mark all the devices as active */ /* Loop 5: Now mark all the devices as active */
for (i = 0; i < pciDeviceListCount(pcidevs); i++) { for (i = 0; i < virPCIDeviceListCount(pcidevs); i++) {
pciDevice *dev = pciDeviceListGet(pcidevs, i); virPCIDevicePtr dev = virPCIDeviceListGet(pcidevs, i);
if (pciDeviceListAdd(driver->activePciHostdevs, dev) < 0) if (virPCIDeviceListAdd(driver->activePciHostdevs, dev) < 0)
goto inactivedevs; goto inactivedevs;
} }
/* Loop 6: Now remove the devices from inactive list. */ /* Loop 6: Now remove the devices from inactive list. */
for (i = 0; i < pciDeviceListCount(pcidevs); i++) { for (i = 0; i < virPCIDeviceListCount(pcidevs); i++) {
pciDevice *dev = pciDeviceListGet(pcidevs, i); virPCIDevicePtr dev = virPCIDeviceListGet(pcidevs, i);
pciDeviceListDel(driver->inactivePciHostdevs, dev); virPCIDeviceListDel(driver->inactivePciHostdevs, dev);
} }
/* Loop 7: Now set the used_by_domain of the device in /* Loop 7: Now set the used_by_domain of the device in
* driver->activePciHostdevs as domain name. * driver->activePciHostdevs as domain name.
*/ */
for (i = 0; i < pciDeviceListCount(pcidevs); i++) { for (i = 0; i < virPCIDeviceListCount(pcidevs); i++) {
pciDevice *dev, *activeDev; virPCIDevicePtr dev, activeDev;
dev = pciDeviceListGet(pcidevs, i); dev = virPCIDeviceListGet(pcidevs, i);
activeDev = pciDeviceListFind(driver->activePciHostdevs, dev); activeDev = virPCIDeviceListFind(driver->activePciHostdevs, dev);
if (activeDev) if (activeDev)
pciDeviceSetUsedBy(activeDev, name); virPCIDeviceSetUsedBy(activeDev, name);
} }
/* Loop 8: Now set the original states for hostdev def */ /* Loop 8: Now set the original states for hostdev def */
for (i = 0; i < nhostdevs; i++) { for (i = 0; i < nhostdevs; i++) {
pciDevice *dev; virPCIDevicePtr dev;
pciDevice *pcidev; virPCIDevicePtr pcidev;
virDomainHostdevDefPtr hostdev = hostdevs[i]; virDomainHostdevDefPtr hostdev = hostdevs[i];
if (hostdev->mode != VIR_DOMAIN_HOSTDEV_MODE_SUBSYS) if (hostdev->mode != VIR_DOMAIN_HOSTDEV_MODE_SUBSYS)
@ -527,41 +527,41 @@ int qemuPrepareHostdevPCIDevices(virQEMUDriverPtr driver,
if (hostdev->source.subsys.type != VIR_DOMAIN_HOSTDEV_SUBSYS_TYPE_PCI) if (hostdev->source.subsys.type != VIR_DOMAIN_HOSTDEV_SUBSYS_TYPE_PCI)
continue; continue;
dev = pciGetDevice(hostdev->source.subsys.u.pci.domain, dev = virPCIDeviceNew(hostdev->source.subsys.u.pci.domain,
hostdev->source.subsys.u.pci.bus, hostdev->source.subsys.u.pci.bus,
hostdev->source.subsys.u.pci.slot, hostdev->source.subsys.u.pci.slot,
hostdev->source.subsys.u.pci.function); hostdev->source.subsys.u.pci.function);
/* original states "unbind_from_stub", "remove_slot", /* original states "unbind_from_stub", "remove_slot",
* "reprobe" were already set by pciDettachDevice in * "reprobe" were already set by pciDettachDevice in
* loop 2. * loop 2.
*/ */
if ((pcidev = pciDeviceListFind(pcidevs, dev))) { if ((pcidev = virPCIDeviceListFind(pcidevs, dev))) {
hostdev->origstates.states.pci.unbind_from_stub = hostdev->origstates.states.pci.unbind_from_stub =
pciDeviceGetUnbindFromStub(pcidev); virPCIDeviceGetUnbindFromStub(pcidev);
hostdev->origstates.states.pci.remove_slot = hostdev->origstates.states.pci.remove_slot =
pciDeviceGetRemoveSlot(pcidev); virPCIDeviceGetRemoveSlot(pcidev);
hostdev->origstates.states.pci.reprobe = hostdev->origstates.states.pci.reprobe =
pciDeviceGetReprobe(pcidev); virPCIDeviceGetReprobe(pcidev);
} }
pciFreeDevice(dev); virPCIDeviceFree(dev);
} }
/* Loop 9: Now steal all the devices from pcidevs */ /* Loop 9: Now steal all the devices from pcidevs */
while (pciDeviceListCount(pcidevs) > 0) while (virPCIDeviceListCount(pcidevs) > 0)
pciDeviceListStealIndex(pcidevs, 0); virPCIDeviceListStealIndex(pcidevs, 0);
ret = 0; ret = 0;
goto cleanup; goto cleanup;
inactivedevs: inactivedevs:
/* Only steal all the devices from driver->activePciHostdevs. We will /* Only steal all the devices from driver->activePciHostdevs. We will
* free them in pciDeviceListFree(). * free them in virPCIDeviceListFree().
*/ */
while (pciDeviceListCount(pcidevs) > 0) { while (virPCIDeviceListCount(pcidevs) > 0) {
pciDevice *dev = pciDeviceListGet(pcidevs, 0); virPCIDevicePtr dev = virPCIDeviceListGet(pcidevs, 0);
pciDeviceListSteal(driver->activePciHostdevs, dev); virPCIDeviceListSteal(driver->activePciHostdevs, dev);
} }
resetvfnetconfig: resetvfnetconfig:
@ -574,13 +574,13 @@ resetvfnetconfig:
} }
reattachdevs: reattachdevs:
for (i = 0; i < pciDeviceListCount(pcidevs); i++) { for (i = 0; i < virPCIDeviceListCount(pcidevs); i++) {
pciDevice *dev = pciDeviceListGet(pcidevs, i); virPCIDevicePtr dev = virPCIDeviceListGet(pcidevs, i);
pciReAttachDevice(dev, driver->activePciHostdevs, NULL, "pci-stub"); virPCIDeviceReattach(dev, driver->activePciHostdevs, NULL, "pci-stub");
} }
cleanup: cleanup:
pciDeviceListFree(pcidevs); virPCIDeviceListFree(pcidevs);
virObjectUnref(cfg); virObjectUnref(cfg);
return ret; return ret;
} }
@ -813,33 +813,33 @@ int qemuPrepareHostDevices(virQEMUDriverPtr driver,
} }
void qemuReattachPciDevice(pciDevice *dev, virQEMUDriverPtr driver) void qemuReattachPciDevice(virPCIDevicePtr dev, virQEMUDriverPtr driver)
{ {
int retries = 100; int retries = 100;
/* If the device is not managed and was attached to guest /* If the device is not managed and was attached to guest
* successfully, it must have been inactive. * successfully, it must have been inactive.
*/ */
if (!pciDeviceGetManaged(dev)) { if (!virPCIDeviceGetManaged(dev)) {
if (pciDeviceListAdd(driver->inactivePciHostdevs, dev) < 0) if (virPCIDeviceListAdd(driver->inactivePciHostdevs, dev) < 0)
pciFreeDevice(dev); virPCIDeviceFree(dev);
return; return;
} }
while (pciWaitForDeviceCleanup(dev, "kvm_assigned_device") while (virPCIDeviceWaitForCleanup(dev, "kvm_assigned_device")
&& retries) { && retries) {
usleep(100*1000); usleep(100*1000);
retries--; retries--;
} }
if (pciReAttachDevice(dev, driver->activePciHostdevs, if (virPCIDeviceReattach(dev, driver->activePciHostdevs,
driver->inactivePciHostdevs, "pci-stub") < 0) { driver->inactivePciHostdevs, "pci-stub") < 0) {
virErrorPtr err = virGetLastError(); virErrorPtr err = virGetLastError();
VIR_ERROR(_("Failed to re-attach PCI device: %s"), VIR_ERROR(_("Failed to re-attach PCI device: %s"),
err ? err->message : _("unknown error")); err ? err->message : _("unknown error"));
virResetError(err); virResetError(err);
} }
pciFreeDevice(dev); virPCIDeviceFree(dev);
} }
@ -848,7 +848,7 @@ void qemuDomainReAttachHostdevDevices(virQEMUDriverPtr driver,
virDomainHostdevDefPtr *hostdevs, virDomainHostdevDefPtr *hostdevs,
int nhostdevs) int nhostdevs)
{ {
pciDeviceList *pcidevs; virPCIDeviceListPtr pcidevs;
int i; int i;
virQEMUDriverConfigPtr cfg = virQEMUDriverGetConfig(driver); virQEMUDriverConfigPtr cfg = virQEMUDriverGetConfig(driver);
@ -856,7 +856,7 @@ void qemuDomainReAttachHostdevDevices(virQEMUDriverPtr driver,
hostdevs, hostdevs,
nhostdevs))) { nhostdevs))) {
virErrorPtr err = virGetLastError(); virErrorPtr err = virGetLastError();
VIR_ERROR(_("Failed to allocate pciDeviceList: %s"), VIR_ERROR(_("Failed to allocate PCI device list: %s"),
err ? err->message : _("unknown error")); err ? err->message : _("unknown error"));
virResetError(err); virResetError(err);
goto cleanup; goto cleanup;
@ -866,22 +866,22 @@ void qemuDomainReAttachHostdevDevices(virQEMUDriverPtr driver,
* them and reset all the devices before re-attach. * them and reset all the devices before re-attach.
* Attach mac and port profile parameters to devices * Attach mac and port profile parameters to devices
*/ */
for (i = 0; i < pciDeviceListCount(pcidevs); i++) { for (i = 0; i < virPCIDeviceListCount(pcidevs); i++) {
pciDevice *dev = pciDeviceListGet(pcidevs, i); virPCIDevicePtr dev = virPCIDeviceListGet(pcidevs, i);
pciDevice *activeDev = NULL; virPCIDevicePtr activeDev = NULL;
/* Never delete the dev from list driver->activePciHostdevs /* Never delete the dev from list driver->activePciHostdevs
* if it's used by other domain. * if it's used by other domain.
*/ */
activeDev = pciDeviceListFind(driver->activePciHostdevs, dev); activeDev = virPCIDeviceListFind(driver->activePciHostdevs, dev);
if (activeDev && if (activeDev &&
STRNEQ_NULLABLE(name, pciDeviceGetUsedBy(activeDev))) { STRNEQ_NULLABLE(name, virPCIDeviceGetUsedBy(activeDev))) {
pciDeviceListSteal(pcidevs, dev); virPCIDeviceListSteal(pcidevs, dev);
continue; continue;
} }
/* pciDeviceListFree() will take care of freeing the dev. */ /* virPCIDeviceListFree() will take care of freeing the dev. */
pciDeviceListSteal(driver->activePciHostdevs, dev); virPCIDeviceListSteal(driver->activePciHostdevs, dev);
} }
/* /*
@ -900,10 +900,10 @@ void qemuDomainReAttachHostdevDevices(virQEMUDriverPtr driver,
} }
} }
for (i = 0; i < pciDeviceListCount(pcidevs); i++) { for (i = 0; i < virPCIDeviceListCount(pcidevs); i++) {
pciDevice *dev = pciDeviceListGet(pcidevs, i); virPCIDevicePtr dev = virPCIDeviceListGet(pcidevs, i);
if (pciResetDevice(dev, driver->activePciHostdevs, if (virPCIDeviceReset(dev, driver->activePciHostdevs,
driver->inactivePciHostdevs) < 0) { driver->inactivePciHostdevs) < 0) {
virErrorPtr err = virGetLastError(); virErrorPtr err = virGetLastError();
VIR_ERROR(_("Failed to reset PCI device: %s"), VIR_ERROR(_("Failed to reset PCI device: %s"),
err ? err->message : _("unknown error")); err ? err->message : _("unknown error"));
@ -911,12 +911,12 @@ void qemuDomainReAttachHostdevDevices(virQEMUDriverPtr driver,
} }
} }
while (pciDeviceListCount(pcidevs) > 0) { while (virPCIDeviceListCount(pcidevs) > 0) {
pciDevice *dev = pciDeviceListStealIndex(pcidevs, 0); virPCIDevicePtr dev = virPCIDeviceListStealIndex(pcidevs, 0);
qemuReattachPciDevice(dev, driver); qemuReattachPciDevice(dev, driver);
} }
pciDeviceListFree(pcidevs); virPCIDeviceListFree(pcidevs);
cleanup: cleanup:
virObjectUnref(cfg); virObjectUnref(cfg);
} }

View File

@ -45,7 +45,7 @@ int qemuPrepareHostdevUSBDevices(virQEMUDriverPtr driver,
int qemuPrepareHostDevices(virQEMUDriverPtr driver, int qemuPrepareHostDevices(virQEMUDriverPtr driver,
virDomainDefPtr def, virDomainDefPtr def,
bool coldBoot); bool coldBoot);
void qemuReattachPciDevice(pciDevice *dev, virQEMUDriverPtr driver); void qemuReattachPciDevice(virPCIDevicePtr dev, virQEMUDriverPtr driver);
void qemuDomainReAttachHostdevDevices(virQEMUDriverPtr driver, void qemuDomainReAttachHostdevDevices(virQEMUDriverPtr driver,
const char *name, const char *name,
virDomainHostdevDefPtr *hostdevs, virDomainHostdevDefPtr *hostdevs,

View File

@ -2331,8 +2331,8 @@ qemuDomainDetachHostPciDevice(virQEMUDriverPtr driver,
qemuDomainObjPrivatePtr priv = vm->privateData; qemuDomainObjPrivatePtr priv = vm->privateData;
virDomainHostdevSubsysPtr subsys = &detach->source.subsys; virDomainHostdevSubsysPtr subsys = &detach->source.subsys;
int ret = -1, rv; int ret = -1, rv;
pciDevice *pci; virPCIDevicePtr pci;
pciDevice *activePci; virPCIDevicePtr activePci;
virQEMUDriverConfigPtr cfg = virQEMUDriverGetConfig(driver); virQEMUDriverConfigPtr cfg = virQEMUDriverGetConfig(driver);
if (qemuIsMultiFunctionDevice(vm->def, detach->info)) { if (qemuIsMultiFunctionDevice(vm->def, detach->info)) {
@ -2368,20 +2368,20 @@ qemuDomainDetachHostPciDevice(virQEMUDriverPtr driver,
if (detach->parent.data.net) if (detach->parent.data.net)
qemuDomainHostdevNetConfigRestore(detach, cfg->stateDir); qemuDomainHostdevNetConfigRestore(detach, cfg->stateDir);
pci = pciGetDevice(subsys->u.pci.domain, subsys->u.pci.bus, pci = virPCIDeviceNew(subsys->u.pci.domain, subsys->u.pci.bus,
subsys->u.pci.slot, subsys->u.pci.function); subsys->u.pci.slot, subsys->u.pci.function);
if (pci) { if (pci) {
activePci = pciDeviceListSteal(driver->activePciHostdevs, pci); activePci = virPCIDeviceListSteal(driver->activePciHostdevs, pci);
if (activePci && if (activePci &&
pciResetDevice(activePci, driver->activePciHostdevs, virPCIDeviceReset(activePci, driver->activePciHostdevs,
driver->inactivePciHostdevs) == 0) { driver->inactivePciHostdevs) == 0) {
qemuReattachPciDevice(activePci, driver); qemuReattachPciDevice(activePci, driver);
ret = 0; ret = 0;
} else { } else {
/* reset of the device failed, treat it as if it was returned */ /* reset of the device failed, treat it as if it was returned */
pciFreeDevice(activePci); virPCIDeviceFree(activePci);
} }
pciFreeDevice(pci); virPCIDeviceFree(pci);
} }
if (qemuCapsGet(priv->caps, QEMU_CAPS_DEVICE) && if (qemuCapsGet(priv->caps, QEMU_CAPS_DEVICE) &&

View File

@ -328,8 +328,8 @@ AppArmorSetSecurityUSBLabel(usbDevice *dev ATTRIBUTE_UNUSED,
} }
static int static int
AppArmorSetSecurityPCILabel(pciDevice *dev ATTRIBUTE_UNUSED, AppArmorSetSecurityPCILabel(virPCIDevicePtr dev ATTRIBUTE_UNUSED,
const char *file, void *opaque) const char *file, void *opaque)
{ {
struct SDPDOP *ptr = opaque; struct SDPDOP *ptr = opaque;
virDomainDefPtr def = ptr->def; virDomainDefPtr def = ptr->def;
@ -783,16 +783,17 @@ AppArmorSetSecurityHostdevLabel(virSecurityManagerPtr mgr,
} }
case VIR_DOMAIN_HOSTDEV_SUBSYS_TYPE_PCI: { case VIR_DOMAIN_HOSTDEV_SUBSYS_TYPE_PCI: {
pciDevice *pci = pciGetDevice(dev->source.subsys.u.pci.domain, virPCIDevicePtr pci =
dev->source.subsys.u.pci.bus, virPCIDeviceNew(dev->source.subsys.u.pci.domain,
dev->source.subsys.u.pci.slot, dev->source.subsys.u.pci.bus,
dev->source.subsys.u.pci.function); dev->source.subsys.u.pci.slot,
dev->source.subsys.u.pci.function);
if (!pci) if (!pci)
goto done; goto done;
ret = pciDeviceFileIterate(pci, AppArmorSetSecurityPCILabel, ptr); ret = virPCIDeviceFileIterate(pci, AppArmorSetSecurityPCILabel, ptr);
pciFreeDevice(pci); virPCIDeviceFree(pci);
break; break;
} }

View File

@ -434,7 +434,7 @@ virSecurityDACRestoreSecurityImageLabel(virSecurityManagerPtr mgr,
static int static int
virSecurityDACSetSecurityPCILabel(pciDevice *dev ATTRIBUTE_UNUSED, virSecurityDACSetSecurityPCILabel(virPCIDevicePtr dev ATTRIBUTE_UNUSED,
const char *file, const char *file,
void *opaque) void *opaque)
{ {
@ -507,17 +507,18 @@ virSecurityDACSetSecurityHostdevLabel(virSecurityManagerPtr mgr,
} }
case VIR_DOMAIN_HOSTDEV_SUBSYS_TYPE_PCI: { case VIR_DOMAIN_HOSTDEV_SUBSYS_TYPE_PCI: {
pciDevice *pci = pciGetDevice(dev->source.subsys.u.pci.domain, virPCIDevicePtr pci =
dev->source.subsys.u.pci.bus, virPCIDeviceNew(dev->source.subsys.u.pci.domain,
dev->source.subsys.u.pci.slot, dev->source.subsys.u.pci.bus,
dev->source.subsys.u.pci.function); dev->source.subsys.u.pci.slot,
dev->source.subsys.u.pci.function);
if (!pci) if (!pci)
goto done; goto done;
ret = pciDeviceFileIterate(pci, virSecurityDACSetSecurityPCILabel, ret = virPCIDeviceFileIterate(pci, virSecurityDACSetSecurityPCILabel,
params); params);
pciFreeDevice(pci); virPCIDeviceFree(pci);
break; break;
} }
@ -533,7 +534,7 @@ done:
static int static int
virSecurityDACRestoreSecurityPCILabel(pciDevice *dev ATTRIBUTE_UNUSED, virSecurityDACRestoreSecurityPCILabel(virPCIDevicePtr dev ATTRIBUTE_UNUSED,
const char *file, const char *file,
void *opaque ATTRIBUTE_UNUSED) void *opaque ATTRIBUTE_UNUSED)
{ {
@ -586,16 +587,17 @@ virSecurityDACRestoreSecurityHostdevLabel(virSecurityManagerPtr mgr,
} }
case VIR_DOMAIN_HOSTDEV_SUBSYS_TYPE_PCI: { case VIR_DOMAIN_HOSTDEV_SUBSYS_TYPE_PCI: {
pciDevice *pci = pciGetDevice(dev->source.subsys.u.pci.domain, virPCIDevicePtr pci =
dev->source.subsys.u.pci.bus, virPCIDeviceNew(dev->source.subsys.u.pci.domain,
dev->source.subsys.u.pci.slot, dev->source.subsys.u.pci.bus,
dev->source.subsys.u.pci.function); dev->source.subsys.u.pci.slot,
dev->source.subsys.u.pci.function);
if (!pci) if (!pci)
goto done; goto done;
ret = pciDeviceFileIterate(pci, virSecurityDACRestoreSecurityPCILabel, mgr); ret = virPCIDeviceFileIterate(pci, virSecurityDACRestoreSecurityPCILabel, mgr);
pciFreeDevice(pci); virPCIDeviceFree(pci);
break; break;
} }

View File

@ -1159,7 +1159,7 @@ virSecuritySELinuxSetSecurityImageLabel(virSecurityManagerPtr mgr,
static int static int
virSecuritySELinuxSetSecurityPCILabel(pciDevice *dev ATTRIBUTE_UNUSED, virSecuritySELinuxSetSecurityPCILabel(virPCIDevicePtr dev ATTRIBUTE_UNUSED,
const char *file, void *opaque) const char *file, void *opaque)
{ {
virSecurityLabelDefPtr secdef; virSecurityLabelDefPtr secdef;
@ -1213,16 +1213,17 @@ virSecuritySELinuxSetSecurityHostdevSubsysLabel(virDomainDefPtr def,
} }
case VIR_DOMAIN_HOSTDEV_SUBSYS_TYPE_PCI: { case VIR_DOMAIN_HOSTDEV_SUBSYS_TYPE_PCI: {
pciDevice *pci = pciGetDevice(dev->source.subsys.u.pci.domain, virPCIDevicePtr pci =
dev->source.subsys.u.pci.bus, virPCIDeviceNew(dev->source.subsys.u.pci.domain,
dev->source.subsys.u.pci.slot, dev->source.subsys.u.pci.bus,
dev->source.subsys.u.pci.function); dev->source.subsys.u.pci.slot,
dev->source.subsys.u.pci.function);
if (!pci) if (!pci)
goto done; goto done;
ret = pciDeviceFileIterate(pci, virSecuritySELinuxSetSecurityPCILabel, def); ret = virPCIDeviceFileIterate(pci, virSecuritySELinuxSetSecurityPCILabel, def);
pciFreeDevice(pci); virPCIDeviceFree(pci);
break; break;
} }
@ -1326,7 +1327,7 @@ virSecuritySELinuxSetSecurityHostdevLabel(virSecurityManagerPtr mgr ATTRIBUTE_UN
static int static int
virSecuritySELinuxRestoreSecurityPCILabel(pciDevice *dev ATTRIBUTE_UNUSED, virSecuritySELinuxRestoreSecurityPCILabel(virPCIDevicePtr dev ATTRIBUTE_UNUSED,
const char *file, const char *file,
void *opaque) void *opaque)
{ {
@ -1374,16 +1375,17 @@ virSecuritySELinuxRestoreSecurityHostdevSubsysLabel(virSecurityManagerPtr mgr,
} }
case VIR_DOMAIN_HOSTDEV_SUBSYS_TYPE_PCI: { case VIR_DOMAIN_HOSTDEV_SUBSYS_TYPE_PCI: {
pciDevice *pci = pciGetDevice(dev->source.subsys.u.pci.domain, virPCIDevicePtr pci =
dev->source.subsys.u.pci.bus, virPCIDeviceNew(dev->source.subsys.u.pci.domain,
dev->source.subsys.u.pci.slot, dev->source.subsys.u.pci.bus,
dev->source.subsys.u.pci.function); dev->source.subsys.u.pci.slot,
dev->source.subsys.u.pci.function);
if (!pci) if (!pci)
goto done; goto done;
ret = pciDeviceFileIterate(pci, virSecuritySELinuxRestoreSecurityPCILabel, mgr); ret = virPCIDeviceFileIterate(pci, virSecuritySELinuxRestoreSecurityPCILabel, mgr);
pciFreeDevice(pci); virPCIDeviceFree(pci);
break; break;
} }

View File

@ -853,8 +853,8 @@ file_iterate_hostdev_cb(usbDevice *dev ATTRIBUTE_UNUSED,
} }
static int static int
file_iterate_pci_cb(pciDevice *dev ATTRIBUTE_UNUSED, file_iterate_pci_cb(virPCIDevicePtr dev ATTRIBUTE_UNUSED,
const char *file, void *opaque) const char *file, void *opaque)
{ {
virBufferPtr buf = opaque; virBufferPtr buf = opaque;
return vah_add_file(buf, file, "rw"); return vah_add_file(buf, file, "rw");
@ -1022,7 +1022,7 @@ get_files(vahControl * ctl)
} }
case VIR_DOMAIN_HOSTDEV_SUBSYS_TYPE_PCI: { case VIR_DOMAIN_HOSTDEV_SUBSYS_TYPE_PCI: {
pciDevice *pci = pciGetDevice( virPCIDevicePtr pci = virPCIDeviceNew(
dev->source.subsys.u.pci.domain, dev->source.subsys.u.pci.domain,
dev->source.subsys.u.pci.bus, dev->source.subsys.u.pci.bus,
dev->source.subsys.u.pci.slot, dev->source.subsys.u.pci.slot,
@ -1031,8 +1031,8 @@ get_files(vahControl * ctl)
if (pci == NULL) if (pci == NULL)
continue; continue;
rc = pciDeviceFileIterate(pci, file_iterate_pci_cb, &buf); rc = virPCIDeviceFileIterate(pci, file_iterate_pci_cb, &buf);
pciFreeDevice(pci); virPCIDeviceFree(pci);
break; break;
} }

View File

@ -980,7 +980,7 @@ virNetDevSysfsDeviceFile(char **pf_sysfs_device_link, const char *ifname,
int int
virNetDevGetVirtualFunctions(const char *pfname, virNetDevGetVirtualFunctions(const char *pfname,
char ***vfname, char ***vfname,
struct pci_config_address ***virt_fns, virPCIDeviceAddressPtr **virt_fns,
unsigned int *n_vfname) unsigned int *n_vfname)
{ {
int ret = -1, i; int ret = -1, i;
@ -991,8 +991,8 @@ virNetDevGetVirtualFunctions(const char *pfname,
if (virNetDevSysfsFile(&pf_sysfs_device_link, pfname, "device") < 0) if (virNetDevSysfsFile(&pf_sysfs_device_link, pfname, "device") < 0)
return ret; return ret;
if (pciGetVirtualFunctions(pf_sysfs_device_link, virt_fns, if (virPCIGetVirtualFunctions(pf_sysfs_device_link, virt_fns,
n_vfname) < 0) n_vfname) < 0)
goto cleanup; goto cleanup;
if (VIR_ALLOC_N(*vfname, *n_vfname) < 0) { if (VIR_ALLOC_N(*vfname, *n_vfname) < 0) {
@ -1002,22 +1002,22 @@ virNetDevGetVirtualFunctions(const char *pfname,
for (i = 0; i < *n_vfname; i++) for (i = 0; i < *n_vfname; i++)
{ {
if (pciGetDeviceAddrString((*virt_fns)[i]->domain, if (virPCIGetAddrString((*virt_fns)[i]->domain,
(*virt_fns)[i]->bus, (*virt_fns)[i]->bus,
(*virt_fns)[i]->slot, (*virt_fns)[i]->slot,
(*virt_fns)[i]->function, (*virt_fns)[i]->function,
&pciConfigAddr) < 0) { &pciConfigAddr) < 0) {
virReportSystemError(ENOSYS, "%s", virReportSystemError(ENOSYS, "%s",
_("Failed to get PCI Config Address String")); _("Failed to get PCI Config Address String"));
goto cleanup; goto cleanup;
} }
if (pciSysfsFile(pciConfigAddr, &pci_sysfs_device_link) < 0) { if (virPCIGetSysfsFile(pciConfigAddr, &pci_sysfs_device_link) < 0) {
virReportSystemError(ENOSYS, "%s", virReportSystemError(ENOSYS, "%s",
_("Failed to get PCI SYSFS file")); _("Failed to get PCI SYSFS file"));
goto cleanup; goto cleanup;
} }
if (pciDeviceNetName(pci_sysfs_device_link, &((*vfname)[i])) < 0) { if (virPCIGetNetName(pci_sysfs_device_link, &((*vfname)[i])) < 0) {
VIR_INFO("VF does not have an interface name"); VIR_INFO("VF does not have an interface name");
} }
} }
@ -1053,7 +1053,7 @@ virNetDevIsVirtualFunction(const char *ifname)
if (virNetDevSysfsFile(&if_sysfs_device_link, ifname, "device") < 0) if (virNetDevSysfsFile(&if_sysfs_device_link, ifname, "device") < 0)
return ret; return ret;
ret = pciDeviceIsVirtualFunction(if_sysfs_device_link); ret = virPCIIsVirtualFunction(if_sysfs_device_link);
VIR_FREE(if_sysfs_device_link); VIR_FREE(if_sysfs_device_link);
@ -1086,9 +1086,9 @@ virNetDevGetVirtualFunctionIndex(const char *pfname, const char *vfname,
return ret; return ret;
} }
ret = pciGetVirtualFunctionIndex(pf_sysfs_device_link, ret = virPCIGetVirtualFunctionIndex(pf_sysfs_device_link,
vf_sysfs_device_link, vf_sysfs_device_link,
vf_index); vf_index);
VIR_FREE(pf_sysfs_device_link); VIR_FREE(pf_sysfs_device_link);
VIR_FREE(vf_sysfs_device_link); VIR_FREE(vf_sysfs_device_link);
@ -1115,7 +1115,7 @@ virNetDevGetPhysicalFunction(const char *ifname, char **pfname)
if (virNetDevSysfsDeviceFile(&physfn_sysfs_path, ifname, "physfn") < 0) if (virNetDevSysfsDeviceFile(&physfn_sysfs_path, ifname, "physfn") < 0)
return ret; return ret;
ret = pciDeviceNetName(physfn_sysfs_path, pfname); ret = virPCIGetNetName(physfn_sysfs_path, pfname);
VIR_FREE(physfn_sysfs_path); VIR_FREE(physfn_sysfs_path);
@ -1149,7 +1149,7 @@ virNetDevGetVirtualFunctionInfo(const char *vfname, char **pfname,
if (virNetDevSysfsFile(&vf_sysfs_path, vfname, "device") < 0) if (virNetDevSysfsFile(&vf_sysfs_path, vfname, "device") < 0)
goto cleanup; goto cleanup;
ret = pciGetVirtualFunctionIndex(pf_sysfs_path, vf_sysfs_path, vf); ret = virPCIGetVirtualFunctionIndex(pf_sysfs_path, vf_sysfs_path, vf);
cleanup: cleanup:
if (ret < 0) if (ret < 0)
@ -1165,7 +1165,7 @@ cleanup:
int int
virNetDevGetVirtualFunctions(const char *pfname ATTRIBUTE_UNUSED, virNetDevGetVirtualFunctions(const char *pfname ATTRIBUTE_UNUSED,
char ***vfname ATTRIBUTE_UNUSED, char ***vfname ATTRIBUTE_UNUSED,
struct pci_config_address ***virt_fns ATTRIBUTE_UNUSED, virPCIDeviceAddressPtr **virt_fns ATTRIBUTE_UNUSED,
unsigned int *n_vfname ATTRIBUTE_UNUSED) unsigned int *n_vfname ATTRIBUTE_UNUSED)
{ {
virReportSystemError(ENOSYS, "%s", virReportSystemError(ENOSYS, "%s",

View File

@ -104,7 +104,7 @@ int virNetDevGetPhysicalFunction(const char *ifname, char **pfname)
int virNetDevGetVirtualFunctions(const char *pfname, int virNetDevGetVirtualFunctions(const char *pfname,
char ***vfname, char ***vfname,
struct pci_config_address ***virt_fns, virPCIDeviceAddressPtr **virt_fns,
unsigned int *n_vfname) unsigned int *n_vfname)
ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2) ATTRIBUTE_NONNULL(3) ATTRIBUTE_NONNULL(1) ATTRIBUTE_NONNULL(2) ATTRIBUTE_NONNULL(3)
ATTRIBUTE_NONNULL(4) ATTRIBUTE_RETURN_CHECK; ATTRIBUTE_NONNULL(4) ATTRIBUTE_RETURN_CHECK;

File diff suppressed because it is too large Load Diff

View File

@ -26,67 +26,74 @@
# include "internal.h" # include "internal.h"
typedef struct _pciDevice pciDevice; typedef struct _virPCIDevice virPCIDevice;
typedef struct _pciDeviceList pciDeviceList; typedef virPCIDevice *virPCIDevicePtr;
typedef struct _virPCIDeviceAddress virPCIDeviceAddress;
typedef virPCIDeviceAddress *virPCIDeviceAddressPtr;
typedef struct _virPCIDeviceList virPCIDeviceList;
typedef virPCIDeviceList *virPCIDeviceListPtr;
struct pci_config_address { struct _virPCIDeviceAddress {
unsigned int domain; unsigned int domain;
unsigned int bus; unsigned int bus;
unsigned int slot; unsigned int slot;
unsigned int function; unsigned int function;
}; };
pciDevice *pciGetDevice (unsigned domain, virPCIDevicePtr virPCIDeviceNew(unsigned domain,
unsigned bus, unsigned bus,
unsigned slot, unsigned slot,
unsigned function); unsigned function);
void pciFreeDevice (pciDevice *dev); void virPCIDeviceFree(virPCIDevicePtr dev);
const char *pciDeviceGetName (pciDevice *dev); const char *virPCIDeviceGetName(virPCIDevicePtr dev);
int pciDettachDevice (pciDevice *dev,
pciDeviceList *activeDevs,
pciDeviceList *inactiveDevs,
const char *driver);
int pciReAttachDevice (pciDevice *dev,
pciDeviceList *activeDevs,
pciDeviceList *inactiveDevs,
const char *driver);
int pciResetDevice (pciDevice *dev,
pciDeviceList *activeDevs,
pciDeviceList *inactiveDevs);
void pciDeviceSetManaged(pciDevice *dev,
unsigned managed);
unsigned pciDeviceGetManaged(pciDevice *dev);
void pciDeviceSetUsedBy(pciDevice *dev,
const char *used_by);
const char *pciDeviceGetUsedBy(pciDevice *dev);
unsigned pciDeviceGetUnbindFromStub(pciDevice *dev);
void pciDeviceSetUnbindFromStub(pciDevice *dev,
unsigned unbind);
unsigned pciDeviceGetRemoveSlot(pciDevice *dev);
void pciDeviceSetRemoveSlot(pciDevice *dev,
unsigned remove_slot);
unsigned pciDeviceGetReprobe(pciDevice *dev);
void pciDeviceSetReprobe(pciDevice *dev,
unsigned reprobe);
void pciDeviceReAttachInit(pciDevice *dev);
pciDeviceList *pciDeviceListNew (void); int virPCIDeviceDetach(virPCIDevicePtr dev,
void pciDeviceListFree (pciDeviceList *list); virPCIDeviceListPtr activeDevs,
int pciDeviceListAdd (pciDeviceList *list, virPCIDeviceListPtr inactiveDevs,
pciDevice *dev); const char *driver);
pciDevice * pciDeviceListGet (pciDeviceList *list, int virPCIDeviceReattach(virPCIDevicePtr dev,
int idx); virPCIDeviceListPtr activeDevs,
int pciDeviceListCount (pciDeviceList *list); virPCIDeviceListPtr inactiveDevs,
pciDevice * pciDeviceListSteal (pciDeviceList *list, const char *driver);
pciDevice *dev); int virPCIDeviceReset(virPCIDevicePtr dev,
pciDevice * pciDeviceListStealIndex(pciDeviceList *list, virPCIDeviceListPtr activeDevs,
int idx); virPCIDeviceListPtr inactiveDevs);
void pciDeviceListDel (pciDeviceList *list,
pciDevice *dev); void virPCIDeviceSetManaged(virPCIDevice *dev,
pciDevice * pciDeviceListFind (pciDeviceList *list, unsigned managed);
pciDevice *dev); unsigned virPCIDeviceGetManaged(virPCIDevice *dev);
int pciDeviceListFindIndex(pciDeviceList *list, void virPCIDeviceSetUsedBy(virPCIDevice *dev,
pciDevice *dev); const char *used_by);
const char *virPCIDeviceGetUsedBy(virPCIDevice *dev);
unsigned virPCIDeviceGetUnbindFromStub(virPCIDevicePtr dev);
void virPCIDeviceSetUnbindFromStub(virPCIDevice *dev,
unsigned unbind);
unsigned virPCIDeviceGetRemoveSlot(virPCIDevicePtr dev);
void virPCIDeviceSetRemoveSlot(virPCIDevice *dev,
unsigned remove_slot);
unsigned virPCIDeviceGetReprobe(virPCIDevicePtr dev);
void virPCIDeviceSetReprobe(virPCIDevice *dev,
unsigned reprobe);
void virPCIDeviceReattachInit(virPCIDevice *dev);
virPCIDeviceListPtr virPCIDeviceListNew(void);
void virPCIDeviceListFree(virPCIDeviceListPtr list);
int virPCIDeviceListAdd(virPCIDeviceListPtr list,
virPCIDevicePtr dev);
virPCIDevicePtr virPCIDeviceListGet(virPCIDeviceListPtr list,
int idx);
int virPCIDeviceListCount(virPCIDeviceListPtr list);
virPCIDevicePtr virPCIDeviceListSteal(virPCIDeviceListPtr list,
virPCIDevicePtr dev);
virPCIDevicePtr virPCIDeviceListStealIndex(virPCIDeviceListPtr list,
int idx);
void virPCIDeviceListDel(virPCIDeviceListPtr list,
virPCIDevicePtr dev);
virPCIDevicePtr virPCIDeviceListFind(virPCIDeviceListPtr list,
virPCIDevicePtr dev);
int virPCIDeviceListFindIndex(virPCIDeviceListPtr list,
virPCIDevicePtr dev);
/* /*
* Callback that will be invoked once for each file * Callback that will be invoked once for each file
@ -95,46 +102,47 @@ int pciDeviceListFindIndex(pciDeviceList *list,
* Should return 0 if successfully processed, or * Should return 0 if successfully processed, or
* -1 to indicate error and abort iteration * -1 to indicate error and abort iteration
*/ */
typedef int (*pciDeviceFileActor)(pciDevice *dev, typedef int (*virPCIDeviceFileActor)(virPCIDevicePtr dev,
const char *path, void *opaque); const char *path, void *opaque);
int pciDeviceFileIterate(pciDevice *dev, int virPCIDeviceFileIterate(virPCIDevicePtr dev,
pciDeviceFileActor actor, virPCIDeviceFileActor actor,
void *opaque); void *opaque);
int pciDeviceIsAssignable(pciDevice *dev, int virPCIDeviceIsAssignable(virPCIDevicePtr dev,
int strict_acs_check); int strict_acs_check);
int pciWaitForDeviceCleanup(pciDevice *dev, const char *matcher); int virPCIDeviceWaitForCleanup(virPCIDevicePtr dev, const char *matcher);
int pciGetPhysicalFunction(const char *sysfs_path, int virPCIGetPhysicalFunction(const char *sysfs_path,
struct pci_config_address **phys_fn); virPCIDeviceAddressPtr *phys_fn);
int pciGetVirtualFunctions(const char *sysfs_path, int virPCIGetVirtualFunctions(const char *sysfs_path,
struct pci_config_address ***virtual_functions, virPCIDeviceAddressPtr **virtual_functions,
unsigned int *num_virtual_functions); unsigned int *num_virtual_functions);
int pciDeviceIsVirtualFunction(const char *vf_sysfs_device_link); int virPCIIsVirtualFunction(const char *vf_sysfs_device_link);
int pciGetVirtualFunctionIndex(const char *pf_sysfs_device_link, int virPCIGetVirtualFunctionIndex(const char *pf_sysfs_device_link,
const char *vf_sysfs_device_link, const char *vf_sysfs_device_link,
int *vf_index); int *vf_index);
int pciConfigAddressToSysfsFile(struct pci_config_address *dev, int virPCIDeviceAddressGetSysfsFile(virPCIDeviceAddressPtr dev,
char **pci_sysfs_device_link); char **pci_sysfs_device_link);
int pciDeviceNetName(char *device_link_sysfs_path, char **netname); int virPCIGetNetName(char *device_link_sysfs_path, char **netname);
int pciSysfsFile(char *pciDeviceName, char **pci_sysfs_device_link) int virPCIGetSysfsFile(char *virPCIDeviceName,
char **pci_sysfs_device_link)
ATTRIBUTE_RETURN_CHECK; ATTRIBUTE_RETURN_CHECK;
int pciGetDeviceAddrString(unsigned domain, int virPCIGetAddrString(unsigned domain,
unsigned bus, unsigned bus,
unsigned slot, unsigned slot,
unsigned function, unsigned function,
char **pciConfigAddr) char **pciConfigAddr)
ATTRIBUTE_NONNULL(5) ATTRIBUTE_RETURN_CHECK; ATTRIBUTE_NONNULL(5) ATTRIBUTE_RETURN_CHECK;
int pciDeviceGetVirtualFunctionInfo(const char *vf_sysfs_device_path, int virPCIGetVirtualFunctionInfo(const char *vf_sysfs_device_path,
char **pfname, int *vf_index); char **pfname, int *vf_index);
#endif /* __VIR_PCI_H__ */ #endif /* __VIR_PCI_H__ */

View File

@ -2102,23 +2102,23 @@ out:
static int static int
xenUnifiedNodeDeviceDettach(virNodeDevicePtr dev) xenUnifiedNodeDeviceDettach(virNodeDevicePtr dev)
{ {
pciDevice *pci; virPCIDevicePtr pci;
unsigned domain, bus, slot, function; unsigned domain, bus, slot, function;
int ret = -1; int ret = -1;
if (xenUnifiedNodeDeviceGetPciInfo(dev, &domain, &bus, &slot, &function) < 0) if (xenUnifiedNodeDeviceGetPciInfo(dev, &domain, &bus, &slot, &function) < 0)
return -1; return -1;
pci = pciGetDevice(domain, bus, slot, function); pci = virPCIDeviceNew(domain, bus, slot, function);
if (!pci) if (!pci)
return -1; return -1;
if (pciDettachDevice(pci, NULL, NULL, "pciback") < 0) if (virPCIDeviceDetach(pci, NULL, NULL, "pciback") < 0)
goto out; goto out;
ret = 0; ret = 0;
out: out:
pciFreeDevice(pci); virPCIDeviceFree(pci);
return ret; return ret;
} }
@ -2183,7 +2183,7 @@ out:
static int static int
xenUnifiedNodeDeviceReAttach(virNodeDevicePtr dev) xenUnifiedNodeDeviceReAttach(virNodeDevicePtr dev)
{ {
pciDevice *pci; virPCIDevicePtr pci;
unsigned domain, bus, slot, function; unsigned domain, bus, slot, function;
int ret = -1; int ret = -1;
int domid; int domid;
@ -2191,7 +2191,7 @@ xenUnifiedNodeDeviceReAttach(virNodeDevicePtr dev)
if (xenUnifiedNodeDeviceGetPciInfo(dev, &domain, &bus, &slot, &function) < 0) if (xenUnifiedNodeDeviceGetPciInfo(dev, &domain, &bus, &slot, &function) < 0)
return -1; return -1;
pci = pciGetDevice(domain, bus, slot, function); pci = virPCIDeviceNew(domain, bus, slot, function);
if (!pci) if (!pci)
return -1; return -1;
@ -2203,35 +2203,35 @@ xenUnifiedNodeDeviceReAttach(virNodeDevicePtr dev)
goto out; goto out;
} }
if (pciReAttachDevice(pci, NULL, NULL, "pciback") < 0) if (virPCIDeviceReattach(pci, NULL, NULL, "pciback") < 0)
goto out; goto out;
ret = 0; ret = 0;
out: out:
pciFreeDevice(pci); virPCIDeviceFree(pci);
return ret; return ret;
} }
static int static int
xenUnifiedNodeDeviceReset(virNodeDevicePtr dev) xenUnifiedNodeDeviceReset(virNodeDevicePtr dev)
{ {
pciDevice *pci; virPCIDevicePtr pci;
unsigned domain, bus, slot, function; unsigned domain, bus, slot, function;
int ret = -1; int ret = -1;
if (xenUnifiedNodeDeviceGetPciInfo(dev, &domain, &bus, &slot, &function) < 0) if (xenUnifiedNodeDeviceGetPciInfo(dev, &domain, &bus, &slot, &function) < 0)
return -1; return -1;
pci = pciGetDevice(domain, bus, slot, function); pci = virPCIDeviceNew(domain, bus, slot, function);
if (!pci) if (!pci)
return -1; return -1;
if (pciResetDevice(pci, NULL, NULL) < 0) if (virPCIDeviceReset(pci, NULL, NULL) < 0)
goto out; goto out;
ret = 0; ret = 0;
out: out:
pciFreeDevice(pci); virPCIDeviceFree(pci);
return ret; return ret;
} }