[PATCH RESEND 05/20] virpci: introduce virPCIDeviceExists()
Laine Stump
laine at redhat.com
Thu Jan 21 01:22:56 UTC 2021
On 1/18/21 2:53 PM, Daniel Henrique Barboza wrote:
> We're going to add logic to handle the case where a previously
> existing PCI device does not longer exist in the host.
>
> The logic was copied from virPCIDeviceNew(), which verifies if a
> PCI device exists in the host, returning NULL and throwing an
> error if it doesn't. The NULL is used for other errors as well
> (product/vendor id read errors, dev id overflow), meaning that we
> can't re-use virPCIDeviceNew() for the purpose of detecting
> if the device exists.
>
> Signed-off-by: Daniel Henrique Barboza <danielhb413 at gmail.com>
> ---
> src/libvirt_private.syms | 1 +
> src/util/virpci.c | 10 ++++++++++
> src/util/virpci.h | 1 +
> 3 files changed, 12 insertions(+)
>
> diff --git a/src/libvirt_private.syms b/src/libvirt_private.syms
> index 55284577b0..36635e6de7 100644
> --- a/src/libvirt_private.syms
> +++ b/src/libvirt_private.syms
> @@ -2819,6 +2819,7 @@ virPCIDeviceAddressIsValid;
> virPCIDeviceAddressParse;
> virPCIDeviceCopy;
> virPCIDeviceDetach;
> +virPCIDeviceExists;
> virPCIDeviceFileIterate;
> virPCIDeviceFree;
> virPCIDeviceGetAddress;
> diff --git a/src/util/virpci.c b/src/util/virpci.c
> index 5a91553b5f..7143380348 100644
> --- a/src/util/virpci.c
> +++ b/src/util/virpci.c
> @@ -1448,6 +1448,16 @@ virPCIDeviceAddressAsString(const virPCIDeviceAddress *addr)
> return str;
> }
>
> +bool
> +virPCIDeviceExists(const virPCIDeviceAddress *addr)
> +{
> + g_autofree char *devName = virPCIDeviceAddressAsString(addr);
> + g_autofree char *devPath = g_strdup_printf(PCI_SYSFS "devices/%s/config",
> + devName);
This same string is used at the top of virPCIDeviceNew(). Might be good
to have a short (static) utility function virPCIDeviceConfigFileName()
function.
But, as with most of my comments, that's for later.
Reviewed-by: Laine Stump <laine at redhat.com>
> +
> + return virFileExists(devPath);
> +}
> +
> virPCIDevicePtr
> virPCIDeviceNew(const virPCIDeviceAddress *address)
> {
> diff --git a/src/util/virpci.h b/src/util/virpci.h
> index d4451848c1..a9c597a428 100644
> --- a/src/util/virpci.h
> +++ b/src/util/virpci.h
> @@ -201,6 +201,7 @@ int virPCIDeviceAddressGetIOMMUGroupAddresses(virPCIDeviceAddressPtr devAddr,
> size_t *nIommuGroupDevices);
> int virPCIDeviceAddressGetIOMMUGroupNum(virPCIDeviceAddressPtr addr);
> char *virPCIDeviceAddressGetIOMMUGroupDev(const virPCIDeviceAddress *devAddr);
> +bool virPCIDeviceExists(const virPCIDeviceAddress *addr);
> char *virPCIDeviceGetIOMMUGroupDev(virPCIDevicePtr dev);
>
> int virPCIDeviceIsAssignable(virPCIDevicePtr dev,
More information about the libvir-list
mailing list