blob: cc12a2a295f618d65ab29a9e3590b67230b16781 [file] [log] [blame]
/* SPDX-License-Identifier: GPL-2.0-only */
/*
* The mainboard must define a PNOT method to handle power
* state notifications and Notify CPU device objects to
* re-evaluate their _PPC and _CST tables.
*/
External (\_SB.CP00._PPC, IntObj)
Device (EC0)
{
Name (_HID, EISAID ("PNP0C09"))
Name (_UID, 1)
Name (_GPE, EC_SCI_GPI + 16) // GPE for Runtime SCI
OperationRegion (ERAM, EmbeddedControl, 0x00, 0xff)
Field (ERAM, ByteAcc, Lock, Preserve)
{
// EC Name Space Configuration
Offset(0x40),
BDC0, 16, // Batt Design Capacity ; 40h, 41h
BDV0, 16, // Batt Design Voltage ; 42h, 43h
BFC0, 16, // Batt Last Full Charge Capacity ; 44h, 45h
BPC0, 16, // Batt Current ; 46h, 47h
BRC0, 16, // Batt Remaining Capacity ; 48h, 49h
BPV0, 16, // Batt Present Voltage ; 4Ah, 4Bh
BCG0, 16, // Batt Charge current ; 4Ch, 4Dh
BACV, 16, // Batt Charging Voltage ; 4Eh, 4Fh
BTM0, 16, // Batt Battery Temp ; 50h, 51h
BSN0, 16, // Batt Serial Number ; 52h, 53h
BPCT, 16, // Batt Percentage of full charge ; 54h, 55h
BSSB, 16, // BATT Battery Status SMB ; 56h, 57h
CYC0, 16, // Batt Cycle Counter ; 58h, 59h
BMD0, 16, // Manufacture Date ; 5Ah, 5Bh
// Batt Day ; BIT[4:0] (Day)
// Batt Month ; BIT[9:5] (Month)
// Batt Year ; BIT[15:10] (Year)
Offset(0x60),
BCHM, 32, // Battery Chemistry ; 60h - 64h
BATD, 56, // Battery Device name ; 64h - 6Ah
Offset(0x70),
ADPT, 1, // AC Adapter Status for OS ; 70h.0
ADPN, 1, // AC Adapter H/W status ; 70h.1
BTIN, 1, // Battery Present ; 70h.2
BTBD, 1, // Battery Malfunction ; 70h.3
ACMD, 1, // ACPI Mode ; 70h.4
, 1, // Reserved ; 70h.5
SSBS, 1, // 1=Standard BIOS, 0=coreboot ; 70h.6
PSTH, 1, // Passive Thermal Policy ; 70h.7
BST0, 8, // Battery Status ; 71h
// Bit0 : Discharging
// Bit1 : Charging
// Bit2 : Discharging and Critical Low
// Bit3-7 : Reserved
LIDF, 1, // Lid is open ; 72h.0
GPRC, 1, // Recovery GPI Status ; 72h.1
, 6, // Reserved ; 72h.2-7
TPLD, 1, // TouchPad LED Activation ; 73h.0
TPST, 1, // Touchpad LED Status ; 73h.1
, 6, // Reserved ; 73h.2-7
Offset(0x78),
CTMP, 8, // Current CPU Temperature ; 78h
SKTB, 8, // GPU Temperature ; 79h
LTM1, 8, // Local Temp 1 ; 7Ah
LTM2, 8, // Local Temp 2 ; 7Bh
FTCH, 16, // Fan Tachometer value ; 7Ch - 7Dh
FDBG, 16, // Fan Debug - Override Fan Tach value ; 7Eh - 7Fh
, 1, // Reserved ; 80h.0
KBID, 1, // 0=EN KBD, 1=JP KBD ; 80h.1
, 6, // Reserved ; 80h.2-7
NPST, 8, // Number of P-State level ; 81h
MPST, 8, // Maximum P-State ; 82h
KWAK, 1, // Keyboard WAKE(0=Disable,1=Enable) ; 83h.0
TWAK, 1, // TouchPad WAKE(0=Disable,1=Enable) ; 83h.1
, 1, // Reserved ; 83h.2
LWAK, 1, // LAN Wake Enable (0=Disable, 1=Enable); 83h.3
RWAK, 1, // RTC Wake Enable(0=DIsable,1=Enable) ; 83h.4
, 3, // Reserved ; 83h.5-7
KBEV, 1, // Keyboard Wake Event ; 84h.0
TPEV, 1, // TouchPad Wake Event ; 84h.1
LDEV, 1, // Lid Wake Event ; 84h.2
, 4, // Reserved ; 84h.3-6
PBEV, 1, // Power Button Wake Event ; 84h.7
ECCD, 8, // EC Code State ; 85h
ROFW, 8, // RO FW Reason ID ; 86h
Offset(0xBA),
FWVR, 48, // EC Firmware Version ; BAh-BFh
Offset(0xC0),
SMPR, 8, // SMBus protocol register ; C0h
SMST, 8, // SMBus status register ; C1h
SMAD, 8, // SMBus address register ; C2h
SMCM, 8, // SMBus command register ; C3h
SMD0, 0x100, // SMBus data regs (32) ; C4h - E3h
BCNT, 8, // SMBus Block Count ; E4h
}
Method (_CRS, 0, Serialized)
{
Name (ECMD, ResourceTemplate()
{
IO (Decode16, 0x62, 0x62, 0, 1)
IO (Decode16, 0x66, 0x66, 0, 1)
})
Return (ECMD)
}
Method(_STA)
{
Return(0x0F)
}
Method (_REG, 2, NotSerialized)
{
// Initialize AC power state
\PWRS = ADPT
// Initialize LID switch state
\LIDS = LIDF
// Force a read of CPU temperature
Local0 = CTMP
// Use Local0 to avoid iasl warning: Method Local is set but never used
Local0 &= Ones
// Find and program number of P-States
MPST = SizeOf (\_SB.CP00._PSS)
Printf ("Programming number of P-states: %o", MPST)
// Find and program the current P-State
NPST = \_SB.CP00._PPC
Printf ("Programming Current P-state: %o", NPST)
}
/*
* EC Query Responses
*
* Lid Status Change 06h
* Wifi Button Event (F12) 07h
* TZ Event Update CPU Temp 08h
* CPU P-State Down 0Eh
* CPU P-State UP 0Fh
* AC plug in 10h
* AC removed 11h
* Battery Plugged in 12h
* Battery Removed 13h
* Battery State Change 14h
*/
// Wifi Button Event
Method (_Q07)
{
Printf ("Wifi Button Event 0x07")
}
// Thermal Event
Method (_Q08)
{
Printf ("Thermal Event 0x08")
Notify(\_TZ.THRM, 0x80)
}
// Pstate Down
Method (_Q0E)
{
Printf ("Pstate Event 0x0E")
Local0 = \_SB.CP00._PPC
Local1 = PPCM - 1
If(Local0 < Local1) {
Local0++
\PPCN ()
}
NPST = Local0
}
// Pstate Up
Method (_Q0F)
{
Printf ("Pstate Event 0x0F")
Local0 = \_SB.CP00._PPC
If(Local0) {
Local0--
\PPCN ()
}
NPST = Local0
}
// AC Power Connected
Method (_Q10, 0, NotSerialized)
{
Printf ("AC Insertion Event 0x10")
\PWRS = 1
Notify (AC, 0x80)
Notify (BATX, 0x80)
\PNOT ()
}
// AC Power Removed
Method (_Q11, 0, NotSerialized)
{
Printf ("AC Detach Event 0x11")
\PWRS = Zero
Notify (AC, 0x80)
Notify (BATX, 0x80)
\PNOT ()
}
// Battery State Change - Attach Event
Method (_Q12, 0, NotSerialized)
{
Printf ("Battery Insertion Event 0x12")
Notify (BATX, 0x81)
Notify (BATX, 0x80)
\PNOT ()
}
// Battery State Change - Detach Event
Method (_Q13, 0, NotSerialized)
{
Printf ("Battery Detach Event 0x13")
Notify (BATX, 0x81)
Notify (BATX, 0x80)
\PNOT ()
}
// Battery State Change Event
Method (_Q14, 0, NotSerialized)
{
Printf ("Battery State Change Event 0x14")
Notify (BATX, 0x80)
}
// Lid Switch Event
Method (_Q06)
{
Printf ("Lid Switch Event 0x06")
sleep(20)
\LIDS = LIDF
Notify (\_SB.LID0, 0x80)
}
#include "ac.asl"
#include "battery.asl"
}