1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586 |
- --- a/drivers/bcma/driver_gpio.c
- +++ b/drivers/bcma/driver_gpio.c
- @@ -226,6 +226,7 @@ int bcma_gpio_init(struct bcma_drv_cc *c
- chip->of_node = cc->core->dev.of_node;
- #endif
- switch (bus->chipinfo.id) {
- + case BCMA_CHIP_ID_BCM4707:
- case BCMA_CHIP_ID_BCM5357:
- case BCMA_CHIP_ID_BCM53572:
- chip->ngpio = 32;
- @@ -235,16 +236,17 @@ int bcma_gpio_init(struct bcma_drv_cc *c
- }
-
- /*
- - * On MIPS we register GPIO devices (LEDs, buttons) using absolute GPIO
- - * pin numbers. We don't have Device Tree there and we can't really use
- - * relative (per chip) numbers.
- - * So let's use predictable base for BCM47XX and "random" for all other.
- + * Register SoC GPIO devices with absolute GPIO pin base.
- + * On MIPS, we don't have Device Tree and we can't use relative (per chip)
- + * GPIO numbers.
- + * On some ARM devices, user space may want to access some system GPIO
- + * pins directly, which is easier to do with a predictable GPIO base.
- */
- -#if IS_BUILTIN(CONFIG_BCM47XX)
- - chip->base = bus->num * BCMA_GPIO_MAX_PINS;
- -#else
- - chip->base = -1;
- -#endif
- + if (IS_BUILTIN(CONFIG_BCM47XX) ||
- + cc->core->bus->hosttype == BCMA_HOSTTYPE_SOC)
- + chip->base = bus->num * BCMA_GPIO_MAX_PINS;
- + else
- + chip->base = -1;
-
- err = bcma_gpio_irq_domain_init(cc);
- if (err)
- --- a/drivers/bcma/Kconfig
- +++ b/drivers/bcma/Kconfig
- @@ -29,12 +29,6 @@ config BCMA_HOST_PCI
- select BCMA_DRIVER_PCI
- default y
-
- -config BCMA_DRIVER_PCI_HOSTMODE
- - bool "Driver for PCI core working in hostmode"
- - depends on BCMA && MIPS && BCMA_HOST_PCI
- - help
- - PCI core hostmode operation (external PCI bus).
- -
- config BCMA_HOST_SOC
- bool "Support for BCMA in a SoC"
- depends on BCMA
- @@ -61,6 +55,12 @@ config BCMA_DRIVER_PCI
- This driver is also prerequisite for a hostmode PCIe core
- support.
-
- +config BCMA_DRIVER_PCI_HOSTMODE
- + bool "Driver for PCI core working in hostmode"
- + depends on BCMA && MIPS && BCMA_DRIVER_PCI
- + help
- + PCI core hostmode operation (external PCI bus).
- +
- config BCMA_DRIVER_MIPS
- bool "BCMA Broadcom MIPS core driver"
- depends on BCMA && MIPS
- --- a/include/linux/bcma/bcma_driver_pci.h
- +++ b/include/linux/bcma/bcma_driver_pci.h
- @@ -246,7 +246,18 @@ static inline void bcma_core_pci_power_s
- }
- #endif
-
- +#ifdef CONFIG_BCMA_DRIVER_PCI_HOSTMODE
- extern int bcma_core_pci_pcibios_map_irq(const struct pci_dev *dev);
- extern int bcma_core_pci_plat_dev_init(struct pci_dev *dev);
- +#else
- +static inline int bcma_core_pci_pcibios_map_irq(const struct pci_dev *dev)
- +{
- + return -ENOTSUPP;
- +}
- +static inline int bcma_core_pci_plat_dev_init(struct pci_dev *dev)
- +{
- + return -ENOTSUPP;
- +}
- +#endif
-
- #endif /* LINUX_BCMA_DRIVER_PCI_H_ */
|