PCI: Add defines for normal and subtractive PCI bridges
authorPali Rohár <pali@kernel.org>
Mon, 14 Feb 2022 11:41:08 +0000 (12:41 +0100)
committerBjorn Helgaas <bhelgaas@google.com>
Thu, 17 Feb 2022 21:29:35 +0000 (15:29 -0600)
Add these PCI class codes to pci_ids.h:

  PCI_CLASS_BRIDGE_PCI_NORMAL
  PCI_CLASS_BRIDGE_PCI_SUBTRACTIVE

Use these defines in all kernel code for describing PCI class codes for
normal and subtractive PCI bridges.

[bhelgaas: similar change in pci-mvebu.c]
Link: https://lore.kernel.org/r/20220214114109.26809-1-pali@kernel.org
Signed-off-by: Pali Rohár <pali@kernel.org>
Signed-off-by: Bjorn Helgaas <bhelgaas@google.com>
24 files changed:
arch/mips/include/asm/mach-bcm63xx/bcm63xx_regs.h
arch/mips/pci/fixup-sb1250.c
arch/mips/pci/pci-bcm63xx.c
arch/powerpc/platforms/powernv/pci.c
arch/powerpc/sysdev/fsl_pci.c
arch/sh/drivers/pci/pcie-sh7786.c
drivers/pci/controller/dwc/pci-keystone.c
drivers/pci/controller/dwc/pci-meson.c
drivers/pci/controller/dwc/pcie-qcom.c
drivers/pci/controller/mobiveil/pcie-mobiveil-host.c
drivers/pci/controller/pci-aardvark.c
drivers/pci/controller/pci-loongson.c
drivers/pci/controller/pci-mvebu.c
drivers/pci/controller/pci-tegra.c
drivers/pci/controller/pcie-iproc-bcma.c
drivers/pci/controller/pcie-iproc.c
drivers/pci/controller/pcie-mediatek-gen3.c
drivers/pci/controller/pcie-rcar-host.c
drivers/pci/controller/pcie-rockchip-host.c
drivers/pci/controller/pcie-rockchip.h
drivers/pci/hotplug/shpchp_core.c
drivers/pci/pci-bridge-emul.c
drivers/pci/pcie/portdrv_pci.c
include/linux/pci_ids.h

index 9ceb5e7..d3f397d 100644 (file)
 
 #define PCIE_IDVAL3_REG                        0x43c
 #define IDVAL3_CLASS_CODE_MASK         0xffffff
-#define IDVAL3_SUBCLASS_SHIFT          8
-#define IDVAL3_CLASS_SHIFT             16
 
 #define PCIE_DLSTATUS_REG              0x1048
 #define DLSTATUS_PHYLINKUP             (1 << 13)
index 40efc99..3f914c3 100644 (file)
@@ -75,7 +75,7 @@ DECLARE_PCI_FIXUP_FINAL(PCI_VENDOR_ID_SIBYTE, PCI_DEVICE_ID_BCM1250_PCI,
  */
 static void quirk_sb1250_ht(struct pci_dev *dev)
 {
-       dev->class = PCI_CLASS_BRIDGE_PCI << 8;
+       dev->class = PCI_CLASS_BRIDGE_PCI_NORMAL;
 }
 DECLARE_PCI_FIXUP_EARLY(PCI_VENDOR_ID_SIBYTE, PCI_DEVICE_ID_BCM1250_HT,
                        quirk_sb1250_ht);
index 5548365..ac83243 100644 (file)
@@ -186,7 +186,7 @@ static int __init bcm63xx_register_pcie(void)
        /* setup class code as bridge */
        val = bcm_pcie_readl(PCIE_IDVAL3_REG);
        val &= ~IDVAL3_CLASS_CODE_MASK;
-       val |= (PCI_CLASS_BRIDGE_PCI << IDVAL3_SUBCLASS_SHIFT);
+       val |= PCI_CLASS_BRIDGE_PCI_NORMAL;
        bcm_pcie_writel(val, PCIE_IDVAL3_REG);
 
        /* disable bar1 size */
index 9a8391b..f705487 100644 (file)
@@ -815,7 +815,7 @@ void pnv_pci_shutdown(void)
 /* Fixup wrong class code in p7ioc and p8 root complex */
 static void pnv_p7ioc_rc_quirk(struct pci_dev *dev)
 {
-       dev->class = PCI_CLASS_BRIDGE_PCI << 8;
+       dev->class = PCI_CLASS_BRIDGE_PCI_NORMAL;
 }
 DECLARE_PCI_FIXUP_EARLY(PCI_VENDOR_ID_IBM, 0x3b9, pnv_p7ioc_rc_quirk);
 
index 674f047..a97ce60 100644 (file)
@@ -55,7 +55,7 @@ static void quirk_fsl_pcie_early(struct pci_dev *dev)
        if ((hdr_type & 0x7f) != PCI_HEADER_TYPE_BRIDGE)
                return;
 
-       dev->class = PCI_CLASS_BRIDGE_PCI << 8;
+       dev->class = PCI_CLASS_BRIDGE_PCI_NORMAL;
        fsl_pcie_bus_fixup = 1;
        return;
 }
