]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
PCI: dwc: ep: Enforce DWC specific 64-bit BAR limitation
authorNiklas Cassel <cassel@kernel.org>
Tue, 28 May 2024 13:48:40 +0000 (15:48 +0200)
committerBjorn Helgaas <bhelgaas@google.com>
Tue, 9 Jul 2024 23:21:39 +0000 (18:21 -0500)
From the DWC EP databook 5.96a, section "3.5.7.1.4 General Rules for BAR
Setup (Fixed Mask or Programmable Mask Schemes Only)":

"Any pair (for example BARs 0 and 1) can be configured as one 64-bit BAR,
two 32-bit BARs, or one 32-bit BAR."

"BAR pairs cannot overlap to form a 64-bit BAR. For example, you cannot
combine BARs 1 and 2 to form a 64-bit BAR."

While this limitation does exist in some other PCI endpoint controllers,
e.g. cdns_pcie_ep_set_bar(), the limitation does not appear to be defined
in the PCIe specification itself, thus add an explicit check for this in
dw_pcie_ep_set_bar() (rather than pci_epc_set_bar()).

Link: https://lore.kernel.org/linux-pci/20240528134839.8817-2-cassel@kernel.org
Signed-off-by: Niklas Cassel <cassel@kernel.org>
Signed-off-by: Krzysztof WilczyƄski <kwilczynski@kernel.org>
Signed-off-by: Bjorn Helgaas <bhelgaas@google.com>
Reviewed-by: Manivannan Sadhasivam <manivannan.sadhasivam@linaro.org>
drivers/pci/controller/dwc/pcie-designware-ep.c

index bdbdd099405a15da95fdd5a1aef8e75d4e120e99..43ba5c6738df1a534dc827ab0bf4cb52fd0e40d3 100644 (file)
@@ -215,6 +215,13 @@ static int dw_pcie_ep_set_bar(struct pci_epc *epc, u8 func_no, u8 vfunc_no,
        int ret, type;
        u32 reg;
 
+       /*
+        * DWC does not allow BAR pairs to overlap, e.g. you cannot combine BARs
+        * 1 and 2 to form a 64-bit BAR.
+        */
+       if ((flags & PCI_BASE_ADDRESS_MEM_TYPE_64) && (bar & 1))
+               return -EINVAL;
+
        reg = PCI_BASE_ADDRESS_0 + (4 * bar);
 
        if (!(flags & PCI_BASE_ADDRESS_SPACE))