]> www.infradead.org Git - users/hch/misc.git/commitdiff
PCI: tegra194: Fix broken tegra_pcie_ep_raise_msi_irq()
authorNiklas Cassel <cassel@kernel.org>
Mon, 22 Sep 2025 14:08:24 +0000 (16:08 +0200)
committerManivannan Sadhasivam <mani@kernel.org>
Wed, 24 Sep 2025 16:20:19 +0000 (21:50 +0530)
The pci_epc_raise_irq() supplies a MSI or MSI-X interrupt number in range
(1-N), as per the pci_epc_raise_irq() kdoc, where N is 32 for MSI.

But tegra_pcie_ep_raise_msi_irq() incorrectly uses the interrupt number as
the MSI vector. This causes wrong MSI vector to be triggered, leading to
the failure of PCI endpoint Kselftest MSI_TEST test case.

To fix this issue, convert the interrupt number to MSI vector.

Fixes: c57247f940e8 ("PCI: tegra: Add support for PCIe endpoint mode in Tegra194")
Signed-off-by: Niklas Cassel <cassel@kernel.org>
Signed-off-by: Manivannan Sadhasivam <mani@kernel.org>
Cc: stable@vger.kernel.org
Link: https://patch.msgid.link/20250922140822.519796-6-cassel@kernel.org
drivers/pci/controller/dwc/pcie-tegra194.c

index 0e413857649fd01c6a3d4dedfe54b2f6c7466f8d..a00d5b9cd8717e8886b4da9411cfa30dedac6141 100644 (file)
@@ -1955,10 +1955,10 @@ static int tegra_pcie_ep_raise_intx_irq(struct tegra_pcie_dw *pcie, u16 irq)
 
 static int tegra_pcie_ep_raise_msi_irq(struct tegra_pcie_dw *pcie, u16 irq)
 {
-       if (unlikely(irq > 31))
+       if (unlikely(irq > 32))
                return -EINVAL;
 
-       appl_writel(pcie, BIT(irq), APPL_MSI_CTRL_1);
+       appl_writel(pcie, BIT(irq - 1), APPL_MSI_CTRL_1);
 
        return 0;
 }