soc/mediatek/mt8196: Add GPUEB support
[coreboot.git] / src / soc / intel / meteorlake / pcie_rp.c
blob914520efbb278686dc3c955226ca30da208cf75d
1 /* SPDX-License-Identifier: GPL-2.0-only */
3 #include <intelblocks/pcie_rp.h>
4 #include <soc/pci_devs.h>
5 #include <soc/pcie.h>
6 #include <soc/soc_info.h>
8 /*
9 * Document #640228 Meteor Lake - U/H and U Type4 Processor - 2.3 Device IDs - Table 8 "Other
10 * Device ID" specifies that the first Thunderbolt PCIe root port number is 16. TBT's LCAP
11 * registers return port index which starts from 16 (usually for other PCIe root ports index
12 * starts from 1). Thus, keeping lcap_port_base 16 for TBT, so that coreboot's PCIe remapping
13 * logic can return a correct index (0-based).
16 static const struct pcie_rp_group tbt_rp_groups[] = {
17 { .slot = PCI_DEV_SLOT_TBT, .count = CONFIG_MAX_TBT_ROOT_PORTS, .lcap_port_base = 16 },
18 { 0 }
21 static const struct pcie_rp_group mtlp_rp_groups[] = {
22 { .slot = PCI_DEV_SLOT_PCIE_1, .start = 0, .count = 8, .lcap_port_base = 1 },
23 { .slot = PCI_DEV_SLOT_PCIE_2, .start = 0, .count = 3, .lcap_port_base = 1 },
24 { .slot = PCI_DEV_SLOT_PCIE_3, .start = 0, .count = 1, .lcap_port_base = 1 },
25 { 0 }
28 const struct pcie_rp_group *get_pcie_rp_table(void)
30 return mtlp_rp_groups;
33 const struct pcie_rp_group *get_tbt_pcie_rp_table(void)
35 return tbt_rp_groups;
38 enum pcie_rp_type soc_get_pcie_rp_type(const struct device *dev)
40 return PCIE_RP_PCH;
43 int soc_get_cpu_rp_vw_idx(const struct device *dev)
45 return -1;