summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorMaxim Polyakov <max.senia.poliak@gmail.com>2020-04-26 20:56:50 +0300
committerPatrick Georgi <pgeorgi@google.com>2021-02-26 07:31:03 +0000
commit1090b16b98d3fe176ec71cd7897e58e60c761ec4 (patch)
treeb0446b93f88b178ce3d043b2095625112986d2da /src
parent3865a33231064c4ea9e6950776c60dc37b4abf78 (diff)
downloadcoreboot-1090b16b98d3fe176ec71cd7897e58e60c761ec4.tar.xz
intel/xeon_sp: Add ACPI to control GPIO
This has been tested on the OCP Delta Lake platform. Change-Id: I07c882077eb3c035faae81641bc860e69db224b4 Signed-off-by: Maxim Polyakov <max.senia.poliak@gmail.com> Reviewed-on: https://review.coreboot.org/c/coreboot/+/39979 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Lance Zhao
Diffstat (limited to 'src')
-rw-r--r--src/soc/intel/xeon_sp/acpi/gpio.asl174
-rw-r--r--src/soc/intel/xeon_sp/acpi/pch.asl3
-rw-r--r--src/soc/intel/xeon_sp/include/soc/iomap.h1
-rw-r--r--src/soc/intel/xeon_sp/include/soc/irq.h1
4 files changed, 179 insertions, 0 deletions
diff --git a/src/soc/intel/xeon_sp/acpi/gpio.asl b/src/soc/intel/xeon_sp/acpi/gpio.asl
new file mode 100644
index 0000000000..6fe3d51588
--- /dev/null
+++ b/src/soc/intel/xeon_sp/acpi/gpio.asl
@@ -0,0 +1,174 @@
+/* SPDX-License-Identifier: GPL-2.0-only */
+/* This file is part of the coreboot project. */
+
+#include <soc/gpio.h>
+#include <soc/pcr_ids.h>
+#include <soc/irq.h>
+#include <soc/intel/common/block/acpi/acpi/gpio_op.asl>
+#include <soc/intel/common/acpi/pcr.asl>
+
+Device (GPIO)
+{
+ Name (_HID, "INT3536")
+ Name (_UID, 0)
+ Name (_DDN, "GPIO Controller")
+
+ Name (RBUF, ResourceTemplate()
+ {
+ Memory32Fixed (ReadWrite, 0, 0, COM0)
+ Memory32Fixed (ReadWrite, 0, 0, COM1)
+ Memory32Fixed (ReadWrite, 0, 0, COM2)
+ Memory32Fixed (ReadWrite, 0, 0, COM3)
+ Memory32Fixed (ReadWrite, 0, 0, COM4)
+ Memory32Fixed (ReadWrite, 0, 0, COM5)
+ Interrupt (ResourceConsumer, Level, ActiveLow, Shared,,, GIRQ) { PCH_IRQ14 }
+ })
+
+ /* Current Resource Settings */
+ Method (_CRS, 0, NotSerialized)
+ {
+ /* GPIO Community 0 */
+ CreateDWordField (^RBUF, ^COM0._BAS, BAS0)
+ CreateDWordField (^RBUF, ^COM0._LEN, LEN0)
+ BAS0 = ^^PCRB (PID_GPIOCOM0)
+ LEN0 = GPIO_BASE_SIZE
+
+ /* GPIO Community 1 */
+ CreateDWordField (^RBUF, ^COM1._BAS, BAS1)
+ CreateDWordField (^RBUF, ^COM1._LEN, LEN1)
+ BAS1 = ^^PCRB (PID_GPIOCOM1)
+ LEN1 = GPIO_BASE_SIZE
+
+ /* GPIO Community 2 */
+ CreateDWordField (^RBUF, ^COM2._BAS, BAS2)
+ CreateDWordField (^RBUF, ^COM2._LEN, LEN2)
+ BAS2 = ^^PCRB (PID_GPIOCOM2)
+ LEN2 = GPIO_BASE_SIZE
+
+ /* GPIO Community 3 */
+ CreateDWordField (^RBUF, ^COM3._BAS, BAS3)
+ CreateDWordField (^RBUF, ^COM3._LEN, LEN3)
+ BAS3 = ^^PCRB (PID_GPIOCOM3)
+ LEN3 = GPIO_BASE_SIZE
+
+ /* GPIO Community 4 */
+ CreateDWordField (^RBUF, ^COM4._BAS, BAS4)
+ CreateDWordField (^RBUF, ^COM4._LEN, LEN4)
+ BAS4 = ^^PCRB (PID_GPIOCOM4)
+ LEN4 = GPIO_BASE_SIZE
+
+ /* GPIO Community 5 */
+ CreateDWordField (^RBUF, ^COM5._BAS, BAS5)
+ CreateDWordField (^RBUF, ^COM5._LEN, LEN5)
+ BAS5 = ^^PCRB (PID_GPIOCOM5)
+ LEN5 = GPIO_BASE_SIZE
+
+ Return (RBUF)
+ }
+
+ /* Return status of power resource */
+ Method (_STA, 0, NotSerialized)
+ {
+ Return (0xF)
+ }
+}
+
+/*
+ * Get GPIO DW0 Address
+ * Arg0 - GPIO Number
+ */
+Method (GADD, 1, NotSerialized)
+{
+ /* GPIO Community 0 */
+ if ((Arg0 >= GPP_A0) && (Arg0 <= GPP_F23))
+ {
+ Local0 = PID_GPIOCOM0
+ Local1 = Arg0 - GPP_A0
+ }
+
+ /* GPIO Community 1 */
+ if ((Arg0 >= GPP_C0) && (Arg0 <= GPP_E12))
+ {
+ Local0 = PID_GPIOCOM1
+ Local1 = Arg0 - GPP_C0
+ }
+
+ /* GPIO Community 2 */
+ if ((Arg0 >= GPD0) && (Arg0 <= GPD11))
+ {
+ Local0 = PID_GPIOCOM2
+ Local1 = Arg0 - GPD0
+ }
+
+ /* GPIO Community 3 */
+ if ((Arg0 >= GPP_I0) && (Arg0 <= GPP_I10))
+ {
+ Local0 = PID_GPIOCOM3
+ Local1 = Arg0 - GPP_I0
+ }
+
+ /* GPIO Community 4 */
+ if ((Arg0 >= GPP_J0) && (Arg0 <= GPP_K10))
+ {
+ Local0 = PID_GPIOCOM4
+ Local1 = Arg0 - GPP_J0
+ }
+
+ /* GPIO Community 5 */
+ if ((Arg0 >= GPP_G0) && (Arg0 <= GPP_L19))
+ {
+ Local0 = PID_GPIOCOM5
+ Local1 = Arg0 - GPP_G0
+ }
+
+ Local2 = PCRB (Local0)
+ Local2 += PAD_CFG_BASE
+ Return (Local2 + (Local1 * 8))
+}
+
+/*
+ * Return PCR Port ID of GPIO Communities
+ *
+ * Arg0: GPIO Community (0-5)
+ */
+Method (GPID, 1, Serialized)
+{
+ Switch (ToInteger (Arg0))
+ {
+ Case (COMM_0)
+ {
+ Local0 = PID_GPIOCOM0
+ }
+
+ Case (COMM_1)
+ {
+ Local0 = PID_GPIOCOM1
+ }
+
+ Case (COMM_2)
+ {
+ Local0 = PID_GPIOCOM2
+ }
+
+ Case (COMM_3)
+ {
+ Local0 = PID_GPIOCOM3
+ }
+
+ Case (COMM_4)
+ {
+ Local0 = PID_GPIOCOM4
+ }
+
+ Case (COMM_5)
+ {
+ Local0 = PID_GPIOCOM5
+ }
+
+ Default
+ {
+ Return (0)
+ }
+ }
+ Return (Local0)
+}
diff --git a/src/soc/intel/xeon_sp/acpi/pch.asl b/src/soc/intel/xeon_sp/acpi/pch.asl
index 98a5fdd50d..fef68b0818 100644
--- a/src/soc/intel/xeon_sp/acpi/pch.asl
+++ b/src/soc/intel/xeon_sp/acpi/pch.asl
@@ -2,5 +2,8 @@
/* This file should be included in the proper platform ACPI \_SB PCI scope */
+/* GPIO */
+#include <soc/intel/xeon_sp/acpi/gpio.asl>
+
/* LPC 0:1f.0 */
#include <soc/intel/common/block/acpi/acpi/lpc.asl>
diff --git a/src/soc/intel/xeon_sp/include/soc/iomap.h b/src/soc/intel/xeon_sp/include/soc/iomap.h
index f9c364454f..a51b58c1a6 100644
--- a/src/soc/intel/xeon_sp/include/soc/iomap.h
+++ b/src/soc/intel/xeon_sp/include/soc/iomap.h
@@ -33,5 +33,6 @@
#define PCH_PWRM_BASE_SIZE 0x10000
#define P2SB_BAR CONFIG_PCR_BASE_ADDRESS
+#define GPIO_BASE_SIZE 0x10000
#endif /* _SOC_IOMAP_H_ */
diff --git a/src/soc/intel/xeon_sp/include/soc/irq.h b/src/soc/intel/xeon_sp/include/soc/irq.h
index 2517fb8704..4d3ad7a09f 100644
--- a/src/soc/intel/xeon_sp/include/soc/irq.h
+++ b/src/soc/intel/xeon_sp/include/soc/irq.h
@@ -5,5 +5,6 @@
#define PCH_IRQ10 10
#define PCH_IRQ11 11
+#define PCH_IRQ14 14
#endif /* _SOC_IRQ_H_ */