index 4d49947..b0c2a52 100644 (file)
@@ -314,7 +314,7 @@ static int __init pcie_init(struct sh7786_pcie_port *port)
         * class to match. Hardware takes care of propagating the IDSETR
         * settings, so there is no need to bother with a quirk.
         */
-       pci_write_reg(chan, PCI_CLASS_BRIDGE_PCI << 16, SH4A_PCIEIDSETR1);
+       pci_write_reg(chan, PCI_CLASS_BRIDGE_PCI_NORMAL << 8, SH4A_PCIEIDSETR1);
 
        /* Initialize default capabilities. */
        data = pci_read_reg(chan, SH4A_PCIEEXPCAP0);
index 1c2ee4e..d10e5fd 100644 (file)
@@ -531,13 +531,13 @@ static void ks_pcie_quirk(struct pci_dev *dev)
        struct pci_dev *bridge;
        static const struct pci_device_id rc_pci_devids[] = {
                { PCI_DEVICE(PCI_VENDOR_ID_TI, PCIE_RC_K2HK),
-                .class = PCI_CLASS_BRIDGE_PCI << 8, .class_mask = ~0, },
+                .class = PCI_CLASS_BRIDGE_PCI_NORMAL, .class_mask = ~0, },
                { PCI_DEVICE(PCI_VENDOR_ID_TI, PCIE_RC_K2E),
-                .class = PCI_CLASS_BRIDGE_PCI << 8, .class_mask = ~0, },
+                .class = PCI_CLASS_BRIDGE_PCI_NORMAL, .class_mask = ~0, },
                { PCI_DEVICE(PCI_VENDOR_ID_TI, PCIE_RC_K2L),
-                .class = PCI_CLASS_BRIDGE_PCI << 8, .class_mask = ~0, },
+                .class = PCI_CLASS_BRIDGE_PCI_NORMAL, .class_mask = ~0, },
                { PCI_DEVICE(PCI_VENDOR_ID_TI, PCIE_RC_K2G),
-                .class = PCI_CLASS_BRIDGE_PCI << 8, .class_mask = ~0, },
+                .class = PCI_CLASS_BRIDGE_PCI_NORMAL, .class_mask = ~0, },
                { 0, },
        };
 
index 686ded0..f44bf34 100644 (file)
@@ -313,14 +313,14 @@ static int meson_pcie_rd_own_conf(struct pci_bus *bus, u32 devfn,
         * cannot program the PCI_CLASS_DEVICE register, so we must fabricate
         * the return value in the config accessors.
         */
-       if (where == PCI_CLASS_REVISION && size == 4)
-               *val = (PCI_CLASS_BRIDGE_PCI << 16) | (*val & 0xffff);
-       else if (where == PCI_CLASS_DEVICE && size == 2)
-               *val = PCI_CLASS_BRIDGE_PCI;
-       else if (where == PCI_CLASS_DEVICE && size == 1)
-               *val = PCI_CLASS_BRIDGE_PCI & 0xff;
-       else if (where == PCI_CLASS_DEVICE + 1 && size == 1)
-               *val = (PCI_CLASS_BRIDGE_PCI >> 8) & 0xff;
+       if ((where & ~3) == PCI_CLASS_REVISION) {
+               if (size <= 2)
+                       *val = (*val & ((1 << (size * 8)) - 1)) << (8 * (where & 3));
+               *val &= ~0xffffff00;
+               *val |= PCI_CLASS_BRIDGE_PCI_NORMAL << 8;
+               if (size <= 2)
+                       *val = (*val >> (8 * (where & 3))) & ((1 << (size * 8)) - 1);
+       }
 
        return PCIBIOS_SUCCESSFUL;
 }
