2014-09-26 05:09:19 +07:00
|
|
|
Driver for ARM AXI Bus with Broadcom Plugins (bcma)
|
|
|
|
|
|
|
|
Required properties:
|
|
|
|
|
|
|
|
- compatible : brcm,bus-axi
|
|
|
|
|
|
|
|
- reg : iomem address range of chipcommon core
|
|
|
|
|
|
|
|
The cores on the AXI bus are automatically detected by bcma with the
|
|
|
|
memory ranges they are using and they get registered afterwards.
|
2014-11-01 22:54:56 +07:00
|
|
|
Automatic detection of the IRQ number is not working on
|
|
|
|
BCM47xx/BCM53xx ARM SoCs. To assign IRQ numbers to the cores, provide
|
|
|
|
them manually through device tree. Use an interrupt-map to specify the
|
|
|
|
IRQ used by the devices on the bus. The first address is just an index,
|
|
|
|
because we do not have any special register.
|
2014-09-26 05:09:19 +07:00
|
|
|
|
2014-09-30 17:55:48 +07:00
|
|
|
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.
|
|
|
|
|
2014-09-26 05:09:19 +07:00
|
|
|
Example:
|
|
|
|
|
|
|
|
axi@18000000 {
|
|
|
|
compatible = "brcm,bus-axi";
|
|
|
|
reg = <0x18000000 0x1000>;
|
|
|
|
ranges = <0x00000000 0x18000000 0x00100000>;
|
|
|
|
#address-cells = <1>;
|
|
|
|
#size-cells = <1>;
|
2014-11-01 22:54:56 +07:00
|
|
|
#interrupt-cells = <1>;
|
|
|
|
interrupt-map-mask = <0x000fffff 0xffff>;
|
|
|
|
interrupt-map =
|
|
|
|
/* Ethernet Controller 0 */
|
|
|
|
<0x00024000 0 &gic GIC_SPI 147 IRQ_TYPE_LEVEL_HIGH>,
|
|
|
|
|
|
|
|
/* Ethernet Controller 1 */
|
|
|
|
<0x00025000 0 &gic GIC_SPI 148 IRQ_TYPE_LEVEL_HIGH>;
|
|
|
|
|
|
|
|
/* PCIe Controller 0 */
|
|
|
|
<0x00012000 0 &gic GIC_SPI 126 IRQ_TYPE_LEVEL_HIGH>,
|
|
|
|
<0x00012000 1 &gic GIC_SPI 127 IRQ_TYPE_LEVEL_HIGH>,
|
|
|
|
<0x00012000 2 &gic GIC_SPI 128 IRQ_TYPE_LEVEL_HIGH>,
|
|
|
|
<0x00012000 3 &gic GIC_SPI 129 IRQ_TYPE_LEVEL_HIGH>,
|
|
|
|
<0x00012000 4 &gic GIC_SPI 130 IRQ_TYPE_LEVEL_HIGH>,
|
|
|
|
<0x00012000 5 &gic GIC_SPI 131 IRQ_TYPE_LEVEL_HIGH>;
|
2014-09-30 17:55:48 +07:00
|
|
|
|
|
|
|
chipcommon {
|
|
|
|
reg = <0x00000000 0x1000>;
|
|
|
|
|
|
|
|
gpio-controller;
|
|
|
|
#gpio-cells = <2>;
|
|
|
|
};
|
2014-09-26 05:09:19 +07:00
|
|
|
};
|