]> www.infradead.org Git - users/dwmw2/linux.git/commitdiff
PCI: Fix pci_add_dma_alias() bitmask size
authorJames Sewart <jamessewart@arista.com>
Tue, 10 Dec 2019 21:51:33 +0000 (15:51 -0600)
committerBjorn Helgaas <bhelgaas@google.com>
Wed, 18 Dec 2019 18:21:16 +0000 (12:21 -0600)
The number of possible devfns is 256, but pci_add_dma_alias() allocated a
bitmap of size 255.  Fix this off-by-one error.

This fixes commits 338c3149a221 ("PCI: Add support for multiple DMA
aliases") and c6635792737b ("PCI: Allocate dma_alias_mask with
bitmap_zalloc()"), but I doubt it was possible to see a problem because
it takes 4 64-bit longs (or 8 32-bit longs) to hold 255 bits, and
bitmap_zalloc() doesn't save the 255-bit size anywhere.

[bhelgaas: commit log, move #define to drivers/pci/pci.h, include loop
limit fix from Qian Cai:
https://lore.kernel.org/r/20191218170004.5297-1-cai@lca.pw]
Signed-off-by: James Sewart <jamessewart@arista.com>
Signed-off-by: Bjorn Helgaas <bhelgaas@google.com>
Reviewed-by: Logan Gunthorpe <logang@deltatee.com>
drivers/pci/pci.c
drivers/pci/pci.h
drivers/pci/search.c

index e87196cc1a7fba33d37661ad0f73ca1dd1418583..7b5fa2eabe0951cf29069d034dd7421ea2fbb584 100644 (file)
@@ -6017,7 +6017,7 @@ EXPORT_SYMBOL_GPL(pci_pr3_present);
 void pci_add_dma_alias(struct pci_dev *dev, u8 devfn)
 {
        if (!dev->dma_alias_mask)
-               dev->dma_alias_mask = bitmap_zalloc(U8_MAX, GFP_KERNEL);
+               dev->dma_alias_mask = bitmap_zalloc(MAX_NR_DEVFNS, GFP_KERNEL);
        if (!dev->dma_alias_mask) {
                pci_warn(dev, "Unable to allocate DMA alias mask\n");
                return;
index a0a53bd05a0b8602f9fac6c0ca218f01b3ba3c28..6394e7746fb54217e6caa37abb690449686dad30 100644 (file)
@@ -4,6 +4,9 @@
 
 #include <linux/pci.h>
 
+/* Number of possible devfns: 0.0 to 1f.7 inclusive */
+#define MAX_NR_DEVFNS 256
+
 #define PCI_FIND_CAP_TTL       48
 
 #define PCI_VSEC_ID_INTEL_TBT  0x1234  /* Thunderbolt */
index bade14002fd8ad9afa5f3910458d4b3fcd9ea924..e4dbdef5aef05018b585375e57a0e2db0bd431d7 100644 (file)
@@ -41,9 +41,9 @@ int pci_for_each_dma_alias(struct pci_dev *pdev,
         * DMA, iterate over that too.
         */
        if (unlikely(pdev->dma_alias_mask)) {
-               u8 devfn;
+               unsigned int devfn;
 
-               for_each_set_bit(devfn, pdev->dma_alias_mask, U8_MAX) {
+               for_each_set_bit(devfn, pdev->dma_alias_mask, MAX_NR_DEVFNS) {
                        ret = fn(pdev, PCI_DEVID(pdev->bus->number, devfn),
                                 data);
                        if (ret)