ec/system76_ec: add support for System76 EC
This adds ACPI code for System76 EC and converts system76/lemp9 to use EC_SYSTEM76_EC. Tested on system76/lemp9. Signed-off-by: Jeremy Soller <jeremy@system76.com> Change-Id: I1f693268d94b693b6764e4a3baf4c3180689f3be Reviewed-on: https://review.coreboot.org/c/coreboot/+/43612 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Philipp Deppenwiese <zaolin.daisuki@gmail.com> Reviewed-by: Michael Niewöhner
This commit is contained in:
parent
b8d6af9569
commit
0de0fe1104
13 changed files with 78 additions and 29 deletions
9
src/ec/system76/ec/Kconfig
Normal file
9
src/ec/system76/ec/Kconfig
Normal file
|
@ -0,0 +1,9 @@
|
||||||
|
config EC_SYSTEM76_EC
|
||||||
|
bool
|
||||||
|
help
|
||||||
|
System76 EC
|
||||||
|
|
||||||
|
config EC_SYSTEM76_EC_COLOR_KEYBOARD
|
||||||
|
depends on EC_SYSTEM76_EC
|
||||||
|
bool
|
||||||
|
default n
|
|
@ -3,11 +3,11 @@
|
||||||
Device (PWRB)
|
Device (PWRB)
|
||||||
{
|
{
|
||||||
Name (_HID, EisaId ("PNP0C0C"))
|
Name (_HID, EisaId ("PNP0C0C"))
|
||||||
Name (_PRW, Package () { 0x29 /* GPP_D9 */, 3 })
|
Name (_PRW, Package () { EC_GPE_SWI, 3 })
|
||||||
}
|
}
|
||||||
|
|
||||||
Device (SLPB)
|
Device (SLPB)
|
||||||
{
|
{
|
||||||
Name (_HID, EisaId ("PNP0C0E"))
|
Name (_HID, EisaId ("PNP0C0E"))
|
||||||
Name (_PRW, Package () { 0x29 /* GPP_D9 */, 3 })
|
Name (_PRW, Package () { EC_GPE_SWI, 3 })
|
||||||
}
|
}
|
|
@ -1,9 +1,18 @@
|
||||||
/* SPDX-License-Identifier: GPL-2.0-only */
|
/* SPDX-License-Identifier: GPL-2.0-only */
|
||||||
|
|
||||||
Device (EC0)
|
Scope (\_SB) {
|
||||||
|
#include "ac.asl"
|
||||||
|
#include "battery.asl"
|
||||||
|
#include "buttons.asl"
|
||||||
|
#include "hid.asl"
|
||||||
|
#include "lid.asl"
|
||||||
|
#include "s76.asl"
|
||||||
|
}
|
||||||
|
|
||||||
|
Device (\_SB.PCI0.LPCB.EC0)
|
||||||
{
|
{
|
||||||
Name (_HID, EisaId ("PNP0C09") /* Embedded Controller Device */) // _HID: Hardware ID
|
Name (_HID, EisaId ("PNP0C09") /* Embedded Controller Device */) // _HID: Hardware ID
|
||||||
Name (_GPE, 0x50 /* GPP_E16 */) // _GPE: General Purpose Events
|
Name (_GPE, EC_GPE_SCI) // _GPE: General Purpose Events
|
||||||
Name (_CRS, ResourceTemplate () // _CRS: Current Resource Settings
|
Name (_CRS, ResourceTemplate () // _CRS: Current Resource Settings
|
||||||
{
|
{
|
||||||
IO (Decode16,
|
IO (Decode16,
|
||||||
|
@ -20,7 +29,7 @@ Device (EC0)
|
||||||
)
|
)
|
||||||
})
|
})
|
||||||
|
|
||||||
#include "acpi/ec_ram.asl"
|
#include "ec_ram.asl"
|
||||||
|
|
||||||
Name (ECOK, Zero)
|
Name (ECOK, Zero)
|
||||||
Method (_REG, 2, Serialized) // _REG: Region Availability
|
Method (_REG, 2, Serialized) // _REG: Region Availability
|
||||||
|
@ -39,6 +48,10 @@ Device (EC0)
|
||||||
^^^^BAT0.UPBI()
|
^^^^BAT0.UPBI()
|
||||||
^^^^BAT0.UPBS()
|
^^^^BAT0.UPBS()
|
||||||
|
|
||||||
|
// Notify of changes
|
||||||
|
Notify(^^^^AC, Zero)
|
||||||
|
Notify(^^^^BAT0, Zero)
|
||||||
|
|
||||||
PNOT ()
|
PNOT ()
|
||||||
|
|
||||||
// EC is now available
|
// EC is now available
|
||||||
|
@ -71,8 +84,6 @@ Device (EC0)
|
||||||
Notify(^^^^AC, Zero)
|
Notify(^^^^AC, Zero)
|
||||||
Notify(^^^^BAT0, Zero)
|
Notify(^^^^BAT0, Zero)
|
||||||
|
|
||||||
Sleep (1000)
|
|
||||||
|
|
||||||
// Reset System76 Device
|
// Reset System76 Device
|
||||||
^^^^S76D.RSET()
|
^^^^S76D.RSET()
|
||||||
}
|
}
|
||||||
|
@ -116,13 +127,17 @@ Device (EC0)
|
||||||
Method (_Q11, 0, NotSerialized) // Brightness Down
|
Method (_Q11, 0, NotSerialized) // Brightness Down
|
||||||
{
|
{
|
||||||
Debug = "EC: Brightness Down"
|
Debug = "EC: Brightness Down"
|
||||||
^^^^HIDD.HPEM (20)
|
if (^^^^HIDD.HRDY) {
|
||||||
|
^^^^HIDD.HPEM (20)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Method (_Q12, 0, NotSerialized) // Brightness Up
|
Method (_Q12, 0, NotSerialized) // Brightness Up
|
||||||
{
|
{
|
||||||
Debug = "EC: Brightness Up"
|
Debug = "EC: Brightness Up"
|
||||||
^^^^HIDD.HPEM (19)
|
if (^^^^HIDD.HRDY) {
|
||||||
|
^^^^HIDD.HPEM (19)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Method (_Q13, 0, NotSerialized) // Camera Toggle
|
Method (_Q13, 0, NotSerialized) // Camera Toggle
|
||||||
|
@ -133,10 +148,10 @@ Device (EC0)
|
||||||
Method (_Q14, 0, NotSerialized) // Airplane Mode
|
Method (_Q14, 0, NotSerialized) // Airplane Mode
|
||||||
{
|
{
|
||||||
Debug = "EC: Airplane Mode"
|
Debug = "EC: Airplane Mode"
|
||||||
// Only send HIDD message when hardware airplane mode not in use
|
if (^^^^HIDD.HRDY) {
|
||||||
If (ECOS == 2) {
|
|
||||||
^^^^HIDD.HPEM (8)
|
^^^^HIDD.HPEM (8)
|
||||||
}
|
}
|
||||||
|
// TODO: hardware airplane mode
|
||||||
}
|
}
|
||||||
|
|
||||||
Method (_Q15, 0, NotSerialized) // Suspend Button
|
Method (_Q15, 0, NotSerialized) // Suspend Button
|
||||||
|
@ -150,13 +165,10 @@ Device (EC0)
|
||||||
Debug = "EC: AC Detect"
|
Debug = "EC: AC Detect"
|
||||||
^^^^AC.ACFG = ADP
|
^^^^AC.ACFG = ADP
|
||||||
Notify (AC, 0x80) // Status Change
|
Notify (AC, 0x80) // Status Change
|
||||||
Sleep (0x01F4)
|
|
||||||
If (BAT0)
|
If (BAT0)
|
||||||
{
|
{
|
||||||
Notify (^^^^BAT0, 0x81) // Information Change
|
Notify (^^^^BAT0, 0x81) // Information Change
|
||||||
Sleep (0x32)
|
|
||||||
Notify (^^^^BAT0, 0x80) // Status Change
|
Notify (^^^^BAT0, 0x80) // Status Change
|
||||||
Sleep (0x32)
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -3,7 +3,7 @@
|
||||||
Device (LID0)
|
Device (LID0)
|
||||||
{
|
{
|
||||||
Name (_HID, EisaId ("PNP0C0D"))
|
Name (_HID, EisaId ("PNP0C0D"))
|
||||||
Name (_PRW, Package () { 0x29 /* GPP_D9 */, 3 })
|
Name (_PRW, Package () { EC_GPE_SWI, 3 })
|
||||||
|
|
||||||
Method (_LID, 0, NotSerialized) {
|
Method (_LID, 0, NotSerialized) {
|
||||||
DEBUG = "LID: _LID"
|
DEBUG = "LID: _LID"
|
|
@ -14,6 +14,9 @@ Device (S76D) {
|
||||||
Debug = "S76D: RSET"
|
Debug = "S76D: RSET"
|
||||||
SAPL(0)
|
SAPL(0)
|
||||||
SKBL(0)
|
SKBL(0)
|
||||||
|
#if CONFIG(EC_SYSTEM76_EC_COLOR_KEYBOARD)
|
||||||
|
SKBC(0xFFFFFF)
|
||||||
|
#endif // CONFIG(EC_SYSTEM76_EC_COLOR_KEYBOARD)
|
||||||
}
|
}
|
||||||
|
|
||||||
Method (INIT, 0, Serialized) {
|
Method (INIT, 0, Serialized) {
|
||||||
|
@ -61,6 +64,32 @@ Device (S76D) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if CONFIG(EC_SYSTEM76_EC_COLOR_KEYBOARD)
|
||||||
|
// Set KB LED Brightness
|
||||||
|
Method (SKBL, 1, Serialized) {
|
||||||
|
If (^^PCI0.LPCB.EC0.ECOK) {
|
||||||
|
^^PCI0.LPCB.EC0.FDAT = 6
|
||||||
|
^^PCI0.LPCB.EC0.FBUF = Arg0
|
||||||
|
^^PCI0.LPCB.EC0.FBF1 = 0
|
||||||
|
^^PCI0.LPCB.EC0.FBF2 = Arg0
|
||||||
|
^^PCI0.LPCB.EC0.FCMD = 0xCA
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Set Keyboard Color
|
||||||
|
Method (SKBC, 1, Serialized) {
|
||||||
|
If (^^PCI0.LPCB.EC0.ECOK) {
|
||||||
|
^^PCI0.LPCB.EC0.FDAT = 0x3
|
||||||
|
^^PCI0.LPCB.EC0.FBUF = (Arg0 & 0xFF)
|
||||||
|
^^PCI0.LPCB.EC0.FBF1 = ((Arg0 >> 16) & 0xFF)
|
||||||
|
^^PCI0.LPCB.EC0.FBF2 = ((Arg0 >> 8) & 0xFF)
|
||||||
|
^^PCI0.LPCB.EC0.FCMD = 0xCA
|
||||||
|
Return (Arg0)
|
||||||
|
} Else {
|
||||||
|
Return (0)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#else // CONFIG(EC_SYSTEM76_EC_COLOR_KEYBOARD)
|
||||||
// Get KB LED
|
// Get KB LED
|
||||||
Method (GKBL, 0, Serialized) {
|
Method (GKBL, 0, Serialized) {
|
||||||
Local0 = 0
|
Local0 = 0
|
||||||
|
@ -81,4 +110,5 @@ Device (S76D) {
|
||||||
^^PCI0.LPCB.EC0.FCMD = 0xCA
|
^^PCI0.LPCB.EC0.FCMD = 0xCA
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#endif // CONFIG(EC_SYSTEM76_EC_COLOR_KEYBOARD)
|
||||||
}
|
}
|
|
@ -3,7 +3,7 @@ if BOARD_SYSTEM76_LEMP9
|
||||||
config BOARD_SPECIFIC_OPTIONS
|
config BOARD_SPECIFIC_OPTIONS
|
||||||
def_bool y
|
def_bool y
|
||||||
select BOARD_ROMSIZE_KB_16384
|
select BOARD_ROMSIZE_KB_16384
|
||||||
select EC_ACPI
|
select EC_SYSTEM76_EC
|
||||||
select HAVE_ACPI_RESUME
|
select HAVE_ACPI_RESUME
|
||||||
select HAVE_ACPI_TABLES
|
select HAVE_ACPI_TABLES
|
||||||
select HAVE_SMI_HANDLER
|
select HAVE_SMI_HANDLER
|
||||||
|
|
|
@ -1,12 +1,11 @@
|
||||||
/* SPDX-License-Identifier: GPL-2.0-only */
|
/* SPDX-License-Identifier: GPL-2.0-only */
|
||||||
|
|
||||||
|
#define EC_GPE_SCI 0x50 /* GPP_E16 */
|
||||||
|
#define EC_GPE_SWI 0x29 /* GPP_D9 */
|
||||||
|
#define EC_COLOR_KEYBOARD 0
|
||||||
|
#include <ec/system76/ec/acpi/ec.asl>
|
||||||
|
|
||||||
Scope (\_SB) {
|
Scope (\_SB) {
|
||||||
#include "ac.asl"
|
|
||||||
#include "battery.asl"
|
|
||||||
#include "buttons.asl"
|
|
||||||
#include "hid.asl"
|
|
||||||
#include "lid.asl"
|
|
||||||
#include "s76.asl"
|
|
||||||
#include "sleep.asl"
|
#include "sleep.asl"
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -147,14 +147,14 @@ chip soc/intel/cannonlake
|
||||||
|
|
||||||
# LPC (soc/intel/cannonlake/lpc.c)
|
# LPC (soc/intel/cannonlake/lpc.c)
|
||||||
# LPC configuration from lspci -s 1f.0 -xxx
|
# LPC configuration from lspci -s 1f.0 -xxx
|
||||||
# Address 0x84: Decode 0x80 - 0x8F
|
# Address 0x84: Decode 0x80 - 0x8F (Port 80)
|
||||||
register "gen1_dec" = "0x000c0081"
|
register "gen1_dec" = "0x000c0081"
|
||||||
# Address 0x88: Decode 0x68 - 0x6F
|
# Address 0x88: Decode 0x68 - 0x6F (PMC)
|
||||||
register "gen2_dec" = "0x00040069"
|
register "gen2_dec" = "0x00040069"
|
||||||
# Address 0x8C: Decode 0x3320 - 0x332F
|
# Address 0x8C: Decode 0xE00 - 0xEFF (AP/EC command)
|
||||||
register "gen3_dec" = "0x000c3321"
|
register "gen3_dec" = "0x00fc0E01"
|
||||||
# Address 0x90: Disabled
|
# Address 0x90: Decode 0xF00 - 0xFFF (AP/EC debug)
|
||||||
register "gen4_dec" = "0x00000000"
|
register "gen4_dec" = "0x00fc0F01"
|
||||||
|
|
||||||
# PMC (soc/intel/cannonlake/pmc.c)
|
# PMC (soc/intel/cannonlake/pmc.c)
|
||||||
# Enable deep Sx states
|
# Enable deep Sx states
|
||||||
|
|
|
@ -25,7 +25,6 @@ DefinitionBlock(
|
||||||
Scope (\_SB.PCI0.LPCB)
|
Scope (\_SB.PCI0.LPCB)
|
||||||
{
|
{
|
||||||
#include <drivers/pc80/pc/ps2_controller.asl>
|
#include <drivers/pc80/pc/ps2_controller.asl>
|
||||||
#include "acpi/ec.asl"
|
|
||||||
}
|
}
|
||||||
|
|
||||||
#include "acpi/mainboard.asl"
|
#include "acpi/mainboard.asl"
|
||||||
|
|
Loading…
Reference in a new issue