[PATCH V3] bcma: use device from DT (brcm, bus-chipcommon) for SoC GPIO chip
Arnd Bergmann
arnd at arndb.de
Tue Sep 30 03:36:28 PDT 2014
On Tuesday 30 September 2014 12:22:26 Rafał Miłecki wrote:
>
> +The top-level axi bus may contain children representing attached cores
> +(devices). This is needed since some hardware details can't be auto
> +detected (e.g. IRQ numbers). Also some of the cores may be responsible
> +for extra things, e.g. ChipCommon providing access to the GPIO chip.
> +
> Example:
>
> axi at 18000000 {
> @@ -17,4 +22,12 @@ Example:
> ranges = <0x00000000 0x18000000 0x00100000>;
> #address-cells = <1>;
> #size-cells = <1>;
> +
> + chipcommon {
> + compatible = "brcm,bus-chipcommon";
> + reg = <0x00000000 0x1000>;
> +
> + gpio-controller;
> + #gpio-cells = <2>;
> + };
> };
Looks good.
> diff --git a/drivers/bcma/driver_gpio.c b/drivers/bcma/driver_gpio.c
> index 8ea497c..28bdbe5 100644
> --- a/drivers/bcma/driver_gpio.c
> +++ b/drivers/bcma/driver_gpio.c
> @@ -218,6 +218,12 @@ int bcma_gpio_init(struct bcma_drv_cc *cc)
> #if IS_BUILTIN(CONFIG_BCM47XX)
> chip->to_irq = bcma_gpio_to_irq;
> #endif
> +#if IS_BUILTIN(CONFIG_OF)
> + if (cc->core->bus->hosttype == BCMA_HOSTTYPE_SOC)
> + chip->of_node = of_find_compatible_node(
> + bus->host_pdev->dev.of_node, NULL,
> + "brcm,bus-chipcommon");
> +#endif
> switch (cc->core->bus->chipinfo.id) {
This doesn't: you are now searching through all nodes starting at the
axi node rather than searching just through the children.
I think it would be better with the first change in place to set
chip->of_node to cc->core->dev.of_node, and set that pointer in
bcma_bus_scan by matching the 'reg' number. I think that is what
an earlier version of the bcma DT support did in order to find the
IRQs. We no longer need it for that purpose, but it seems like a
good idea anyway, as I expect other bcma_devices to have similar
requirements to add additional properties.
Arnd
More information about the linux-arm-kernel
mailing list