/* SPDX-License-Identifier: GPL-2.0-only */ #include #include #include #include #include #include #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, }; static struct device_operations device_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_DEVICE_ID_INTEL_SPT_LP_PCIE_RP1, PCI_DEVICE_ID_INTEL_SPT_LP_PCIE_RP2, PCI_DEVICE_ID_INTEL_SPT_LP_PCIE_RP3, PCI_DEVICE_ID_INTEL_SPT_LP_PCIE_RP4, PCI_DEVICE_ID_INTEL_SPT_LP_PCIE_RP5, PCI_DEVICE_ID_INTEL_SPT_LP_PCIE_RP6, PCI_DEVICE_ID_INTEL_SPT_LP_PCIE_RP7, PCI_DEVICE_ID_INTEL_SPT_LP_PCIE_RP8, PCI_DEVICE_ID_INTEL_SPT_LP_PCIE_RP9, PCI_DEVICE_ID_INTEL_SPT_LP_PCIE_RP10, PCI_DEVICE_ID_INTEL_SPT_LP_PCIE_RP11, PCI_DEVICE_ID_INTEL_SPT_LP_PCIE_RP12, PCI_DEVICE_ID_INTEL_SPT_H_PCIE_RP1, PCI_DEVICE_ID_INTEL_SPT_H_PCIE_RP2, PCI_DEVICE_ID_INTEL_SPT_H_PCIE_RP3, PCI_DEVICE_ID_INTEL_SPT_H_PCIE_RP4, PCI_DEVICE_ID_INTEL_SPT_H_PCIE_RP5, PCI_DEVICE_ID_INTEL_SPT_H_PCIE_RP6, PCI_DEVICE_ID_INTEL_SPT_H_PCIE_RP7, PCI_DEVICE_ID_INTEL_SPT_H_PCIE_RP8, PCI_DEVICE_ID_INTEL_SPT_H_PCIE_RP9, PCI_DEVICE_ID_INTEL_SPT_H_PCIE_RP10, PCI_DEVICE_ID_INTEL_SPT_H_PCIE_RP11, PCI_DEVICE_ID_INTEL_SPT_H_PCIE_RP12, PCI_DEVICE_ID_INTEL_SPT_H_PCIE_RP13, PCI_DEVICE_ID_INTEL_SPT_H_PCIE_RP14, PCI_DEVICE_ID_INTEL_SPT_H_PCIE_RP15, PCI_DEVICE_ID_INTEL_SPT_H_PCIE_RP16, PCI_DEVICE_ID_INTEL_SPT_H_PCIE_RP17, PCI_DEVICE_ID_INTEL_SPT_H_PCIE_RP18, PCI_DEVICE_ID_INTEL_SPT_H_PCIE_RP19, PCI_DEVICE_ID_INTEL_SPT_H_PCIE_RP20, PCI_DEVICE_ID_INTEL_LWB_PCIE_RP1, PCI_DEVICE_ID_INTEL_LWB_PCIE_RP2, PCI_DEVICE_ID_INTEL_LWB_PCIE_RP3, PCI_DEVICE_ID_INTEL_LWB_PCIE_RP4, PCI_DEVICE_ID_INTEL_LWB_PCIE_RP5, PCI_DEVICE_ID_INTEL_LWB_PCIE_RP6, PCI_DEVICE_ID_INTEL_LWB_PCIE_RP7, PCI_DEVICE_ID_INTEL_LWB_PCIE_RP8, PCI_DEVICE_ID_INTEL_LWB_PCIE_RP9, PCI_DEVICE_ID_INTEL_LWB_PCIE_RP10, PCI_DEVICE_ID_INTEL_LWB_PCIE_RP11, PCI_DEVICE_ID_INTEL_LWB_PCIE_RP12, PCI_DEVICE_ID_INTEL_LWB_PCIE_RP13, PCI_DEVICE_ID_INTEL_LWB_PCIE_RP14, PCI_DEVICE_ID_INTEL_LWB_PCIE_RP15, PCI_DEVICE_ID_INTEL_LWB_PCIE_RP16, PCI_DEVICE_ID_INTEL_LWB_PCIE_RP17, PCI_DEVICE_ID_INTEL_LWB_PCIE_RP18, PCI_DEVICE_ID_INTEL_LWB_PCIE_RP19, PCI_DEVICE_ID_INTEL_LWB_PCIE_RP20, PCI_DEVICE_ID_INTEL_LWB_PCIE_RP1_SUPER, PCI_DEVICE_ID_INTEL_LWB_PCIE_RP2_SUPER, PCI_DEVICE_ID_INTEL_LWB_PCIE_RP3_SUPER, PCI_DEVICE_ID_INTEL_LWB_PCIE_RP4_SUPER, PCI_DEVICE_ID_INTEL_LWB_PCIE_RP5_SUPER, PCI_DEVICE_ID_INTEL_LWB_PCIE_RP6_SUPER, PCI_DEVICE_ID_INTEL_LWB_PCIE_RP7_SUPER, PCI_DEVICE_ID_INTEL_LWB_PCIE_RP8_SUPER, PCI_DEVICE_ID_INTEL_LWB_PCIE_RP9_SUPER, PCI_DEVICE_ID_INTEL_LWB_PCIE_RP10_SUPER, PCI_DEVICE_ID_INTEL_LWB_PCIE_RP11_SUPER, PCI_DEVICE_ID_INTEL_LWB_PCIE_RP12_SUPER, PCI_DEVICE_ID_INTEL_LWB_PCIE_RP13_SUPER, PCI_DEVICE_ID_INTEL_LWB_PCIE_RP14_SUPER, PCI_DEVICE_ID_INTEL_LWB_PCIE_RP15_SUPER, PCI_DEVICE_ID_INTEL_LWB_PCIE_RP16_SUPER, PCI_DEVICE_ID_INTEL_LWB_PCIE_RP17_SUPER, PCI_DEVICE_ID_INTEL_LWB_PCIE_RP18_SUPER, PCI_DEVICE_ID_INTEL_LWB_PCIE_RP19_SUPER, PCI_DEVICE_ID_INTEL_LWB_PCIE_RP20_SUPER, PCI_DEVICE_ID_INTEL_KBP_H_PCIE_RP1, PCI_DEVICE_ID_INTEL_KBP_H_PCIE_RP2, PCI_DEVICE_ID_INTEL_KBP_H_PCIE_RP3, PCI_DEVICE_ID_INTEL_KBP_H_PCIE_RP4, PCI_DEVICE_ID_INTEL_KBP_H_PCIE_RP5, PCI_DEVICE_ID_INTEL_KBP_H_PCIE_RP6, PCI_DEVICE_ID_INTEL_KBP_H_PCIE_RP7, PCI_DEVICE_ID_INTEL_KBP_H_PCIE_RP8, PCI_DEVICE_ID_INTEL_KBP_H_PCIE_RP9, PCI_DEVICE_ID_INTEL_KBP_H_PCIE_RP10, PCI_DEVICE_ID_INTEL_KBP_H_PCIE_RP11, PCI_DEVICE_ID_INTEL_KBP_H_PCIE_RP12, PCI_DEVICE_ID_INTEL_KBP_H_PCIE_RP13, PCI_DEVICE_ID_INTEL_KBP_H_PCIE_RP14, PCI_DEVICE_ID_INTEL_KBP_H_PCIE_RP15, PCI_DEVICE_ID_INTEL_KBP_H_PCIE_RP16, PCI_DEVICE_ID_INTEL_KBP_H_PCIE_RP17, PCI_DEVICE_ID_INTEL_KBP_H_PCIE_RP18, PCI_DEVICE_ID_INTEL_KBP_H_PCIE_RP19, PCI_DEVICE_ID_INTEL_KBP_H_PCIE_RP20, PCI_DEVICE_ID_INTEL_KBP_H_PCIE_RP21, PCI_DEVICE_ID_INTEL_KBP_H_PCIE_RP22, PCI_DEVICE_ID_INTEL_KBP_H_PCIE_RP23, PCI_DEVICE_ID_INTEL_KBP_H_PCIE_RP24, PCI_DEVICE_ID_INTEL_CNL_LP_PCIE_RP1, PCI_DEVICE_ID_INTEL_CNL_LP_PCIE_RP2, PCI_DEVICE_ID_INTEL_CNL_LP_PCIE_RP3, PCI_DEVICE_ID_INTEL_CNL_LP_PCIE_RP4, PCI_DEVICE_ID_INTEL_CNL_LP_PCIE_RP5, PCI_DEVICE_ID_INTEL_CNL_LP_PCIE_RP6, PCI_DEVICE_ID_INTEL_CNL_LP_PCIE_RP7, PCI_DEVICE_ID_INTEL_CNL_LP_PCIE_RP8, PCI_DEVICE_ID_INTEL_CNL_LP_PCIE_RP9, PCI_DEVICE_ID_INTEL_CNL_LP_PCIE_RP10, PCI_DEVICE_ID_INTEL_CNL_LP_PCIE_RP11, PCI_DEVICE_ID_INTEL_CNL_LP_PCIE_RP12, PCI_DEVICE_ID_INTEL_CNL_LP_PCIE_RP13, PCI_DEVICE_ID_INTEL_CNL_LP_PCIE_RP14, PCI_DEVICE_ID_INTEL_CNL_LP_PCIE_RP15, PCI_DEVICE_ID_INTEL_CNL_LP_PCIE_RP16, PCI_DEVICE_ID_INTEL_CNP_H_PCIE_RP1, PCI_DEVICE_ID_INTEL_CNP_H_PCIE_RP2, PCI_DEVICE_ID_INTEL_CNP_H_PCIE_RP3, PCI_DEVICE_ID_INTEL_CNP_H_PCIE_RP4, PCI_DEVICE_ID_INTEL_CNP_H_PCIE_RP5, PCI_DEVICE_ID_INTEL_CNP_H_PCIE_RP6, PCI_DEVICE_ID_INTEL_CNP_H_PCIE_RP7, PCI_DEVICE_ID_INTEL_CNP_H_PCIE_RP8, PCI_DEVICE_ID_INTEL_CNP_H_PCIE_RP9, PCI_DEVICE_ID_INTEL_CNP_H_PCIE_RP10, PCI_DEVICE_ID_INTEL_CNP_H_PCIE_RP11, PCI_DEVICE_ID_INTEL_CNP_H_PCIE_RP12, PCI_DEVICE_ID_INTEL_CNP_H_PCIE_RP13, PCI_DEVICE_ID_INTEL_CNP_H_PCIE_RP14, PCI_DEVICE_ID_INTEL_CNP_H_PCIE_RP15, PCI_DEVICE_ID_INTEL_CNP_H_PCIE_RP16, PCI_DEVICE_ID_INTEL_CNP_H_PCIE_RP17, PCI_DEVICE_ID_INTEL_CNP_H_PCIE_RP18, PCI_DEVICE_ID_INTEL_CNP_H_PCIE_RP19, PCI_DEVICE_ID_INTEL_CNP_H_PCIE_RP20, PCI_DEVICE_ID_INTEL_CNP_H_PCIE_RP21, PCI_DEVICE_ID_INTEL_CNP_H_PCIE_RP22, PCI_DEVICE_ID_INTEL_CNP_H_PCIE_RP23, PCI_DEVICE_ID_INTEL_CNP_H_PCIE_RP24, PCI_DEVICE_ID_INTEL_ICP_LP_PCIE_RP1, PCI_DEVICE_ID_INTEL_ICP_LP_PCIE_RP2, PCI_DEVICE_ID_INTEL_ICP_LP_PCIE_RP3, PCI_DEVICE_ID_INTEL_ICP_LP_PCIE_RP4, PCI_DEVICE_ID_INTEL_ICP_LP_PCIE_RP5, PCI_DEVICE_ID_INTEL_ICP_LP_PCIE_RP6, PCI_DEVICE_ID_INTEL_ICP_LP_PCIE_RP7, PCI_DEVICE_ID_INTEL_ICP_LP_PCIE_RP8, PCI_DEVICE_ID_INTEL_ICP_LP_PCIE_RP9, PCI_DEVICE_ID_INTEL_ICP_LP_PCIE_RP10, PCI_DEVICE_ID_INTEL_ICP_LP_PCIE_RP11, PCI_DEVICE_ID_INTEL_ICP_LP_PCIE_RP12, PCI_DEVICE_ID_INTEL_ICP_LP_PCIE_RP13, PCI_DEVICE_ID_INTEL_ICP_LP_PCIE_RP14, PCI_DEVICE_ID_INTEL_ICP_LP_PCIE_RP15, PCI_DEVICE_ID_INTEL_ICP_LP_PCIE_RP16, PCI_DEVICE_ID_INTEL_CMP_LP_PCIE_RP1, PCI_DEVICE_ID_INTEL_CMP_LP_PCIE_RP2, PCI_DEVICE_ID_INTEL_CMP_LP_PCIE_RP3, PCI_DEVICE_ID_INTEL_CMP_LP_PCIE_RP4, PCI_DEVICE_ID_INTEL_CMP_LP_PCIE_RP5, PCI_DEVICE_ID_INTEL_CMP_LP_PCIE_RP6, PCI_DEVICE_ID_INTEL_CMP_LP_PCIE_RP7, PCI_DEVICE_ID_INTEL_CMP_LP_PCIE_RP8, PCI_DEVICE_ID_INTEL_CMP_LP_PCIE_RP9, PCI_DEVICE_ID_INTEL_CMP_LP_PCIE_RP10, PCI_DEVICE_ID_INTEL_CMP_LP_PCIE_RP11, PCI_DEVICE_ID_INTEL_CMP_LP_PCIE_RP12, PCI_DEVICE_ID_INTEL_CMP_LP_PCIE_RP13, PCI_DEVICE_ID_INTEL_CMP_LP_PCIE_RP14, PCI_DEVICE_ID_INTEL_CMP_LP_PCIE_RP15, PCI_DEVICE_ID_INTEL_CMP_LP_PCIE_RP16, PCI_DEVICE_ID_INTEL_CMP_H_PCIE_RP1, PCI_DEVICE_ID_INTEL_CMP_H_PCIE_RP2, PCI_DEVICE_ID_INTEL_CMP_H_PCIE_RP3, PCI_DEVICE_ID_INTEL_CMP_H_PCIE_RP4, PCI_DEVICE_ID_INTEL_CMP_H_PCIE_RP5, PCI_DEVICE_ID_INTEL_CMP_H_PCIE_RP6, PCI_DEVICE_ID_INTEL_CMP_H_PCIE_RP7, PCI_DEVICE_ID_INTEL_CMP_H_PCIE_RP8, PCI_DEVICE_ID_INTEL_CMP_H_PCIE_RP9, PCI_DEVICE_ID_INTEL_CMP_H_PCIE_RP10, PCI_DEVICE_ID_INTEL_CMP_H_PCIE_RP11, PCI_DEVICE_ID_INTEL_CMP_H_PCIE_RP12, PCI_DEVICE_ID_INTEL_CMP_H_PCIE_RP13, PCI_DEVICE_ID_INTEL_CMP_H_PCIE_RP14, PCI_DEVICE_ID_INTEL_CMP_H_PCIE_RP15, PCI_DEVICE_ID_INTEL_CMP_H_PCIE_RP16, PCI_DEVICE_ID_INTEL_CMP_H_PCIE_RP17, PCI_DEVICE_ID_INTEL_CMP_H_PCIE_RP18, PCI_DEVICE_ID_INTEL_CMP_H_PCIE_RP19, PCI_DEVICE_ID_INTEL_CMP_H_PCIE_RP20, PCI_DEVICE_ID_INTEL_CMP_H_PCIE_RP21, PCI_DEVICE_ID_INTEL_CMP_H_PCIE_RP22, PCI_DEVICE_ID_INTEL_CMP_H_PCIE_RP23, PCI_DEVICE_ID_INTEL_CMP_H_PCIE_RP24, PCI_DEVICE_ID_INTEL_TGP_LP_PCIE_RP1, PCI_DEVICE_ID_INTEL_TGP_LP_PCIE_RP2, PCI_DEVICE_ID_INTEL_TGP_LP_PCIE_RP3, PCI_DEVICE_ID_INTEL_TGP_LP_PCIE_RP4, PCI_DEVICE_ID_INTEL_TGP_LP_PCIE_RP5, PCI_DEVICE_ID_INTEL_TGP_LP_PCIE_RP6, PCI_DEVICE_ID_INTEL_TGP_LP_PCIE_RP7, PCI_DEVICE_ID_INTEL_TGP_LP_PCIE_RP8, PCI_DEVICE_ID_INTEL_TGP_LP_PCIE_RP9, PCI_DEVICE_ID_INTEL_TGP_LP_PCIE_RP10, PCI_DEVICE_ID_INTEL_TGP_LP_PCIE_RP11, PCI_DEVICE_ID_INTEL_TGP_LP_PCIE_RP12, PCI_DEVICE_ID_INTEL_TGP_LP_PCIE_RP13, PCI_DEVICE_ID_INTEL_TGP_LP_PCIE_RP14, PCI_DEVICE_ID_INTEL_TGP_LP_PCIE_RP15, PCI_DEVICE_ID_INTEL_TGP_LP_PCIE_RP16, PCI_DEVICE_ID_INTEL_MCC_PCIE_RP1, PCI_DEVICE_ID_INTEL_MCC_PCIE_RP2, PCI_DEVICE_ID_INTEL_MCC_PCIE_RP3, PCI_DEVICE_ID_INTEL_MCC_PCIE_RP4, PCI_DEVICE_ID_INTEL_MCC_PCIE_RP5, PCI_DEVICE_ID_INTEL_MCC_PCIE_RP6, PCI_DEVICE_ID_INTEL_MCC_PCIE_RP7, PCI_DEVICE_ID_INTEL_JSP_PCIE_RP1, PCI_DEVICE_ID_INTEL_JSP_PCIE_RP2, PCI_DEVICE_ID_INTEL_JSP_PCIE_RP3, PCI_DEVICE_ID_INTEL_JSP_PCIE_RP4, PCI_DEVICE_ID_INTEL_JSP_PCIE_RP5, PCI_DEVICE_ID_INTEL_JSP_PCIE_RP6, PCI_DEVICE_ID_INTEL_JSP_PCIE_RP7, PCI_DEVICE_ID_INTEL_JSP_PCIE_RP8, PCI_DEVICE_ID_INTEL_ADP_P_PCIE_RP1, PCI_DEVICE_ID_INTEL_ADP_P_PCIE_RP2, PCI_DEVICE_ID_INTEL_ADP_P_PCIE_RP3, PCI_DEVICE_ID_INTEL_ADP_P_PCIE_RP4, PCI_DEVICE_ID_INTEL_ADP_P_PCIE_RP5, PCI_DEVICE_ID_INTEL_ADP_P_PCIE_RP6, PCI_DEVICE_ID_INTEL_ADP_P_PCIE_RP7, PCI_DEVICE_ID_INTEL_ADP_P_PCIE_RP8, PCI_DEVICE_ID_INTEL_ADP_P_PCIE_RP9, PCI_DEVICE_ID_INTEL_ADP_P_PCIE_RP10, PCI_DEVICE_ID_INTEL_ADP_P_PCIE_RP11, PCI_DEVICE_ID_INTEL_ADP_P_PCIE_RP12, PCI_DEVICE_ID_INTEL_ADP_S_PCIE_RP1, PCI_DEVICE_ID_INTEL_ADP_S_PCIE_RP2, PCI_DEVICE_ID_INTEL_ADP_S_PCIE_RP3, PCI_DEVICE_ID_INTEL_ADP_S_PCIE_RP4, PCI_DEVICE_ID_INTEL_ADP_S_PCIE_RP5, PCI_DEVICE_ID_INTEL_ADP_S_PCIE_RP6, PCI_DEVICE_ID_INTEL_ADP_S_PCIE_RP7, PCI_DEVICE_ID_INTEL_ADP_S_PCIE_RP8, PCI_DEVICE_ID_INTEL_ADP_S_PCIE_RP9, PCI_DEVICE_ID_INTEL_ADP_S_PCIE_RP10, PCI_DEVICE_ID_INTEL_ADP_S_PCIE_RP11, PCI_DEVICE_ID_INTEL_ADP_S_PCIE_RP12, PCI_DEVICE_ID_INTEL_ADP_S_PCIE_RP13, PCI_DEVICE_ID_INTEL_ADP_S_PCIE_RP14, PCI_DEVICE_ID_INTEL_ADP_S_PCIE_RP15, PCI_DEVICE_ID_INTEL_ADP_S_PCIE_RP16, PCI_DEVICE_ID_INTEL_ADP_S_PCIE_RP17, PCI_DEVICE_ID_INTEL_ADP_S_PCIE_RP18, PCI_DEVICE_ID_INTEL_ADP_S_PCIE_RP19, PCI_DEVICE_ID_INTEL_ADP_S_PCIE_RP20, PCI_DEVICE_ID_INTEL_ADP_S_PCIE_RP21, PCI_DEVICE_ID_INTEL_ADP_S_PCIE_RP22, PCI_DEVICE_ID_INTEL_ADP_S_PCIE_RP23, PCI_DEVICE_ID_INTEL_ADP_S_PCIE_RP24, PCI_DEVICE_ID_INTEL_ADP_S_PCIE_RP25, PCI_DEVICE_ID_INTEL_ADP_S_PCIE_RP26, PCI_DEVICE_ID_INTEL_ADP_S_PCIE_RP27, PCI_DEVICE_ID_INTEL_ADP_S_PCIE_RP28, PCI_DEVICE_ID_INTEL_ADP_M_PCIE_RP1, PCI_DEVICE_ID_INTEL_ADP_M_PCIE_RP2, PCI_DEVICE_ID_INTEL_ADP_M_PCIE_RP3, PCI_DEVICE_ID_INTEL_ADP_M_PCIE_RP4, PCI_DEVICE_ID_INTEL_ADP_M_PCIE_RP5, PCI_DEVICE_ID_INTEL_ADP_M_PCIE_RP6, PCI_DEVICE_ID_INTEL_ADP_M_PCIE_RP7, PCI_DEVICE_ID_INTEL_ADP_M_PCIE_RP8, PCI_DEVICE_ID_INTEL_ADP_M_PCIE_RP9, PCI_DEVICE_ID_INTEL_ADP_M_PCIE_RP10, 0 }; static const struct pci_driver pch_pcie __pci_driver = { .ops = &device_ops, .vendor = PCI_VENDOR_ID_INTEL, .devices = pcie_device_ids, };