blob: c8a958d70db292f880b58b2c7483a090b346ad27 [file] [log] [blame]
/* SPDX-License-Identifier: GPL-2.0-only */
#include <console/console.h>
#include <device/device.h>
#include <device/pci.h>
#include <device/pci_ids.h>
#include <device/pci_ops.h>
#include <device/pciexp.h>
#include <stdint.h>
#define CACHE_LINE_SIZE 0x10
static void pch_pcie_init(struct device *dev)
{
u16 reg16;
printk(BIOS_DEBUG, "Initializing PCH PCIe bridge.\n");
/* Enable SERR */
pci_or_config32(dev, PCI_COMMAND, PCI_COMMAND_SERR);
/* Enable Bus Master */
pci_or_config32(dev, PCI_COMMAND, PCI_COMMAND_MASTER);
/* Set Cache Line Size to 0x10 */
pci_write_config8(dev, PCI_CACHE_LINE_SIZE, CACHE_LINE_SIZE);
/* disable parity error response */
pci_and_config16(dev, PCI_BRIDGE_CONTROL, ~PCI_BRIDGE_CTL_PARITY);
if (CONFIG(PCIE_DEBUG_INFO)) {
printk(BIOS_SPEW, " MBL = 0x%08x\n",
pci_read_config32(dev, PCI_MEMORY_BASE));
printk(BIOS_SPEW, " PMBL = 0x%08x\n",
pci_read_config32(dev, PCI_PREF_MEMORY_BASE));
printk(BIOS_SPEW, " PMBU32 = 0x%08x\n",
pci_read_config32(dev, PCI_PREF_BASE_UPPER32));
printk(BIOS_SPEW, " PMLU32 = 0x%08x\n",
pci_read_config32(dev, PCI_PREF_LIMIT_UPPER32));
}
/* Clear errors in status registers */
reg16 = pci_read_config16(dev, PCI_STATUS);
pci_write_config16(dev, PCI_STATUS, reg16);
reg16 = pci_read_config16(dev, PCI_SEC_STATUS);
pci_write_config16(dev, PCI_SEC_STATUS, reg16);
}
static void pcie_get_ltr_max_latencies(u16 *max_snoop, u16 *max_nosnoop)
{
*max_snoop = PCIE_LTR_MAX_SNOOP_LATENCY_3146US;
*max_nosnoop = PCIE_LTR_MAX_NO_SNOOP_LATENCY_3146US;
}
static struct pci_operations pcie_ops = {
.get_ltr_max_latencies = pcie_get_ltr_max_latencies,
.set_subsystem = pci_dev_set_subsystem,
};
struct device_operations pcie_rp_ops = {
.read_resources = pci_bus_read_resources,
.set_resources = pci_dev_set_resources,
.enable_resources = pci_bus_enable_resources,
.init = pch_pcie_init,
.scan_bus = pciexp_scan_bridge,
.ops_pci = &pcie_ops,
};
static const unsigned short pcie_device_ids[] = {
PCI_DID_INTEL_RPL_P_PCIE_RP1,
PCI_DID_INTEL_RPL_P_PCIE_RP2,
PCI_DID_INTEL_RPL_P_PCIE_RP3,
PCI_DID_INTEL_MTL_SOC_PCIE_RP1,
PCI_DID_INTEL_MTL_SOC_PCIE_RP2,
PCI_DID_INTEL_MTL_SOC_PCIE_RP3,
PCI_DID_INTEL_MTL_SOC_PCIE_RP4,
PCI_DID_INTEL_MTL_SOC_PCIE_RP5,
PCI_DID_INTEL_MTL_SOC_PCIE_RP6,
PCI_DID_INTEL_MTL_SOC_PCIE_RP7,
PCI_DID_INTEL_MTL_SOC_PCIE_RP8,
PCI_DID_INTEL_MTL_SOC_PCIE_RP9,
PCI_DID_INTEL_MTL_IOE_P_PCIE_RP10,
PCI_DID_INTEL_MTL_IOE_P_PCIE_RP11,
PCI_DID_INTEL_MTL_IOE_P_PCIE_RP12,
PCI_DID_INTEL_LWB_PCIE_RP1,
PCI_DID_INTEL_LWB_PCIE_RP2,
PCI_DID_INTEL_LWB_PCIE_RP3,
PCI_DID_INTEL_LWB_PCIE_RP4,
PCI_DID_INTEL_LWB_PCIE_RP5,
PCI_DID_INTEL_LWB_PCIE_RP6,
PCI_DID_INTEL_LWB_PCIE_RP7,
PCI_DID_INTEL_LWB_PCIE_RP8,
PCI_DID_INTEL_LWB_PCIE_RP9,
PCI_DID_INTEL_LWB_PCIE_RP10,
PCI_DID_INTEL_LWB_PCIE_RP11,
PCI_DID_INTEL_LWB_PCIE_RP12,
PCI_DID_INTEL_LWB_PCIE_RP13,
PCI_DID_INTEL_LWB_PCIE_RP14,
PCI_DID_INTEL_LWB_PCIE_RP15,
PCI_DID_INTEL_LWB_PCIE_RP16,
PCI_DID_INTEL_LWB_PCIE_RP17,
PCI_DID_INTEL_LWB_PCIE_RP18,
PCI_DID_INTEL_LWB_PCIE_RP19,
PCI_DID_INTEL_LWB_PCIE_RP20,
PCI_DID_INTEL_LWB_PCIE_RP1_SUPER,
PCI_DID_INTEL_LWB_PCIE_RP2_SUPER,
PCI_DID_INTEL_LWB_PCIE_RP3_SUPER,
PCI_DID_INTEL_LWB_PCIE_RP4_SUPER,
PCI_DID_INTEL_LWB_PCIE_RP5_SUPER,
PCI_DID_INTEL_LWB_PCIE_RP6_SUPER,
PCI_DID_INTEL_LWB_PCIE_RP7_SUPER,
PCI_DID_INTEL_LWB_PCIE_RP8_SUPER,
PCI_DID_INTEL_LWB_PCIE_RP9_SUPER,
PCI_DID_INTEL_LWB_PCIE_RP10_SUPER,
PCI_DID_INTEL_LWB_PCIE_RP11_SUPER,
PCI_DID_INTEL_LWB_PCIE_RP12_SUPER,
PCI_DID_INTEL_LWB_PCIE_RP13_SUPER,
PCI_DID_INTEL_LWB_PCIE_RP14_SUPER,
PCI_DID_INTEL_LWB_PCIE_RP15_SUPER,
PCI_DID_INTEL_LWB_PCIE_RP16_SUPER,
PCI_DID_INTEL_LWB_PCIE_RP17_SUPER,
PCI_DID_INTEL_LWB_PCIE_RP18_SUPER,
PCI_DID_INTEL_LWB_PCIE_RP19_SUPER,
PCI_DID_INTEL_LWB_PCIE_RP20_SUPER,
PCI_DID_INTEL_CNL_LP_PCIE_RP1,
PCI_DID_INTEL_CNL_LP_PCIE_RP2,
PCI_DID_INTEL_CNL_LP_PCIE_RP3,
PCI_DID_INTEL_CNL_LP_PCIE_RP4,
PCI_DID_INTEL_CNL_LP_PCIE_RP5,
PCI_DID_INTEL_CNL_LP_PCIE_RP6,
PCI_DID_INTEL_CNL_LP_PCIE_RP7,
PCI_DID_INTEL_CNL_LP_PCIE_RP8,
PCI_DID_INTEL_CNL_LP_PCIE_RP9,
PCI_DID_INTEL_CNL_LP_PCIE_RP10,
PCI_DID_INTEL_CNL_LP_PCIE_RP11,
PCI_DID_INTEL_CNL_LP_PCIE_RP12,
PCI_DID_INTEL_CNL_LP_PCIE_RP13,
PCI_DID_INTEL_CNL_LP_PCIE_RP14,
PCI_DID_INTEL_CNL_LP_PCIE_RP15,
PCI_DID_INTEL_CNL_LP_PCIE_RP16,
PCI_DID_INTEL_CNP_H_PCIE_RP1,
PCI_DID_INTEL_CNP_H_PCIE_RP2,
PCI_DID_INTEL_CNP_H_PCIE_RP3,
PCI_DID_INTEL_CNP_H_PCIE_RP4,
PCI_DID_INTEL_CNP_H_PCIE_RP5,
PCI_DID_INTEL_CNP_H_PCIE_RP6,
PCI_DID_INTEL_CNP_H_PCIE_RP7,
PCI_DID_INTEL_CNP_H_PCIE_RP8,
PCI_DID_INTEL_CNP_H_PCIE_RP9,
PCI_DID_INTEL_CNP_H_PCIE_RP10,
PCI_DID_INTEL_CNP_H_PCIE_RP11,
PCI_DID_INTEL_CNP_H_PCIE_RP12,
PCI_DID_INTEL_CNP_H_PCIE_RP13,
PCI_DID_INTEL_CNP_H_PCIE_RP14,
PCI_DID_INTEL_CNP_H_PCIE_RP15,
PCI_DID_INTEL_CNP_H_PCIE_RP16,
PCI_DID_INTEL_CNP_H_PCIE_RP17,
PCI_DID_INTEL_CNP_H_PCIE_RP18,
PCI_DID_INTEL_CNP_H_PCIE_RP19,
PCI_DID_INTEL_CNP_H_PCIE_RP20,
PCI_DID_INTEL_CNP_H_PCIE_RP21,
PCI_DID_INTEL_CNP_H_PCIE_RP22,
PCI_DID_INTEL_CNP_H_PCIE_RP23,
PCI_DID_INTEL_CNP_H_PCIE_RP24,
PCI_DID_INTEL_ICP_LP_PCIE_RP1,
PCI_DID_INTEL_ICP_LP_PCIE_RP2,
PCI_DID_INTEL_ICP_LP_PCIE_RP3,
PCI_DID_INTEL_ICP_LP_PCIE_RP4,
PCI_DID_INTEL_ICP_LP_PCIE_RP5,
PCI_DID_INTEL_ICP_LP_PCIE_RP6,
PCI_DID_INTEL_ICP_LP_PCIE_RP7,
PCI_DID_INTEL_ICP_LP_PCIE_RP8,
PCI_DID_INTEL_ICP_LP_PCIE_RP9,
PCI_DID_INTEL_ICP_LP_PCIE_RP10,
PCI_DID_INTEL_ICP_LP_PCIE_RP11,
PCI_DID_INTEL_ICP_LP_PCIE_RP12,
PCI_DID_INTEL_ICP_LP_PCIE_RP13,
PCI_DID_INTEL_ICP_LP_PCIE_RP14,
PCI_DID_INTEL_ICP_LP_PCIE_RP15,
PCI_DID_INTEL_ICP_LP_PCIE_RP16,
PCI_DID_INTEL_CMP_LP_PCIE_RP1,
PCI_DID_INTEL_CMP_LP_PCIE_RP2,
PCI_DID_INTEL_CMP_LP_PCIE_RP3,
PCI_DID_INTEL_CMP_LP_PCIE_RP4,
PCI_DID_INTEL_CMP_LP_PCIE_RP5,
PCI_DID_INTEL_CMP_LP_PCIE_RP6,
PCI_DID_INTEL_CMP_LP_PCIE_RP7,
PCI_DID_INTEL_CMP_LP_PCIE_RP8,
PCI_DID_INTEL_CMP_LP_PCIE_RP9,
PCI_DID_INTEL_CMP_LP_PCIE_RP10,
PCI_DID_INTEL_CMP_LP_PCIE_RP11,
PCI_DID_INTEL_CMP_LP_PCIE_RP12,
PCI_DID_INTEL_CMP_LP_PCIE_RP13,
PCI_DID_INTEL_CMP_LP_PCIE_RP14,
PCI_DID_INTEL_CMP_LP_PCIE_RP15,
PCI_DID_INTEL_CMP_LP_PCIE_RP16,
PCI_DID_INTEL_CMP_H_PCIE_RP1,
PCI_DID_INTEL_CMP_H_PCIE_RP2,
PCI_DID_INTEL_CMP_H_PCIE_RP3,
PCI_DID_INTEL_CMP_H_PCIE_RP4,
PCI_DID_INTEL_CMP_H_PCIE_RP5,
PCI_DID_INTEL_CMP_H_PCIE_RP6,
PCI_DID_INTEL_CMP_H_PCIE_RP7,
PCI_DID_INTEL_CMP_H_PCIE_RP8,
PCI_DID_INTEL_CMP_H_PCIE_RP9,
PCI_DID_INTEL_CMP_H_PCIE_RP10,
PCI_DID_INTEL_CMP_H_PCIE_RP11,
PCI_DID_INTEL_CMP_H_PCIE_RP12,
PCI_DID_INTEL_CMP_H_PCIE_RP13,
PCI_DID_INTEL_CMP_H_PCIE_RP14,
PCI_DID_INTEL_CMP_H_PCIE_RP15,
PCI_DID_INTEL_CMP_H_PCIE_RP16,
PCI_DID_INTEL_CMP_H_PCIE_RP17,
PCI_DID_INTEL_CMP_H_PCIE_RP18,
PCI_DID_INTEL_CMP_H_PCIE_RP19,
PCI_DID_INTEL_CMP_H_PCIE_RP20,
PCI_DID_INTEL_CMP_H_PCIE_RP21,
PCI_DID_INTEL_CMP_H_PCIE_RP22,
PCI_DID_INTEL_CMP_H_PCIE_RP23,
PCI_DID_INTEL_CMP_H_PCIE_RP24,
PCI_DID_INTEL_TGP_LP_PCIE_RP1,
PCI_DID_INTEL_TGP_LP_PCIE_RP2,
PCI_DID_INTEL_TGP_LP_PCIE_RP3,
PCI_DID_INTEL_TGP_LP_PCIE_RP4,
PCI_DID_INTEL_TGP_LP_PCIE_RP5,
PCI_DID_INTEL_TGP_LP_PCIE_RP6,
PCI_DID_INTEL_TGP_LP_PCIE_RP7,
PCI_DID_INTEL_TGP_LP_PCIE_RP8,
PCI_DID_INTEL_TGP_LP_PCIE_RP9,
PCI_DID_INTEL_TGP_LP_PCIE_RP10,
PCI_DID_INTEL_TGP_LP_PCIE_RP11,
PCI_DID_INTEL_TGP_LP_PCIE_RP12,
PCI_DID_INTEL_TGP_LP_PCIE_RP13,
PCI_DID_INTEL_TGP_LP_PCIE_RP14,
PCI_DID_INTEL_TGP_LP_PCIE_RP15,
PCI_DID_INTEL_TGP_LP_PCIE_RP16,
PCI_DID_INTEL_TGP_H_PCIE_RP1,
PCI_DID_INTEL_TGP_H_PCIE_RP2,
PCI_DID_INTEL_TGP_H_PCIE_RP3,
PCI_DID_INTEL_TGP_H_PCIE_RP4,
PCI_DID_INTEL_TGP_H_PCIE_RP5,
PCI_DID_INTEL_TGP_H_PCIE_RP6,
PCI_DID_INTEL_TGP_H_PCIE_RP7,
PCI_DID_INTEL_TGP_H_PCIE_RP8,
PCI_DID_INTEL_TGP_H_PCIE_RP9,
PCI_DID_INTEL_TGP_H_PCIE_RP10,
PCI_DID_INTEL_TGP_H_PCIE_RP11,
PCI_DID_INTEL_TGP_H_PCIE_RP12,
PCI_DID_INTEL_TGP_H_PCIE_RP13,
PCI_DID_INTEL_TGP_H_PCIE_RP14,
PCI_DID_INTEL_TGP_H_PCIE_RP15,
PCI_DID_INTEL_TGP_H_PCIE_RP16,
PCI_DID_INTEL_TGP_H_PCIE_RP17,
PCI_DID_INTEL_TGP_H_PCIE_RP18,
PCI_DID_INTEL_TGP_H_PCIE_RP19,
PCI_DID_INTEL_TGP_H_PCIE_RP20,
PCI_DID_INTEL_TGP_H_PCIE_RP21,
PCI_DID_INTEL_TGP_H_PCIE_RP22,
PCI_DID_INTEL_TGP_H_PCIE_RP23,
PCI_DID_INTEL_TGP_H_PCIE_RP24,
PCI_DID_INTEL_MCC_PCIE_RP1,
PCI_DID_INTEL_MCC_PCIE_RP2,
PCI_DID_INTEL_MCC_PCIE_RP3,
PCI_DID_INTEL_MCC_PCIE_RP4,
PCI_DID_INTEL_MCC_PCIE_RP5,
PCI_DID_INTEL_MCC_PCIE_RP6,
PCI_DID_INTEL_MCC_PCIE_RP7,
PCI_DID_INTEL_JSP_PCIE_RP1,
PCI_DID_INTEL_JSP_PCIE_RP2,
PCI_DID_INTEL_JSP_PCIE_RP3,
PCI_DID_INTEL_JSP_PCIE_RP4,
PCI_DID_INTEL_JSP_PCIE_RP5,
PCI_DID_INTEL_JSP_PCIE_RP6,
PCI_DID_INTEL_JSP_PCIE_RP7,
PCI_DID_INTEL_JSP_PCIE_RP8,
PCI_DID_INTEL_ADL_P_PCIE_RP1,
PCI_DID_INTEL_ADL_P_PCIE_RP2,
PCI_DID_INTEL_ADL_P_PCIE_RP3,
PCI_DID_INTEL_ADP_P_PCIE_RP1,
PCI_DID_INTEL_ADP_P_PCIE_RP2,
PCI_DID_INTEL_ADP_P_PCIE_RP3,
PCI_DID_INTEL_ADP_P_PCIE_RP4,
PCI_DID_INTEL_ADP_P_PCIE_RP5,
PCI_DID_INTEL_ADP_P_PCIE_RP6,
PCI_DID_INTEL_ADP_P_PCIE_RP7,
PCI_DID_INTEL_ADP_P_PCIE_RP8,
PCI_DID_INTEL_ADP_P_PCIE_RP9,
PCI_DID_INTEL_ADP_P_PCIE_RP10,
PCI_DID_INTEL_ADP_P_PCIE_RP11,
PCI_DID_INTEL_ADP_P_PCIE_RP12,
PCI_DID_INTEL_ADP_S_PCIE_RP1,
PCI_DID_INTEL_ADP_S_PCIE_RP2,
PCI_DID_INTEL_ADP_S_PCIE_RP3,
PCI_DID_INTEL_ADP_S_PCIE_RP4,
PCI_DID_INTEL_ADP_S_PCIE_RP5,
PCI_DID_INTEL_ADP_S_PCIE_RP6,
PCI_DID_INTEL_ADP_S_PCIE_RP7,
PCI_DID_INTEL_ADP_S_PCIE_RP8,
PCI_DID_INTEL_ADP_S_PCIE_RP9,
PCI_DID_INTEL_ADP_S_PCIE_RP10,
PCI_DID_INTEL_ADP_S_PCIE_RP11,
PCI_DID_INTEL_ADP_S_PCIE_RP12,
PCI_DID_INTEL_ADP_S_PCIE_RP13,
PCI_DID_INTEL_ADP_S_PCIE_RP14,
PCI_DID_INTEL_ADP_S_PCIE_RP15,
PCI_DID_INTEL_ADP_S_PCIE_RP16,
PCI_DID_INTEL_ADP_S_PCIE_RP17,
PCI_DID_INTEL_ADP_S_PCIE_RP18,
PCI_DID_INTEL_ADP_S_PCIE_RP19,
PCI_DID_INTEL_ADP_S_PCIE_RP20,
PCI_DID_INTEL_ADP_S_PCIE_RP21,
PCI_DID_INTEL_ADP_S_PCIE_RP22,
PCI_DID_INTEL_ADP_S_PCIE_RP23,
PCI_DID_INTEL_ADP_S_PCIE_RP24,
PCI_DID_INTEL_ADP_S_PCIE_RP25,
PCI_DID_INTEL_ADP_S_PCIE_RP26,
PCI_DID_INTEL_ADP_S_PCIE_RP27,
PCI_DID_INTEL_ADP_S_PCIE_RP28,
PCI_DID_INTEL_ADP_M_N_PCIE_RP1,
PCI_DID_INTEL_ADP_M_N_PCIE_RP2,
PCI_DID_INTEL_ADP_M_N_PCIE_RP3,
PCI_DID_INTEL_ADP_M_N_PCIE_RP4,
PCI_DID_INTEL_ADP_M_PCIE_RP5,
PCI_DID_INTEL_ADP_M_PCIE_RP6,
PCI_DID_INTEL_ADP_M_N_PCIE_RP7,
PCI_DID_INTEL_ADP_M_PCIE_RP8,
PCI_DID_INTEL_ADP_M_N_PCIE_RP9,
PCI_DID_INTEL_ADP_M_N_PCIE_RP10,
PCI_DID_INTEL_ADP_N_PCIE_RP11,
PCI_DID_INTEL_ADP_N_PCIE_RP12,
0
};
static const struct pci_driver pch_pcie __pci_driver = {
.ops = &pcie_rp_ops,
.vendor = PCI_VID_INTEL,
.devices = pcie_device_ids,
};