diff options
author | Jeremy Soller <jeremy@system76.com> | 2021-10-27 15:45:41 -0600 |
---|---|---|
committer | Patrick Georgi <pgeorgi@google.com> | 2021-11-02 20:48:29 +0000 |
commit | fdaccd875da610954e3bc1136fad8a3c70ceae71 (patch) | |
tree | e6444aaeb61e51d84c6d52b979fddffb1e82f93f /src/mainboard/system76/bonw14/acpi | |
parent | f74e42a542ab5a678b40a0e32d03f6a2449e45c9 (diff) |
mb/system76/bonw14: Add System76 Bonobo Workstation 14
Change-Id: I55a827f8d6a5421c36f77049935630f4db4ba04d
Signed-off-by: Jeremy Soller <jeremy@system76.com>
Signed-off-by: Tim Crawford <tcrawford@system76.com>
Reviewed-on: https://review.coreboot.org/c/coreboot/+/49173
Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
Reviewed-by: Patrick Georgi <pgeorgi@google.com>
Diffstat (limited to 'src/mainboard/system76/bonw14/acpi')
-rw-r--r-- | src/mainboard/system76/bonw14/acpi/dgpu.asl | 123 | ||||
-rw-r--r-- | src/mainboard/system76/bonw14/acpi/gpe.asl | 11 | ||||
-rw-r--r-- | src/mainboard/system76/bonw14/acpi/mainboard.asl | 15 | ||||
-rw-r--r-- | src/mainboard/system76/bonw14/acpi/sleep.asl | 11 |
4 files changed, 160 insertions, 0 deletions
diff --git a/src/mainboard/system76/bonw14/acpi/dgpu.asl b/src/mainboard/system76/bonw14/acpi/dgpu.asl new file mode 100644 index 0000000000..6521ee947e --- /dev/null +++ b/src/mainboard/system76/bonw14/acpi/dgpu.asl @@ -0,0 +1,123 @@ +/* SPDX-License-Identifier: GPL-2.0-only */ + +Device (\_SB.PCI0.PEG0) +{ + Name (_ADR, 0x00010000) + + Device (PEGP) + { + Name (_ADR, 0) + + // Convert a byte to a hex string, trimming extra parts + Method (BHEX, 1) + { + Local0 = ToHexString(Arg0) + Return (Mid(Local0, SizeOf(Local0) - 2, 2)) + } + + // UUID to string + Method (IDST, 1) + { + Local0 = "" + Fprintf( + Local0, + "%o%o%o%o-%o%o-%o%o-%o%o-%o%o%o%o%o%o", + BHEX(DerefOf(Arg0[3])), + BHEX(DerefOf(Arg0[2])), + BHEX(DerefOf(Arg0[1])), + BHEX(DerefOf(Arg0[0])), + BHEX(DerefOf(Arg0[5])), + BHEX(DerefOf(Arg0[4])), + BHEX(DerefOf(Arg0[7])), + BHEX(DerefOf(Arg0[6])), + BHEX(DerefOf(Arg0[8])), + BHEX(DerefOf(Arg0[9])), + BHEX(DerefOf(Arg0[10])), + BHEX(DerefOf(Arg0[11])), + BHEX(DerefOf(Arg0[12])), + BHEX(DerefOf(Arg0[13])), + BHEX(DerefOf(Arg0[14])), + BHEX(DerefOf(Arg0[15])) + ) + Return (Local0) + } + + // Safe hex conversion, checks type first + Method (SFST, 1) + { + Local0 = ObjectType(Arg0) + If (Local0 == 1 || Local0 == 2 || Local0 == 3) { + Return (ToHexString(Arg0)) + } Else { + Return (Concatenate("Type: ", Arg0)) + } + } + + Method (_DSM, 4, Serialized) + { + Debug = "NVIDIA _DSM" + Printf(" Arg0: %o", IDST(Arg0)) + Printf(" Arg1: %o", SFST(Arg1)) + Printf(" Arg2: %o", SFST(Arg2)) + Printf(" Arg3: %o", SFST(Arg3)) + + If (Arg0 == ToUUID ("d4a50b75-65c7-46f7-bfb7-41514cea0244")) { + If (Arg1 != 0x0102) { + Printf(" Invalid Arg1, return 0x80000002") + Return (0x80000002) + } + + If (Arg2 == 0) { + Printf(" Arg2 == 0x00, return supported functions") + Return (Buffer (4) { 0x01, 0x00, 0x10, 0x00 }) + } + + If (Arg2 == 0x14) { + Printf(" Arg2 == 0x14, return backlight package") + Return (Package (9) { + 0x8000A450, + 0x0200, + 0, + 0, + 1, + 1, + 200, + 32, + 1000 + }) + } + + Printf(" Unknown Arg2, return 0x80000002") + Return (0x80000002) + } + + Printf(" Unknown Arg0, return 0x80000001") + Return (0x80000001) + } + + // _DOD: Display Output Devices + Method (_DOD, 0, NotSerialized) + { + Return (Package (3) { + 0x80008320, + 0x80006330, + 0x8000A450 + }) + } + + Device (HDM0) + { + Name (_ADR, 0x80008320) + } + + Device (DSP0) + { + Name (_ADR, 0x80006330) + } + + Device (DSP1) + { + Name (_ADR, 0x8000A450) + } + } +} diff --git a/src/mainboard/system76/bonw14/acpi/gpe.asl b/src/mainboard/system76/bonw14/acpi/gpe.asl new file mode 100644 index 0000000000..7ef9a989c0 --- /dev/null +++ b/src/mainboard/system76/bonw14/acpi/gpe.asl @@ -0,0 +1,11 @@ +/* SPDX-License-Identifier: GPL-2.0-only */ + +// GPP_K6 SCI +Method (_L06, 0, Serialized) { + Debug = Concatenate("GPE _L06: ", ToHexString(\_SB.PCI0.LPCB.EC0.WFNO)) + If (\_SB.PCI0.LPCB.EC0.ECOK) { + If (\_SB.PCI0.LPCB.EC0.WFNO == 1) { + Notify(\_SB.LID0, 0x80) + } + } +} diff --git a/src/mainboard/system76/bonw14/acpi/mainboard.asl b/src/mainboard/system76/bonw14/acpi/mainboard.asl new file mode 100644 index 0000000000..0a4c64cc67 --- /dev/null +++ b/src/mainboard/system76/bonw14/acpi/mainboard.asl @@ -0,0 +1,15 @@ +/* SPDX-License-Identifier: GPL-2.0-only */ + +#define EC_GPE_SCI 0x03 /* GPP_K3 */ +#define EC_GPE_SWI 0x06 /* GPP_K6 */ +#include <ec/system76/ec/acpi/ec.asl> + +Scope (\_SB) { + #include "sleep.asl" +} + +Scope (\_GPE) { + #include "gpe.asl" +} + +#include "dgpu.asl" diff --git a/src/mainboard/system76/bonw14/acpi/sleep.asl b/src/mainboard/system76/bonw14/acpi/sleep.asl new file mode 100644 index 0000000000..48c50e075e --- /dev/null +++ b/src/mainboard/system76/bonw14/acpi/sleep.asl @@ -0,0 +1,11 @@ +/* SPDX-License-Identifier: GPL-2.0-only */ + +/* Method called from _PTS prior to enter sleep state */ +Method (MPTS, 1) { + \_SB.PCI0.LPCB.EC0.PTS (Arg0) +} + +/* Method called from _WAK prior to wakeup */ +Method (MWAK, 1) { + \_SB.PCI0.LPCB.EC0.WAK (Arg0) +} |