Takashi Iwai 2646bc
From 83ac7a1c2ed5f17caa07cbbc84bad3c05dc3bf22 Mon Sep 17 00:00:00 2001
Takashi Iwai 2646bc
From: Hans de Goede <hdegoede@redhat.com>
Takashi Iwai 2646bc
Date: Thu, 25 Aug 2022 16:13:34 +0200
Takashi Iwai 2646bc
Subject: [PATCH] platform/x86: msi-laptop: Fix old-ec check for backlight registering
Takashi Iwai 2646bc
Git-commit: 83ac7a1c2ed5f17caa07cbbc84bad3c05dc3bf22
Takashi Iwai 2646bc
Patch-mainline: v6.1-rc1
Takashi Iwai 2646bc
References: git-fixes
Takashi Iwai 2646bc
Takashi Iwai 2646bc
Commit 2cc6c717799f ("msi-laptop: Port to new backlight interface
Takashi Iwai 2646bc
selection API") replaced this check:
Takashi Iwai 2646bc
Takashi Iwai 2646bc
	if (!quirks->old_ec_model || acpi_video_backlight_support())
Takashi Iwai 2646bc
		pr_info("Brightness ignored, ...");
Takashi Iwai 2646bc
	else
Takashi Iwai 2646bc
		do_register();
Takashi Iwai 2646bc
Takashi Iwai 2646bc
With: 
Takashi Iwai 2646bc
Takashi Iwai 2646bc
	if (quirks->old_ec_model ||
Takashi Iwai 2646bc
	    acpi_video_get_backlight_type() == acpi_backlight_vendor)
Takashi Iwai 2646bc
		do_register();
Takashi Iwai 2646bc
Takashi Iwai 2646bc
But since the do_register() part was part of the else branch, the entire
Takashi Iwai 2646bc
condition should be inverted.  So not only the 2 statements on either
Takashi Iwai 2646bc
side of the || should be inverted, but the || itself should be replaced
Takashi Iwai 2646bc
with a &&.
Takashi Iwai 2646bc
Takashi Iwai 2646bc
In practice this has likely not been an issue because the new-ec models
Takashi Iwai 2646bc
(old_ec_model==false) likely all support ACPI video backlight control,
Takashi Iwai 2646bc
making acpi_video_get_backlight_type() return acpi_backlight_video
Takashi Iwai 2646bc
turning the second part of the || also false when old_ec_model == false.
Takashi Iwai 2646bc
Takashi Iwai 2646bc
Fixes: 2cc6c717799f ("msi-laptop: Port to new backlight interface selection API")
Takashi Iwai 2646bc
Signed-off-by: Hans de Goede <hdegoede@redhat.com>
Takashi Iwai 2646bc
Link: https://lore.kernel.org/r/20220825141336.208597-1-hdegoede@redhat.com
Takashi Iwai 2646bc
Acked-by: Takashi Iwai <tiwai@suse.de>
Takashi Iwai 2646bc
Takashi Iwai 2646bc
---
Takashi Iwai 2646bc
 drivers/platform/x86/msi-laptop.c | 3 +--
Takashi Iwai 2646bc
 1 file changed, 1 insertion(+), 2 deletions(-)
Takashi Iwai 2646bc
Takashi Iwai 2646bc
diff --git a/drivers/platform/x86/msi-laptop.c b/drivers/platform/x86/msi-laptop.c
Takashi Iwai 2646bc
index 93ef8851b93e..54170172a666 100644
Takashi Iwai 2646bc
--- a/drivers/platform/x86/msi-laptop.c
Takashi Iwai 2646bc
+++ b/drivers/platform/x86/msi-laptop.c
Takashi Iwai 2646bc
@@ -1047,8 +1047,7 @@ static int __init msi_init(void)
Takashi Iwai 2646bc
 		return -EINVAL;
Takashi Iwai 2646bc
 
Takashi Iwai 2646bc
 	/* Register backlight stuff */
Takashi Iwai 2646bc
-
Takashi Iwai 2646bc
-	if (quirks->old_ec_model ||
Takashi Iwai 2646bc
+	if (quirks->old_ec_model &&
Takashi Iwai 2646bc
 	    acpi_video_get_backlight_type() == acpi_backlight_vendor) {
Takashi Iwai 2646bc
 		struct backlight_properties props;
Takashi Iwai 2646bc
 		memset(&props, 0, sizeof(struct backlight_properties));
Takashi Iwai 2646bc
-- 
Takashi Iwai 2646bc
2.35.3
Takashi Iwai 2646bc