1 /* SPDX-License-Identifier: GPL-2.0-only */
3 #include <intelblocks/pcie_rp.h>
4 #include <soc/pci_devs.h>
8 * TBT's LCAP registers are returning port index which starts from 0x10 (Usually for other PCIe
9 * root ports index starts from 1). Thus keeping lcap_port_base 0x10 for TBT, so that coreboot's
10 * PCIe remapping logic can return correct index (0-based)
13 static const struct pcie_rp_group tbt_rp_groups
[] = {
14 { .slot
= PCI_DEV_SLOT_TBT
, .count
= CONFIG_MAX_TBT_ROOT_PORTS
, .lcap_port_base
= 0x10 },
18 static const struct pcie_rp_group ptl_rp_groups
[] = {
19 { .slot
= PCI_DEV_SLOT_PCIE_1
, .count
= 8, .lcap_port_base
= 1 },
20 #if CONFIG(SOC_INTEL_PANTHERLAKE_U_H)
21 { .slot
= PCI_DEV_SLOT_PCIE_2
, .count
= 4, .lcap_port_base
= 1 },
23 { .slot
= PCI_DEV_SLOT_PCIE_2
, .count
= 2, .lcap_port_base
= 1 },
28 const struct pcie_rp_group
*get_pcie_rp_table(void)
33 const struct pcie_rp_group
*get_tbt_pcie_rp_table(void)
38 enum pcie_rp_type
soc_get_pcie_rp_type(const struct device
*dev
)
43 int soc_get_cpu_rp_vw_idx(const struct device
*dev
)