Need something here... Perhaps to the effect of instead of inlining most of virHostdevOnlyReattachPCIDevice, call virHostdevOnlyReattachPCIDevice. One extra "call" or check being made by doing this is the virPCIDeviceGetStubDriver check and virPCIDeviceWaitForCleanup. Are there any "timing" considerations from this path? Now for every PCI hostdev found, we'll call *WaitForCleanup. That should perhaps be noted. This looks reasonable otherwise. John On 01/25/2016 11:20 AM, Andrea Bolognani wrote: > --- > src/util/virhostdev.c | 14 +------------- > 1 file changed, 1 insertion(+), 13 deletions(-) > > diff --git a/src/util/virhostdev.c b/src/util/virhostdev.c > index 66629b4..586937e 100644 > --- a/src/util/virhostdev.c > +++ b/src/util/virhostdev.c > @@ -799,19 +799,7 @@ virHostdevPreparePCIDevices(virHostdevManagerPtr hostdev_mgr, > for (i = 0; i < virPCIDeviceListCount(pcidevs); i++) { > virPCIDevicePtr dev = virPCIDeviceListGet(pcidevs, i); > > - if (virPCIDeviceGetManaged(dev)) { > - /* NB: This doesn't actually re-bind to original driver, just > - * unbinds from the stub driver > - */ > - VIR_DEBUG("Reattaching managed PCI device %s", > - virPCIDeviceGetName(dev)); > - ignore_value(virPCIDeviceReattach(dev, > - hostdev_mgr->activePCIHostdevs, > - hostdev_mgr->inactivePCIHostdevs)); > - } else { > - VIR_DEBUG("Not reattaching unmanaged PCI device %s", > - virPCIDeviceGetName(dev)); > - } > + ignore_value(virHostdevOnlyReattachPCIDevice(hostdev_mgr, dev, true)); > } > > cleanup: > -- libvir-list mailing list libvir-list@xxxxxxxxxx https://www.redhat.com/mailman/listinfo/libvir-list