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

Commit c04c697c authored by Matthew Garrett's avatar Matthew Garrett Committed by Rafael J. Wysocki
Browse files

ACPI / video: Always call acpi_video_init_brightness() on init



We have to call acpi_video_init_brightness() even if we're not going
to initialise the backlight - Thinkpads seem to use this as the
trigger for enabling ACPI notifications rather than handling it in
firmware.

[rjw: Drop the brightness object created by
 acpi_video_init_brightness() if we are not going to use it.]
Signed-off-by: default avatarMatthew Garrett <matthew.garrett@nebula.com>
Signed-off-by: default avatarRafael J. Wysocki <rafael.j.wysocki@intel.com>
parent 242b2287
Loading
Loading
Loading
Loading
+8 −3
Original line number Diff line number Diff line
@@ -898,6 +898,9 @@ static void acpi_video_device_find_cap(struct acpi_video_device *device)
		device->cap._DDC = 1;
	}

	if (acpi_video_init_brightness(device))
		return;

	if (acpi_video_backlight_support()) {
		struct backlight_properties props;
		struct pci_dev *pdev;
@@ -907,9 +910,6 @@ static void acpi_video_device_find_cap(struct acpi_video_device *device)
		static int count = 0;
		char *name;

		result = acpi_video_init_brightness(device);
		if (result)
			return;
		name = kasprintf(GFP_KERNEL, "acpi_video%d", count);
		if (!name)
			return;
@@ -969,6 +969,11 @@ static void acpi_video_device_find_cap(struct acpi_video_device *device)
		if (result)
			printk(KERN_ERR PREFIX "Create sysfs link\n");

	} else {
		/* Remove the brightness object. */
		kfree(device->brightness->levels);
		kfree(device->brightness);
		device->brightness = NULL;
	}
}