]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
PCI: cadence: Check for the existence of cdns_pcie::ops before using it
authorChen Wang <unicorn_wang@outlook.com>
Fri, 12 Sep 2025 02:36:01 +0000 (10:36 +0800)
committerManivannan Sadhasivam <mani@kernel.org>
Fri, 19 Sep 2025 18:09:38 +0000 (23:39 +0530)
cdns_pcie::ops might not be populated by all the Cadence glue drivers. This
is going to be true for the upcoming Sophgo platform which doesn't set the
ops.

Hence, add a check to prevent NULL pointer dereference.

Signed-off-by: Chen Wang <unicorn_wang@outlook.com>
[mani: reworded subject and description]
Signed-off-by: Manivannan Sadhasivam <mani@kernel.org>
Link: https://patch.msgid.link/35182ee1d972dfcd093a964e11205efcebbdc044.1757643388.git.unicorn_wang@outlook.com
drivers/pci/controller/cadence/pcie-cadence-host.c
drivers/pci/controller/cadence/pcie-cadence.c
drivers/pci/controller/cadence/pcie-cadence.h

index 59a4631de79fe857844755b0f5bb0d4d7993b651..fffd63d6665e8127a9e21df99c41436f98b82b96 100644 (file)
@@ -531,7 +531,7 @@ static int cdns_pcie_host_init_address_translation(struct cdns_pcie_rc *rc)
        cdns_pcie_writel(pcie, CDNS_PCIE_AT_OB_REGION_PCI_ADDR1(0), addr1);
        cdns_pcie_writel(pcie, CDNS_PCIE_AT_OB_REGION_DESC1(0), desc1);
 
-       if (pcie->ops->cpu_addr_fixup)
+       if (pcie->ops && pcie->ops->cpu_addr_fixup)
                cpu_addr = pcie->ops->cpu_addr_fixup(pcie, cpu_addr);
 
        addr0 = CDNS_PCIE_AT_OB_REGION_CPU_ADDR0_NBITS(12) |
index 70a19573440ee9fc0ea78310505a25830cc45247..61806bbd8aa3260f99e4329d893320a4a25250f1 100644 (file)
@@ -92,7 +92,7 @@ void cdns_pcie_set_outbound_region(struct cdns_pcie *pcie, u8 busnr, u8 fn,
        cdns_pcie_writel(pcie, CDNS_PCIE_AT_OB_REGION_DESC1(r), desc1);
 
        /* Set the CPU address */
-       if (pcie->ops->cpu_addr_fixup)
+       if (pcie->ops && pcie->ops->cpu_addr_fixup)
                cpu_addr = pcie->ops->cpu_addr_fixup(pcie, cpu_addr);
 
        addr0 = CDNS_PCIE_AT_OB_REGION_CPU_ADDR0_NBITS(nbits) |
@@ -123,7 +123,7 @@ void cdns_pcie_set_outbound_region_for_normal_msg(struct cdns_pcie *pcie,
        }
 
        /* Set the CPU address */
-       if (pcie->ops->cpu_addr_fixup)
+       if (pcie->ops && pcie->ops->cpu_addr_fixup)
                cpu_addr = pcie->ops->cpu_addr_fixup(pcie, cpu_addr);
 
        addr0 = CDNS_PCIE_AT_OB_REGION_CPU_ADDR0_NBITS(17) |
index 1d81c4bf6c6db7844816f01490e53f3a3d6b8c27..2f07ba661bda78d3392fb2a8167c1a6d23314539 100644 (file)
@@ -468,7 +468,7 @@ static inline u32 cdns_pcie_ep_fn_readl(struct cdns_pcie *pcie, u8 fn, u32 reg)
 
 static inline int cdns_pcie_start_link(struct cdns_pcie *pcie)
 {
-       if (pcie->ops->start_link)
+       if (pcie->ops && pcie->ops->start_link)
                return pcie->ops->start_link(pcie);
 
        return 0;
@@ -476,13 +476,13 @@ static inline int cdns_pcie_start_link(struct cdns_pcie *pcie)
 
 static inline void cdns_pcie_stop_link(struct cdns_pcie *pcie)
 {
-       if (pcie->ops->stop_link)
+       if (pcie->ops && pcie->ops->stop_link)
                pcie->ops->stop_link(pcie);
 }
 
 static inline bool cdns_pcie_link_up(struct cdns_pcie *pcie)
 {
-       if (pcie->ops->link_up)
+       if (pcie->ops && pcie->ops->link_up)
                return pcie->ops->link_up(pcie);
 
        return true;