PCI: mvebu: Handle invalid size of read config request
authorPali Rohár <pali@kernel.org>
Thu, 25 Nov 2021 12:45:54 +0000 (13:45 +0100)
committerLorenzo Pieralisi <lorenzo.pieralisi@arm.com>
Tue, 4 Jan 2022 14:58:35 +0000 (14:58 +0000)
Function mvebu_pcie_hw_rd_conf() does not handle invalid size. So correctly
set read value to all-ones and return appropriate error return value
PCIBIOS_BAD_REGISTER_NUMBER like in mvebu_pcie_hw_wr_conf() function.

Link: https://lore.kernel.org/r/20211125124605.25915-5-pali@kernel.org
Signed-off-by: Pali Rohár <pali@kernel.org>
Signed-off-by: Lorenzo Pieralisi <lorenzo.pieralisi@arm.com>
drivers/pci/controller/pci-mvebu.c

index 2a2100c..8388a9c 100644 (file)
@@ -250,6 +250,9 @@ static int mvebu_pcie_hw_rd_conf(struct mvebu_pcie_port *port,
        case 4:
                *val = readl_relaxed(conf_data);
                break;
+       default:
+               *val = 0xffffffff;
+               return PCIBIOS_BAD_REGISTER_NUMBER;
        }
 
        return PCIBIOS_SUCCESSFUL;