Files
system76-coreboot/src/ec/lenovo/h8/acpi/thinkpad.asl
Patrick Rudolph 31fb846c59 ec/lenovo/h8/acpi: Apply state on wake
Implement ACPI S3 resume control to restore the state before entering
sleep.
* Store the requested state wake state for bluetooth and WWAN.
* Add new methods to init the state and apply the requested state on wake.
* Call the new method on all devices.

Change-Id: I13c08b8c6b1bf0f3deb25a464b26880d8469c005
Signed-off-by: Patrick Rudolph <siro@das-labor.org>
Reviewed-on: https://review.coreboot.org/22377
Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
Reviewed-by: Felix Held <felix-coreboot@felixheld.de>
2018-07-19 16:49:18 +00:00

327 lines
5.5 KiB
Plaintext

/*
* This file is part of the coreboot project.
*
* Copyright (c) 2011 Sven Schnelle <svens@stackframe.org>
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License as
* published by the Free Software Foundation; version 2 of
* the License.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*/
Device (HKEY)
{
/* Generated by ssdt.c */
External (\HBDC, IntObj)
External (\HWAN, IntObj)
External (\HKBL, IntObj)
External (\HUWB, IntObj)
Name (_HID, EisaId ("IBM0068"))
Name (BTN, 0)
Name (BTAB, 0)
/* MASK */
Name (DHKN, 0x080C)
/* Effective Mask */
Name (EMSK, 0)
/* Effective Mask for tablet */
Name (ETAB, 0)
/* Device enabled. */
Name (EN, 0)
Method (_STA, 0, NotSerialized)
{
Return (0x0F)
}
/* Retrieve event. */
Method (MHKP, 0, NotSerialized)
{
Store (BTN, Local0)
If (LNotEqual (Local0, Zero)) {
Store (Zero, BTN)
Add (Local0, 0x1000, Local0)
Return (Local0)
}
Store (BTAB, Local0)
If (LNotEqual (Local0, Zero)) {
Store (Zero, BTAB)
Add (Local0, 0x5000, Local0)
Return (Local0)
}
Return (Zero)
}
/* Report event */
Method (RHK, 1, NotSerialized) {
ShiftLeft (One, Subtract (Arg0, 1), Local0)
If (And (EMSK, Local0)) {
Store (Arg0, BTN)
Notify (HKEY, 0x80)
}
}
/* Report tablet */
Method (RTAB, 1, NotSerialized) {
ShiftLeft (One, Subtract (Arg0, 1), Local0)
If (And (ETAB, Local0)) {
Store (Arg0, BTAB)
Notify (HKEY, 0x80)
}
}
/* Enable/disable all events. */
Method (MHKC, 1, NotSerialized) {
If (Arg0) {
Store (DHKN, EMSK)
Store (Ones, ETAB)
}
Else
{
Store (Zero, EMSK)
Store (Zero, ETAB)
}
Store (Arg0, EN)
}
/* Enable/disable event. */
Method (MHKM, 2, NotSerialized) {
If (LLessEqual (Arg0, 0x20)) {
ShiftLeft (One, Subtract (Arg0, 1), Local0)
If (Arg1)
{
Or (DHKN, Local0, DHKN)
}
Else
{
And (DHKN, Not (Local0), DHKN)
}
If (EN)
{
Store (DHKN, EMSK)
}
}
}
/* Mask hotkey all. */
Method (MHKA, 0, NotSerialized)
{
Return (0x07FFFFFF)
}
/* Report tablet mode switch state */
Method (MHKG, 0, NotSerialized)
{
Return (ShiftLeft(TBSW, 3))
}
/* Mute audio */
Method (SSMS, 1, NotSerialized)
{
Store(Arg0, ALMT)
}
/* Control mute microphone LED */
Method (MMTS, 1, NotSerialized)
{
If (Arg0)
{
TLED(0x8E)
}
Else
{
TLED(0x0E)
}
}
/* Version */
Method (MHKV, 0, NotSerialized)
{
Return (0x0100)
}
/* Master wireless switch state */
Method (WLSW, 0, NotSerialized)
{
Return (\_SB.PCI0.LPCB.EC.GSTS)
}
/* Has thinkpad_acpi module loaded */
Name (HAST, 0)
/* State after sleep */
Name (WBDC, 0)
/*
* Returns the current state:
* Bit 0: BT HW present
* Bit 1: BT radio enabled
* Bit 2: BT state at resume
*/
Method (GBDC, 0)
{
Store (One, HAST)
If (HBDC) {
Store(One, Local0)
If(\_SB.PCI0.LPCB.EC.BTEB)
{
Or(Local0, 2, Local0)
}
Or(Local0, ShiftLeft(WBDC, 2), Local0)
Return (Local0)
} Else {
Return (0)
}
}
/*
* Set the current state:
* Bit 1: BT radio enabled
* Bit 2: BT state at resume
*/
Method (SBDC, 1)
{
Store (One, HAST)
If (HBDC) {
ShiftRight (And(Arg0, 2), 1, Local0)
Store (Local0, \_SB.PCI0.LPCB.EC.BTEB)
ShiftRight (And(Arg0, 4), 2, Local0)
Store (Local0, WBDC)
}
}
/* State after sleep */
Name (WWAN, 0)
/*
* Returns the current state:
* Bit 0: WWAN HW present
* Bit 1: WWAN radio enabled
* Bit 2: WWAN state at resume
*/
Method (GWAN, 0)
{
Store (One, HAST)
If (HWAN) {
Store(One, Local0)
If(\_SB.PCI0.LPCB.EC.WWEB)
{
Or(Local0, 2, Local0)
}
Or(Local0, ShiftLeft(WWAN, 2), Local0)
Return (Local0)
} Else {
Return (0)
}
}
/*
* Set the current state:
* Bit 1: WWAN radio enabled
* Bit 2: WWAN state at resume
*/
Method (SWAN, 1)
{
Store (One, HAST)
If (HWAN) {
ShiftRight (And(Arg0, 2), 1, Local0)
Store (Local0, \_SB.PCI0.LPCB.EC.WWEB)
ShiftRight (And(Arg0, 4), 2, WWAN)
}
}
/*
* 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)
}
}
/*
* Returns the current state:
* Bit 0: UWB HW present
* Bit 1: UWB radio enabled
*/
Method (GUWB, 0)
{
If (HUWB) {
Store (One, Local0)
If(\_SB.PCI0.LPCB.EC.UWBE)
{
Or(Local0, 2, Local0)
}
Return (Local0)
} Else {
Return (0)
}
}
/*
* Set the current state:
* Bit 1: UWB radio enabled
*/
Method (SUWB, 1)
{
If (HUWB) {
ShiftRight (And(Arg0, 2), 1, Local0)
Store (Local0, \_SB.PCI0.LPCB.EC.UWBE)
}
}
/*
* Store initial state
*/
Method (_INI, 0, NotSerialized)
{
Store (\_SB.PCI0.LPCB.EC.BTEB, WBDC)
Store (\_SB.PCI0.LPCB.EC.WWEB, WWAN)
}
/*
* Called from _WAK
*/
Method (WAKE, 1)
{
If (HAST) {
Store (WBDC, \_SB.PCI0.LPCB.EC.BTEB)
Store (WWAN, \_SB.PCI0.LPCB.EC.WWEB)
}
}
}