index c19cd50..a47f1c0 100644 (file)
@@ -1634,7 +1634,7 @@ static const struct of_device_id qcom_pcie_match[] = {
 
 static void qcom_fixup_class(struct pci_dev *dev)
 {
-       dev->class = PCI_CLASS_BRIDGE_PCI << 8;
+       dev->class = PCI_CLASS_BRIDGE_PCI_NORMAL;
 }
 DECLARE_PCI_FIXUP_EARLY(PCI_VENDOR_ID_QCOM, 0x0101, qcom_fixup_class);
 DECLARE_PCI_FIXUP_EARLY(PCI_VENDOR_ID_QCOM, 0x0104, qcom_fixup_class);
index f3547aa..31a7bde 100644 (file)
@@ -295,7 +295,7 @@ int mobiveil_host_init(struct mobiveil_pcie *pcie, bool reinit)
        /* fixup for PCIe class register */
        value = mobiveil_csr_readl(pcie, PAB_INTP_AXI_PIO_CLASS);
        value &= 0xff;
-       value |= (PCI_CLASS_BRIDGE_PCI << 16);
+       value |= PCI_CLASS_BRIDGE_PCI_NORMAL << 8;
        mobiveil_csr_writel(pcie, value, PAB_INTP_AXI_PIO_CLASS);
 
        return 0;
index 4f5b448..2561326 100644 (file)
@@ -529,7 +529,7 @@ static void advk_pcie_setup_hw(struct advk_pcie *pcie)
         */
        reg = advk_readl(pcie, PCIE_CORE_DEV_REV_REG);
        reg &= ~0xffffff00;
-       reg |= (PCI_CLASS_BRIDGE_PCI << 8) << 8;
+       reg |= PCI_CLASS_BRIDGE_PCI_NORMAL << 8;
        advk_writel(pcie, reg, PCIE_CORE_DEV_REV_REG);
 
        /* Disable Root Bridge I/O space, memory space and bus mastering */
index 48169b1..50a8e1d 100644 (file)
@@ -35,7 +35,7 @@ struct loongson_pci {
 /* Fixup wrong class code in PCIe bridges */
 static void bridge_class_quirk(struct pci_dev *dev)
 {
-       dev->class = PCI_CLASS_BRIDGE_PCI << 8;
+       dev->class = PCI_CLASS_BRIDGE_PCI_NORMAL;
 }
 DECLARE_PCI_FIXUP_EARLY(PCI_VENDOR_ID_LOONGSON,
                        DEV_PCIE_PORT_0, bridge_class_quirk);
index 71258ea..b0ec1c6 100644 (file)
@@ -268,7 +268,7 @@ static void mvebu_pcie_setup_hw(struct mvebu_pcie_port *port)
         */
        dev_rev = mvebu_readl(port, PCIE_DEV_REV_OFF);
        dev_rev &= ~0xffffff00;
-       dev_rev |= (PCI_CLASS_BRIDGE_PCI << 8) << 8;
+       dev_rev |= PCI_CLASS_BRIDGE_PCI_NORMAL << 8;
        mvebu_writel(port, dev_rev, PCIE_DEV_REV_OFF);
 
        /* Point PCIe unit MBUS decode windows to DRAM space. */
index cb0aa65..0457ec0 100644 (file)
@@ -726,7 +726,7 @@ static void tegra_pcie_port_free(struct tegra_pcie_port *port)
 /* Tegra PCIE root complex wrongly reports device class */
 static void tegra_pcie_fixup_class(struct pci_dev *dev)
 {
-       dev->class = PCI_CLASS_BRIDGE_PCI << 8;
+       dev->class = PCI_CLASS_BRIDGE_PCI_NORMAL;
 }
 DECLARE_PCI_FIXUP_EARLY(PCI_VENDOR_ID_NVIDIA, 0x0bf0, tegra_pcie_fixup_class);
 DECLARE_PCI_FIXUP_EARLY(PCI_VENDOR_ID_NVIDIA, 0x0bf1, tegra_pcie_fixup_class);
index 54b6e6d..99a9990 100644 (file)
@@ -18,7 +18,7 @@
 /* NS: CLASS field is R/O, and set to wrong 0x200 value */
 static void bcma_pcie2_fixup_class(struct pci_dev *dev)
 {
-       dev->class = PCI_CLASS_BRIDGE_PCI << 8;
+       dev->class = PCI_CLASS_BRIDGE_PCI_NORMAL;
 }
 DECLARE_PCI_FIXUP_EARLY(PCI_VENDOR_ID_BROADCOM, 0x8011, bcma_pcie2_fixup_class);
 DECLARE_PCI_FIXUP_EARLY(PCI_VENDOR_ID_BROADCOM, 0x8012, bcma_pcie2_fixup_class);
index b3e75bc..3df4ab2 100644 (file)
@@ -1581,7 +1581,7 @@ static void quirk_paxc_bridge(struct pci_dev *pdev)
         * code that the bridge is not an Ethernet device.
         */
        if (pdev->hdr_type == PCI_HEADER_TYPE_BRIDGE)
-               pdev->class = PCI_CLASS_BRIDGE_PCI << 8;
+               pdev->class = PCI_CLASS_BRIDGE_PCI_NORMAL;
 
        /*
         * MPSS is not being set properly (as it is currently 0).  This is
index 7705d61..3e8d70b 100644 (file)
@@ -292,7 +292,7 @@ static int mtk_pcie_startup_port(struct mtk_gen3_pcie *pcie)
        /* Set class code */
        val = readl_relaxed(pcie->base + PCIE_PCI_IDS_1);
        val &= ~GENMASK(31, 8);
-       val |= PCI_CLASS(PCI_CLASS_BRIDGE_PCI << 8);
+       val |= PCI_CLASS(PCI_CLASS_BRIDGE_PCI_NORMAL);
        writel_relaxed(val, pcie->base + PCIE_PCI_IDS_1);
 
        /* Mask all INTx interrupts */
index 38b6e02..dfca59c 100644 (file)
@@ -370,7 +370,7 @@ static int rcar_pcie_hw_init(struct rcar_pcie *pcie)
         * class to match. Hardware takes care of propagating the IDSETR
         * settings, so there is no need to bother with a quirk.
         */
-       rcar_pci_write_reg(pcie, PCI_CLASS_BRIDGE_PCI << 16, IDSETR1);
+       rcar_pci_write_reg(pcie, PCI_CLASS_BRIDGE_PCI_NORMAL << 8, IDSETR1);
 
        /*
         * Setup Secondary Bus Number & Subordinate Bus Number, even though
index 45a2888..7f56f99 100644 (file)
@@ -370,7 +370,7 @@ static int rockchip_pcie_host_init_port(struct rockchip_pcie *rockchip)
        rockchip_pcie_write(rockchip, ROCKCHIP_VENDOR_ID,
                            PCIE_CORE_CONFIG_VENDOR);
        rockchip_pcie_write(rockchip,
-                           PCI_CLASS_BRIDGE_PCI << PCIE_RC_CONFIG_SCC_SHIFT,
+                           PCI_CLASS_BRIDGE_PCI_NORMAL << 8,
                            PCIE_RC_CONFIG_RID_CCR);
 
        /* Clear THP cap's next cap pointer to remove L1 substate cap */
index 1650a50..32c3a85 100644 (file)
 #define PCIE_RC_CONFIG_NORMAL_BASE     0x800000
 #define PCIE_RC_CONFIG_BASE            0xa00000
 #define PCIE_RC_CONFIG_RID_CCR         (PCIE_RC_CONFIG_BASE + 0x08)
-#define   PCIE_RC_CONFIG_SCC_SHIFT             16
 #define PCIE_RC_CONFIG_DCR             (PCIE_RC_CONFIG_BASE + 0xc4)
 #define   PCIE_RC_CONFIG_DCR_CSPL_SHIFT                18
 #define   PCIE_RC_CONFIG_DCR_CSPL_LIMIT                0xff
index 81a918d..53692b0 100644 (file)
@@ -312,7 +312,7 @@ static void shpc_remove(struct pci_dev *dev)
 }
 
 static const struct pci_device_id shpcd_pci_tbl[] = {
-       {PCI_DEVICE_CLASS(((PCI_CLASS_BRIDGE_PCI << 8) | 0x00), ~0)},
+       {PCI_DEVICE_CLASS(PCI_CLASS_BRIDGE_PCI_NORMAL, ~0)},
        { /* end: all zeroes */ }
 };
 MODULE_DEVICE_TABLE(pci, shpcd_pci_tbl);
index c994ebe..ec6ab03 100644 (file)
@@ -328,10 +328,12 @@ int pci_bridge_emul_init(struct pci_bridge_emul *bridge,
        BUILD_BUG_ON(sizeof(bridge->conf) != PCI_BRIDGE_CONF_END);
 
        /*
-        * class_revision: Class is high 24 bits and revision is low 8 bit of this member,
-        * while class for PCI Bridge Normal Decode has the 24-bit value: PCI_CLASS_BRIDGE_PCI << 8
+        * class_revision: Class is high 24 bits and revision is low 8 bit
+        * of this member, while class for PCI Bridge Normal Decode has the
+        * 24-bit value: PCI_CLASS_BRIDGE_PCI_NORMAL
         */
-       bridge->conf.class_revision |= cpu_to_le32((PCI_CLASS_BRIDGE_PCI << 8) << 8);
+       bridge->conf.class_revision |=
+               cpu_to_le32(PCI_CLASS_BRIDGE_PCI_NORMAL << 8);
        bridge->conf.header_type = PCI_HEADER_TYPE_BRIDGE;
        bridge->conf.cache_line_size = 0x10;
        bridge->conf.status = cpu_to_le16(PCI_STATUS_CAP_LIST);
index 35eca62..4b88016 100644 (file)
@@ -178,9 +178,9 @@ static pci_ers_result_t pcie_portdrv_mmio_enabled(struct pci_dev *dev)
  */
 static const struct pci_device_id port_pci_ids[] = {
        /* handle any PCI-Express port */
-       { PCI_DEVICE_CLASS(((PCI_CLASS_BRIDGE_PCI << 8) | 0x00), ~0) },
+       { PCI_DEVICE_CLASS(PCI_CLASS_BRIDGE_PCI_NORMAL, ~0) },
        /* subtractive decode PCI-to-PCI bridge, class type is 060401h */
-       { PCI_DEVICE_CLASS(((PCI_CLASS_BRIDGE_PCI << 8) | 0x01), ~0) },
+       { PCI_DEVICE_CLASS(PCI_CLASS_BRIDGE_PCI_SUBTRACTIVE, ~0) },
        /* handle any Root Complex Event Collector */
        { PCI_DEVICE_CLASS(((PCI_CLASS_SYSTEM_RCEC << 8) | 0x00), ~0) },
        { },
index aad54c6..130949c 100644 (file)
@@ -60,6 +60,8 @@
 #define PCI_CLASS_BRIDGE_EISA          0x0602
 #define PCI_CLASS_BRIDGE_MC            0x0603
 #define PCI_CLASS_BRIDGE_PCI           0x0604
+#define PCI_CLASS_BRIDGE_PCI_NORMAL            0x060400
+#define PCI_CLASS_BRIDGE_PCI_SUBTRACTIVE       0x060401
 #define PCI_CLASS_BRIDGE_PCMCIA                0x0605
 #define PCI_CLASS_BRIDGE_NUBUS         0x0606
 #define PCI_CLASS_BRIDGE_CARDBUS       0x0607