(Cc: Jason)

On Tue Mar 24, 2026 at 1:59 AM CET, Danilo Krummrich wrote:
> diff --git a/drivers/vfio/pci/vfio_pci_core.c 
> b/drivers/vfio/pci/vfio_pci_core.c
> index d43745fe4c84..460852f79f29 100644
> --- a/drivers/vfio/pci/vfio_pci_core.c
> +++ b/drivers/vfio/pci/vfio_pci_core.c
> @@ -1987,9 +1987,8 @@ static int vfio_pci_bus_notifier(struct notifier_block 
> *nb,
>           pdev->is_virtfn && physfn == vdev->pdev) {
>               pci_info(vdev->pdev, "Captured SR-IOV VF %s driver_override\n",
>                        pci_name(pdev));
> -             pdev->driver_override = kasprintf(GFP_KERNEL, "%s",
> -                                               vdev->vdev.ops->name);
> -             WARN_ON(!pdev->driver_override);
> +             WARN_ON(device_set_driver_override(&pdev->dev,
> +                                                vdev->vdev.ops->name));

Technically, this is a change in behavior. If vdev->vdev.ops->name is NULL, it
will trigger the WARN_ON(), whereas before it would have just written "(null)"
into driver_override.

I assume that vfio_pci_core drivers are expected to set the name in struct
vfio_device_ops in the first place and this code (silently) relies on this
invariant?

Alex, Jason: Should we keep this hunk above as is and check for a proper name in
struct vfio_device_ops in vfio_pci_core_register_device() with a subsequent
patch?

>       } else if (action == BUS_NOTIFY_BOUND_DRIVER &&
>                  pdev->is_virtfn && physfn == vdev->pdev) {
>               struct pci_driver *drv = pci_dev_driver(pdev);

Reply via email to