Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 0119509c authored by Matthew Garrett's avatar Matthew Garrett Committed by Len Brown
Browse files

ACPI: video: Ignore devices that aren't present in hardware

Vendors often ship machines with a choice of integrated or discrete
graphics, and use the same DSDT for both. As a result, the ACPI video
module will locate devices that may not exist on this specific platform.
Attempt to determine whether the device exists or not, and abort the
device creation if it doesn't.

http://bugzilla.kernel.org/show_bug.cgi?id=9614



Signed-off-by: default avatarMatthew Garrett <mjg59@srcf.ucam.org>
Acked-by: default avatarZhang Rui <rui.zhang@intel.com>
Signed-off-by: default avatarLen Brown <len.brown@intel.com>
parent aa629992
Loading
Loading
Loading
Loading
+29 −0
Original line number Diff line number Diff line
@@ -1256,8 +1256,37 @@ acpi_video_bus_write_DOS(struct file *file,

static int acpi_video_bus_add_fs(struct acpi_device *device)
{
	long device_id;
	int status;
	struct proc_dir_entry *entry = NULL;
	struct acpi_video_bus *video;
	struct device *dev;

	status =
	    acpi_evaluate_integer(device->handle, "_ADR", NULL, &device_id);

	if (!ACPI_SUCCESS(status))
		return -ENODEV;

	/* We need to attempt to determine whether the _ADR refers to a
	   PCI device or not. There's no terribly good way to do this,
	   so the best we can hope for is to assume that there'll never
	   be a video device in the host bridge */
	if (device_id >= 0x10000) {
		/* It looks like a PCI device. Does it exist? */
		dev = acpi_get_physical_device(device->handle);
	} else {
		/* It doesn't look like a PCI device. Does its parent
		   exist? */
		acpi_handle phandle;
		if (acpi_get_parent(device->handle, &phandle))
			return -ENODEV;
		dev = acpi_get_physical_device(phandle);
	}
	if (!dev)
		return -ENODEV;
	put_device(dev);



	video = acpi_driver_data(device);