gpio: pci-idio-16: Fix PCI BAR index
authorWilliam Breathitt Gray <vilhelm.gray@gmail.com>
Wed, 8 Feb 2017 13:32:46 +0000 (08:32 -0500)
committerLinus Walleij <linus.walleij@linaro.org>
Mon, 13 Feb 2017 15:19:10 +0000 (16:19 +0100)
The PCI BAR0 and BAR1 for the PCI-IDIO-16 hold information for the PLX
9052 bridge chip on the device. The PCI BAR2 holds the necessary base
address for I/O control of the PCI-IDIO-16. This patch corrects the PCI
BAR index mismatch for the PCI-IDIO-16 GPIO driver.

Fixes: 02e74fc0401a ("gpio: Add GPIO support for the ACCES PCI-IDIO-16")
Signed-off-by: William Breathitt Gray <vilhelm.gray@gmail.com>
Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
drivers/gpio/gpio-pci-idio-16.c

index b10f3cf7044ae125c9079a2bc038067c5b3fbea2..269ab628634b2b35e2fbbf8a475a04c1c6c30d5c 100644 (file)
@@ -265,6 +265,7 @@ static int idio_16_probe(struct pci_dev *pdev, const struct pci_device_id *id)
        struct device *const dev = &pdev->dev;
        struct idio_16_gpio *idio16gpio;
        int err;
+       const size_t pci_bar_index = 2;
        const char *const name = pci_name(pdev);
 
        idio16gpio = devm_kzalloc(dev, sizeof(*idio16gpio), GFP_KERNEL);
@@ -277,13 +278,13 @@ static int idio_16_probe(struct pci_dev *pdev, const struct pci_device_id *id)
                return err;
        }
 
-       err = pcim_iomap_regions(pdev, 0x1, name);
+       err = pcim_iomap_regions(pdev, BIT(pci_bar_index), name);
        if (err) {
                dev_err(dev, "Unable to map PCI I/O addresses (%d)\n", err);
                return err;
        }
 
-       idio16gpio->reg = pcim_iomap_table(pdev)[0];
+       idio16gpio->reg = pcim_iomap_table(pdev)[pci_bar_index];
 
        /* Deactivate input filters */
        iowrite8(0, &idio16gpio->reg->filter_ctl);