Re: [PATCH] asus-wmi: control backlight power through WMI, not ACPI

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



The patch is almost ok, I won't merge it as-is because I want a
cleaner mechanism to inform the kernel that the vendor backlight
should be prefered. If I can't do it before the end of the next merge
windows I'll merge it in the current form.

On Fri, May 18, 2012 at 10:10 AM, AceLan Kao <acelan.kao@xxxxxxxxxxxxx> wrote:
> BugLink: https://bugs.launchpad.net/bugs/1000146
>
> Some h/w that can adjust screen brightness through ACPI functions, but
> can't turn on/off the backlight power correctly. So, we list those h/w in
> quirks and try to turn on/off the backlight power through WMI.
>
> Signed-off-by: AceLan Kao <acelan.kao@xxxxxxxxxxxxx>
> ---
>  drivers/platform/x86/asus-wmi.c  |    7 +++++++
>  drivers/platform/x86/asus-wmi.h  |    1 +
>  drivers/platform/x86/eeepc-wmi.c |   23 +++++++++++++++++++++++
>  3 files changed, 31 insertions(+)
>
> diff --git a/drivers/platform/x86/asus-wmi.c b/drivers/platform/x86/asus-wmi.c
> index 77aadde..b1b8b0b 100644
> --- a/drivers/platform/x86/asus-wmi.c
> +++ b/drivers/platform/x86/asus-wmi.c
> @@ -69,6 +69,7 @@ MODULE_LICENSE("GPL");
>  #define NOTIFY_BRNDOWN_MAX             0x2e
>  #define NOTIFY_KBD_BRTUP               0xc4
>  #define NOTIFY_KBD_BRTDWN              0xc5
> +#define NOTIFY_BACKLIGHT_POWER         0xe9
>
>  /* WMI Methods */
>  #define ASUS_WMI_METHODID_SPEC         0x43455053 /* BIOS SPECification */
> @@ -1288,6 +1289,12 @@ static void asus_wmi_notify(u32 value, void *context)
>        if (code == NOTIFY_BRNUP_MIN || code == NOTIFY_BRNDOWN_MIN) {
>                if (!acpi_video_backlight_support())
>                        asus_wmi_backlight_notify(asus, orig_code);
> +       } else if (asus->driver->quirks->wmi_backlight_power &&
> +                  code == NOTIFY_BACKLIGHT_POWER) {
> +               static int backlight_power = 1;
> +               backlight_power = !backlight_power;
> +               asus_wmi_set_devstate(ASUS_WMI_DEVID_BACKLIGHT,
> +                                     backlight_power, NULL);
>        } else if (!sparse_keymap_report_event(asus->inputdev, code,
>                                               key_value, autorelease))
>                pr_info("Unknown key %x pressed\n", code);
> diff --git a/drivers/platform/x86/asus-wmi.h b/drivers/platform/x86/asus-wmi.h
> index d43b667..9c1da8b 100644
> --- a/drivers/platform/x86/asus-wmi.h
> +++ b/drivers/platform/x86/asus-wmi.h
> @@ -39,6 +39,7 @@ struct quirk_entry {
>        bool hotplug_wireless;
>        bool scalar_panel_brightness;
>        bool store_backlight_power;
> +       bool wmi_backlight_power;
>        int wapf;
>  };
>
> diff --git a/drivers/platform/x86/eeepc-wmi.c b/drivers/platform/x86/eeepc-wmi.c
> index 6567613..8d31f4e 100644
> --- a/drivers/platform/x86/eeepc-wmi.c
> +++ b/drivers/platform/x86/eeepc-wmi.c
> @@ -107,6 +107,11 @@ static struct quirk_entry quirk_asus_et2012_type3 = {
>        .store_backlight_power = true,
>  };
>
> +static struct quirk_entry quirk_asus_x101ch = {
> +       /* We need this when ACPI function doesn't do this well */
> +       .wmi_backlight_power = true,
> +};
> +
>  static struct quirk_entry *quirks;
>
>  static void et2012_quirks(void)
> @@ -157,6 +162,24 @@ static struct dmi_system_id asus_quirks[] = {
>                },
>                .driver_data = &quirk_asus_unknown,
>        },
> +       {
> +               .callback = dmi_matched,
> +               .ident = "ASUSTeK Computer INC. X101CH",
> +               .matches = {
> +                       DMI_MATCH(DMI_SYS_VENDOR, "ASUSTeK COMPUTER INC."),
> +                       DMI_MATCH(DMI_PRODUCT_NAME, "X101CH"),
> +               },
> +               .driver_data = &quirk_asus_x101ch,
> +       },
> +       {
> +               .callback = dmi_matched,
> +               .ident = "ASUSTeK Computer INC. 1015CX",
> +               .matches = {
> +                       DMI_MATCH(DMI_SYS_VENDOR, "ASUSTeK COMPUTER INC."),
> +                       DMI_MATCH(DMI_PRODUCT_NAME, "1015CX"),
> +               },
> +               .driver_data = &quirk_asus_x101ch,
> +       },
>        {},
>  };
>
> --
> 1.7.9.5
>



-- 
Corentin Chary
http://xf.iksaif.net
--
To unsubscribe from this list: send the line "unsubscribe platform-driver-x86" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html


[Index of Archives]     [Linux Kernel Development]     [Linux USB Devel]     [Video for Linux]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux