diff options
author | Ard Biesheuvel <ardb@kernel.org> | 2021-01-09 10:53:53 +0100 |
---|---|---|
committer | Bjorn Helgaas <bhelgaas@google.com> | 2021-01-12 16:39:52 -0600 |
commit | 729e3a669d1b62e9876a671ac03ccba399a23b68 (patch) | |
tree | 68bd6e8b1ad6c4e5d683ab5363ab5701dce8312d /drivers/pci/setup-res.c | |
parent | 7c53f6b671f4aba70ff15e1b05148b10d58c2837 (diff) | |
download | linux-stable-729e3a669d1b62e9876a671ac03ccba399a23b68.tar.gz linux-stable-729e3a669d1b62e9876a671ac03ccba399a23b68.tar.bz2 linux-stable-729e3a669d1b62e9876a671ac03ccba399a23b68.zip |
PCI: Decline to resize resources if boot config must be preserved
The _DSM #5 method in the ACPI host bridge object tells us whether the OS
must preserve the resource assignments done by firmware. If this is the
case, we should not permit drivers to resize BARs on the fly. Make
pci_resize_resource() take this into account.
Link: https://lore.kernel.org/r/20210109095353.13417-1-ardb@kernel.org
Signed-off-by: Ard Biesheuvel <ardb@kernel.org>
Signed-off-by: Bjorn Helgaas <bhelgaas@google.com>
Cc: stable@vger.kernel.org # v5.4+
Diffstat (limited to 'drivers/pci/setup-res.c')
-rw-r--r-- | drivers/pci/setup-res.c | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/drivers/pci/setup-res.c b/drivers/pci/setup-res.c index 43eda101fcf4..7f1acb3918d0 100644 --- a/drivers/pci/setup-res.c +++ b/drivers/pci/setup-res.c @@ -410,10 +410,16 @@ EXPORT_SYMBOL(pci_release_resource); int pci_resize_resource(struct pci_dev *dev, int resno, int size) { struct resource *res = dev->resource + resno; + struct pci_host_bridge *host; int old, ret; u32 sizes; u16 cmd; + /* Check if we must preserve the firmware's resource assignment */ + host = pci_find_host_bridge(dev->bus); + if (host->preserve_config) + return -ENOTSUPP; + /* Make sure the resource isn't assigned before resizing it. */ if (!(res->flags & IORESOURCE_UNSET)) return -EBUSY; |