1 // SPDX-License-Identifier: GPL-2.0
3 * Broadcom BCM63138 DSL SoCs Device Tree
6 #include <dt-bindings/interrupt-controller/arm-gic.h>
7 #include <dt-bindings/interrupt-controller/irq.h>
12 compatible = "brcm,bcm63138";
13 model = "Broadcom BCM63138 DSL SoC";
14 interrupt-parent = <&gic>;
27 compatible = "arm,cortex-a9";
28 next-level-cache = <&L2>;
30 enable-method = "brcm,bcm63138";
35 compatible = "arm,cortex-a9";
36 next-level-cache = <&L2>;
38 enable-method = "brcm,bcm63138";
44 /* UBUS peripheral clock */
45 periph_clk: periph_clk {
47 compatible = "fixed-clock";
48 clock-frequency = <50000000>;
49 clock-output-names = "periph";
52 /* peripheral clock for system timer */
55 compatible = "fixed-factor-clock";
64 compatible = "fixed-factor-clock";
73 compatible = "simple-bus";
74 ranges = <0 0x80000000 0x784000>;
78 L2: cache-controller@1d000 {
79 compatible = "arm,pl310-cache";
80 reg = <0x1d000 0x1000>;
83 cache-size = <524288>;
85 cache-line-size = <32>;
86 interrupts = <GIC_PPI 0 IRQ_TYPE_LEVEL_HIGH>;
90 compatible = "arm,cortex-a9-scu";
91 reg = <0x1e000 0x100>;
94 gic: interrupt-controller@1f000 {
95 compatible = "arm,cortex-a9-gic";
98 #interrupt-cells = <3>;
100 interrupt-controller;
103 global_timer: timer@1e200 {
104 compatible = "arm,cortex-a9-global-timer";
105 reg = <0x1e200 0x20>;
106 interrupts = <GIC_PPI 11 IRQ_TYPE_EDGE_RISING>;
110 local_timer: local-timer@1e600 {
111 compatible = "arm,cortex-a9-twd-timer";
112 reg = <0x1e600 0x20>;
113 interrupts = <GIC_PPI 13 (GIC_CPU_MASK_SIMPLE(2) |
114 IRQ_TYPE_EDGE_RISING)>;
118 twd_watchdog: watchdog@1e620 {
119 compatible = "arm,cortex-a9-twd-wdt";
120 reg = <0x1e620 0x20>;
121 interrupts = <GIC_PPI 14 (GIC_CPU_MASK_SIMPLE(2) |
122 IRQ_TYPE_LEVEL_HIGH)>;
125 armpll: armpll@20000 {
127 compatible = "brcm,bcm63138-armpll";
128 clocks = <&periph_clk>;
129 reg = <0x20000 0xf00>;
132 pmb0: reset-controller@4800c0 {
133 compatible = "brcm,bcm63138-pmb";
134 reg = <0x4800c0 0x10>;
138 pmb1: reset-controller@4800e0 {
139 compatible = "brcm,bcm63138-pmb";
140 reg = <0x4800e0 0x10>;
145 compatible = "brcm,bcm63138-ahci", "brcm,sata3-ahci";
146 reg-names = "ahci", "top-ctrl";
147 reg = <0xa000 0x9ac>, <0x8040 0x24>;
148 interrupts = <GIC_SPI 45 IRQ_TYPE_LEVEL_HIGH>;
149 #address-cells = <1>;
151 resets = <&pmb0 3 1>;
152 reset-names = "ahci";
161 sata_phy: sata-phy@8100 {
162 compatible = "brcm,bcm63138-sata-phy", "brcm,phy-sata3";
163 reg = <0x8100 0x1e00>;
165 #address-cells = <1>;
169 sata_phy0: sata-phy@0 {
176 /* Legacy UBUS base */
178 compatible = "simple-bus";
179 #address-cells = <1>;
181 ranges = <0 0xfffe8000 0x8100>;
184 compatible = "brcm,bcm6328-timer", "syscon";
188 serial0: serial@600 {
189 compatible = "brcm,bcm6345-uart";
191 interrupts = <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>;
192 clocks = <&periph_clk>;
193 clock-names = "periph";
197 serial1: serial@620 {
198 compatible = "brcm,bcm6345-uart";
200 interrupts = <GIC_SPI 33 IRQ_TYPE_LEVEL_HIGH>;
201 clocks = <&periph_clk>;
202 clock-names = "periph";
207 #address-cells = <1>;
209 compatible = "brcm,nand-bcm63138", "brcm,brcmnand-v7.0", "brcm,brcmnand";
210 reg = <0x2000 0x600>, <0xf0 0x10>;
211 reg-names = "nand", "nand-int-base";
213 interrupts = <GIC_SPI 38 IRQ_TYPE_LEVEL_HIGH>;
214 interrupt-names = "nand";
217 bootlut: bootlut@8000 {
218 compatible = "brcm,bcm63138-bootlut";
223 compatible = "syscon-reboot";