@@ -111,9 +111,11 @@ static int vfio_pci_open_device(struct vfio_device *core_vdev)
if (ret)
return ret;
- if (vfio_pci_is_vga(pdev) &&
- pdev->vendor == PCI_VENDOR_ID_INTEL &&
- IS_ENABLED(CONFIG_VFIO_PCI_IGD)) {
+ if (IS_ENABLED(CONFIG_VFIO_PCI_IGD) &&
+ (pdev->vendor == PCI_VENDOR_ID_INTEL) &&
+ (((pdev->class >> 8) == PCI_CLASS_DISPLAY_VGA) ||
+ ((pdev->class >> 8) == PCI_CLASS_DISPLAY_OTHER)) &&
+ (pci_dev_id(pdev) == PCI_DEVID(0, PCI_DEVFN(2, 0)))) {
ret = vfio_pci_igd_init(vdev);
if (ret && ret != -ENODEV) {
pci_warn(pdev, "Failed to setup Intel IGD regions\n");
igd device can either expose as a VGA controller or display controller depending on whether it is configured as the primary display device in BIOS. In both cases, the OpRegion may be present. Also checks if the device is at bdf 00:02.0 to avoid setting up igd-specific regions on Intel discrete GPUs. Signed-off-by: Tomita Moeko <tomitamoeko@gmail.com> --- Changelog: v2: Fix misuse of pci_get_domain_bus_and_slot(), now only compares bdf without touching device reference count. Link: https://lore.kernel.org/all/20241229155140.7434-1-tomitamoeko@gmail.com/ drivers/vfio/pci/vfio_pci.c | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-)