aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/ec/lenovo/h8/acpi/thinkpad.asl31
-rw-r--r--src/ec/lenovo/h8/ssdt.c4
2 files changed, 35 insertions, 0 deletions
diff --git a/src/ec/lenovo/h8/acpi/thinkpad.asl b/src/ec/lenovo/h8/acpi/thinkpad.asl
index d0e4234ed9..a0812e5d48 100644
--- a/src/ec/lenovo/h8/acpi/thinkpad.asl
+++ b/src/ec/lenovo/h8/acpi/thinkpad.asl
@@ -19,6 +19,7 @@ Device (HKEY)
/* Generated by ssdt.c */
External (\HBDC, IntObj)
External (\HWAN, IntObj)
+ External (\HKBL, IntObj)
Name (_HID, EisaId ("IBM0068"))
@@ -228,4 +229,34 @@ Device (HKEY)
/* FIXME: Store state at resume */
}
}
+
+ /*
+ * Argument is unused.
+ * Returns the current state:
+ * Bit 9: Backlight HW present
+ * Bit 0-1: Brightness level
+ */
+ Method (MLCG, 1)
+ {
+ If (HKBL) {
+ Store (0x200, Local0)
+ /* FIXME: Support 2bit brightness control */
+ Or (Local0, \_SB.PCI0.LPCB.EC.KBLT, Local0)
+ Return (Local0)
+ } Else {
+ Return (0)
+ }
+ }
+
+ /*
+ * Set the current state:
+ * Bit 0-1: Brightness level
+ */
+ Method (MLCS, 1)
+ {
+ If (HKBL) {
+ /* FIXME: Support 2bit brightness control */
+ Store (And(Arg0, 1), \_SB.PCI0.LPCB.EC.WWEB)
+ }
+ }
}
diff --git a/src/ec/lenovo/h8/ssdt.c b/src/ec/lenovo/h8/ssdt.c
index 84a52f5f63..4df4bd8a87 100644
--- a/src/ec/lenovo/h8/ssdt.c
+++ b/src/ec/lenovo/h8/ssdt.c
@@ -36,6 +36,8 @@ static char *h8_dsdt_scope(struct device *dev, const char *scope)
*/
void h8_ssdt_generator(struct device *dev)
{
+ struct ec_lenovo_h8_config *conf = dev->chip_info;
+
if (!acpi_device_path(dev))
return;
@@ -47,6 +49,8 @@ void h8_ssdt_generator(struct device *dev)
/* Used by thinkpad_acpi */
acpigen_write_name_byte("HBDC", h8_has_bdc(dev) ? ONE_OP : ZERO_OP);
acpigen_write_name_byte("HWAN", h8_has_wwan(dev) ? ONE_OP : ZERO_OP);
+ acpigen_write_name_byte("HKBL", (conf && conf->has_keyboard_backlight) ?
+ ONE_OP : ZERO_OP);
acpigen_pop_len(); /* Scope HKEY */
}