summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJianjun Wang <jianjun.wang@mediatek.com>2021-07-28 16:53:43 +0800
committerYu-Ping Wu <yupingso@google.com>2022-05-20 02:53:35 +0000
commit20a87c0bed98fe8817a2dfccf4cd271199aabc1a (patch)
treefc9deb0205c596fbd8c448f24f9fca74a1fa8bfa
parent2ad74deb2a11772cdd23c3613b58e9116b36863a (diff)
libpayload/pci: Add pci_map_bus function for MediaTek platform
Add 'pci_map_bus' function and PCIE_MEDIATEK config for MediaTek platform. TEST=Build pass and boot up to kernel successfully via SSD on Dojo board, here is the SSD information in boot log: == NVME IDENTIFY CONTROLLER DATA == PCI VID : 0x15b7 PCI SSVID : 0x15b7 SN : 21517J440114 MN : WDC PC SN530 SDBPTPZ-256G-1006 RAB : 0x4 AERL : 0x7 SQES : 0x66 CQES : 0x44 NN : 0x1 Identified NVMe model WDC PC SN530 SDBPTPZ-256G-1006 BUG=b:178565024 BRANCH=cherry Signed-off-by: Jianjun Wang <jianjun.wang@mediatek.com> Change-Id: I9ea7d111fed6b816fa2352fe93c268116519a577 Reviewed-on: https://review.coreboot.org/c/coreboot/+/56794 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Yu-Ping Wu <yupingso@google.com>
-rw-r--r--payloads/libpayload/Kconfig5
-rw-r--r--payloads/libpayload/drivers/Makefile.inc2
-rw-r--r--payloads/libpayload/drivers/pcie_mediatek.c20
3 files changed, 27 insertions, 0 deletions
diff --git a/payloads/libpayload/Kconfig b/payloads/libpayload/Kconfig
index 7540c674a2..2ad3c00206 100644
--- a/payloads/libpayload/Kconfig
+++ b/payloads/libpayload/Kconfig
@@ -413,6 +413,11 @@ config PCI_IO_OPS
default y if ARCH_X86
default n
+config PCIE_MEDIATEK
+ bool "Support for PCIe devices on MediaTek platforms"
+ depends on PCI && !PCI_IO_OPS
+ default n
+
config NVRAM
bool "Support for reading/writing NVRAM bytes"
depends on ARCH_X86 # for now
diff --git a/payloads/libpayload/drivers/Makefile.inc b/payloads/libpayload/drivers/Makefile.inc
index b2a91f6610..204760757b 100644
--- a/payloads/libpayload/drivers/Makefile.inc
+++ b/payloads/libpayload/drivers/Makefile.inc
@@ -36,6 +36,8 @@ else
libc-$(CONFIG_LP_PCI) += pci_map_bus_ops.c
endif
+libc-$(CONFIG_LP_PCIE_MEDIATEK) += pcie_mediatek.c
+
libc-$(CONFIG_LP_SPEAKER) += speaker.c
libc-$(CONFIG_LP_8250_SERIAL_CONSOLE) += serial/8250.c serial/serial.c
diff --git a/payloads/libpayload/drivers/pcie_mediatek.c b/payloads/libpayload/drivers/pcie_mediatek.c
new file mode 100644
index 0000000000..a953bd7fae
--- /dev/null
+++ b/payloads/libpayload/drivers/pcie_mediatek.c
@@ -0,0 +1,20 @@
+/* SPDX-License-Identifier: GPL-2.0-only */
+
+#include <libpayload.h>
+#include <pci.h>
+
+#define PCIE_CFGNUM_REG 0x140
+#define PCIE_CFG_DEVFN(devfn) ((devfn) & GENMASK(7, 0))
+#define PCIE_CFG_BUS(bus) (((bus) << 8) & GENMASK(15, 8))
+#define PCIE_CFG_OFFSET_ADDR 0x1000
+#define PCIE_CFG_HEADER(bus, devfn) \
+ (PCIE_CFG_BUS(bus) | PCIE_CFG_DEVFN(devfn))
+
+uintptr_t pci_map_bus(pcidev_t dev)
+{
+ u32 devfn = (PCI_SLOT(dev) << 3) | PCI_FUNC(dev);
+ u32 val = PCIE_CFG_HEADER(PCI_BUS(dev), devfn);
+ write32((void *)(lib_sysinfo.pcie_ctrl_base + PCIE_CFGNUM_REG), val);
+
+ return lib_sysinfo.pcie_ctrl_base + PCIE_CFG_OFFSET_ADDR;
+}