xref: /linux/arch/arm/boot/dts/broadcom/bcm63138.dtsi (revision 115e74a29b530d121891238e9551c4bcdf7b04b5)
1// SPDX-License-Identifier: GPL-2.0
2/*
3 * Broadcom BCM63138 DSL SoCs Device Tree
4 */
5
6#include <dt-bindings/interrupt-controller/arm-gic.h>
7#include <dt-bindings/interrupt-controller/irq.h>
8
9/ {
10	#address-cells = <1>;
11	#size-cells = <1>;
12	compatible = "brcm,bcm63138", "brcm,bcmbca";
13	model = "Broadcom BCM963138 Reference Board";
14	interrupt-parent = <&gic>;
15
16	aliases {
17		uart0 = &serial0;
18		uart1 = &serial1;
19	};
20
21	cpus {
22		#address-cells = <1>;
23		#size-cells = <0>;
24
25		cpu@0 {
26			device_type = "cpu";
27			compatible = "arm,cortex-a9";
28			next-level-cache = <&L2>;
29			reg = <0>;
30			enable-method = "brcm,bcm63138";
31		};
32
33		cpu@1 {
34			device_type = "cpu";
35			compatible = "arm,cortex-a9";
36			next-level-cache = <&L2>;
37			reg = <1>;
38			enable-method = "brcm,bcm63138";
39			resets = <&pmb0 4 1>;
40		};
41	};
42
43	clocks {
44		/* UBUS peripheral clock */
45		periph_clk: periph_clk {
46			#clock-cells = <0>;
47			compatible = "fixed-clock";
48			clock-frequency = <50000000>;
49			clock-output-names = "periph";
50		};
51
52		/* peripheral clock for system timer */
53		axi_clk: axi_clk {
54			#clock-cells = <0>;
55			compatible = "fixed-factor-clock";
56			clocks = <&armpll>;
57			clock-div = <2>;
58			clock-mult = <1>;
59		};
60
61		/* APB bus clock */
62		apb_clk: apb_clk {
63			#clock-cells = <0>;
64			compatible = "fixed-factor-clock";
65			clocks = <&armpll>;
66			clock-div = <4>;
67			clock-mult = <1>;
68		};
69
70		hsspi_pll: hsspi-pll {
71			compatible = "fixed-clock";
72			#clock-cells = <0>;
73			clock-frequency = <400000000>;
74		};
75	};
76
77	/* ARM bus */
78	axi@80000000 {
79		compatible = "simple-bus";
80		ranges = <0 0x80000000 0x784000>;
81		#address-cells = <1>;
82		#size-cells = <1>;
83
84		L2: cache-controller@1d000 {
85			compatible = "arm,pl310-cache";
86			reg = <0x1d000 0x1000>;
87			cache-unified;
88			cache-level = <2>;
89			cache-size = <524288>;
90			cache-sets = <1024>;
91			cache-line-size = <32>;
92			interrupts = <GIC_PPI 0 IRQ_TYPE_LEVEL_HIGH>;
93		};
94
95		scu: scu@1e000 {
96			compatible = "arm,cortex-a9-scu";
97			reg = <0x1e000 0x100>;
98		};
99
100		gic: interrupt-controller@1f000 {
101			compatible = "arm,cortex-a9-gic";
102			reg = <0x1f000 0x1000
103				0x1e100 0x100>;
104			#interrupt-cells = <3>;
105			#address-cells = <0>;
106			interrupt-controller;
107		};
108
109		global_timer: timer@1e200 {
110			compatible = "arm,cortex-a9-global-timer";
111			reg = <0x1e200 0x20>;
112			interrupts = <GIC_PPI 11 IRQ_TYPE_EDGE_RISING>;
113			clocks = <&axi_clk>;
114		};
115
116		local_timer: local-timer@1e600 {
117			compatible = "arm,cortex-a9-twd-timer";
118			reg = <0x1e600 0x20>;
119			interrupts = <GIC_PPI 13 (GIC_CPU_MASK_SIMPLE(2) |
120						  IRQ_TYPE_EDGE_RISING)>;
121			clocks = <&axi_clk>;
122		};
123
124		twd_watchdog: watchdog@1e620 {
125			compatible = "arm,cortex-a9-twd-wdt";
126			reg = <0x1e620 0x20>;
127			interrupts = <GIC_PPI 14 (GIC_CPU_MASK_SIMPLE(2) |
128						  IRQ_TYPE_LEVEL_HIGH)>;
129		};
130
131		armpll: armpll@20000 {
132			#clock-cells = <0>;
133			compatible = "brcm,bcm63138-armpll";
134			clocks = <&periph_clk>;
135			reg = <0x20000 0xf00>;
136		};
137
138		pmb0: reset-controller@4800c0 {
139			compatible = "brcm,bcm63138-pmb";
140			reg = <0x4800c0 0x10>;
141			#reset-cells = <2>;
142		};
143
144		pmb1: reset-controller@4800e0 {
145			compatible = "brcm,bcm63138-pmb";
146			reg = <0x4800e0 0x10>;
147			#reset-cells = <2>;
148		};
149
150		ahci: sata@a000 {
151			compatible = "brcm,bcm63138-ahci", "brcm,sata3-ahci";
152			reg-names = "ahci", "top-ctrl";
153			reg = <0xa000 0x9ac>, <0x8040 0x24>;
154			interrupts = <GIC_SPI 45 IRQ_TYPE_LEVEL_HIGH>;
155			#address-cells = <1>;
156			#size-cells = <0>;
157			resets = <&pmb0 3 1>;
158			reset-names = "ahci";
159			status = "disabled";
160
161			sata0: sata-port@0 {
162				reg = <0>;
163				phys = <&sata_phy0>;
164			};
165		};
166
167		sata_phy: sata-phy@8100 {
168			compatible = "brcm,bcm63138-sata-phy", "brcm,phy-sata3";
169			reg = <0x8100 0x1e00>;
170			reg-names = "phy";
171			#address-cells = <1>;
172			#size-cells = <0>;
173			status = "disabled";
174
175			sata_phy0: sata-phy@0 {
176				reg = <0>;
177				#phy-cells = <0>;
178			};
179		};
180	};
181
182	/* Legacy UBUS base */
183	ubus@fffe8000 {
184		compatible = "simple-bus";
185		#address-cells = <1>;
186		#size-cells = <1>;
187		ranges = <0 0xfffe8000 0x10000>;
188
189		timer: timer@80 {
190			compatible = "brcm,bcm6328-timer", "syscon";
191			reg = <0x80 0x3c>;
192		};
193
194		/* GPIOs 0 .. 31 */
195		gpio0: gpio@100 {
196			compatible = "brcm,bcm6345-gpio";
197			reg = <0x100 0x04>, <0x114 0x04>;
198			reg-names = "dirout", "dat";
199			gpio-controller;
200			#gpio-cells = <2>;
201			status = "disabled";
202		};
203
204		/* GPIOs 32 .. 63 */
205		gpio1: gpio@104 {
206			compatible = "brcm,bcm6345-gpio";
207			reg = <0x104 0x04>, <0x118 0x04>;
208			reg-names = "dirout", "dat";
209			gpio-controller;
210			#gpio-cells = <2>;
211			status = "disabled";
212		};
213
214		/* GPIOs 64 .. 95 */
215		gpio2: gpio@108 {
216			compatible = "brcm,bcm6345-gpio";
217			reg = <0x108 0x04>, <0x11c 0x04>;
218			reg-names = "dirout", "dat";
219			gpio-controller;
220			#gpio-cells = <2>;
221			status = "disabled";
222		};
223
224		/* GPIOs 96 .. 127 */
225		gpio3: gpio@10c {
226			compatible = "brcm,bcm6345-gpio";
227			reg = <0x10c 0x04>, <0x120 0x04>;
228			reg-names = "dirout", "dat";
229			gpio-controller;
230			#gpio-cells = <2>;
231			status = "disabled";
232		};
233
234		/* GPIOs 128 .. 159 */
235		gpio4: gpio@110 {
236			compatible = "brcm,bcm6345-gpio";
237			reg = <0x110 0x04>, <0x124 0x04>;
238			reg-names = "dirout", "dat";
239			gpio-controller;
240			#gpio-cells = <2>;
241			status = "disabled";
242		};
243
244		rng@300 {
245			compatible = "brcm,iproc-rng200";
246			reg = <0x300 0x28>;
247			interrupts = <GIC_SPI 85 IRQ_TYPE_LEVEL_HIGH>;
248		};
249
250		serial0: serial@600 {
251			compatible = "brcm,bcm6345-uart";
252			reg = <0x600 0x1b>;
253			interrupts = <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>;
254			clocks = <&periph_clk>;
255			clock-names = "periph";
256			status = "disabled";
257		};
258
259		serial1: serial@620 {
260			compatible = "brcm,bcm6345-uart";
261			reg = <0x620 0x1b>;
262			interrupts = <GIC_SPI 33 IRQ_TYPE_LEVEL_HIGH>;
263			clocks = <&periph_clk>;
264			clock-names = "periph";
265			status = "disabled";
266		};
267
268		leds: led-controller@700 {
269			#address-cells = <1>;
270			#size-cells = <0>;
271			compatible = "brcm,bcm63138-leds";
272			reg = <0x700 0xdc>;
273			status = "disabled";
274		};
275
276		hsspi: spi@1000 {
277			#address-cells = <1>;
278			#size-cells = <0>;
279			compatible = "brcm,bcm63138-hsspi", "brcm,bcmbca-hsspi-v1.0";
280			reg = <0x1000 0x600>;
281			interrupts = <GIC_SPI 37 IRQ_TYPE_LEVEL_HIGH>;
282			clocks = <&hsspi_pll &hsspi_pll>;
283			clock-names = "hsspi", "pll";
284			num-cs = <8>;
285			status = "disabled";
286		};
287
288		nand_controller: nand-controller@2000 {
289			#address-cells = <1>;
290			#size-cells = <0>;
291			compatible = "brcm,nand-bcm63138", "brcm,brcmnand-v7.0", "brcm,brcmnand";
292			reg = <0x2000 0x600>, <0xf0 0x10>;
293			reg-names = "nand", "nand-int-base";
294			status = "disabled";
295			interrupts = <GIC_SPI 38 IRQ_TYPE_LEVEL_HIGH>;
296			interrupt-names = "nand_ctlrdy";
297
298			nandcs: nand@0 {
299				compatible = "brcm,nandcs";
300				reg = <0>;
301			};
302		};
303
304		serial@4400 {
305			compatible = "brcm,bcm63138-hs-uart", "brcm,bcmbca-hs-uart";
306			reg = <0x4400 0x1e0>;
307			interrupts = <GIC_SPI 34 IRQ_TYPE_LEVEL_HIGH>;
308		};
309
310		bootlut: bootlut@8000 {
311			compatible = "brcm,bcm63138-bootlut";
312			reg = <0x8000 0x50>;
313		};
314
315		pl081_dma: dma-controller@d000 {
316			compatible = "arm,pl081", "arm,primecell";
317			// The magic B105F00D info is missing
318			arm,primecell-periphid = <0x00041081>;
319			reg = <0xd000 0x1000>;
320			interrupts = <GIC_SPI 23 IRQ_TYPE_LEVEL_HIGH>;
321			memcpy-burst-size = <256>;
322			memcpy-bus-width = <32>;
323			clocks = <&periph_clk>;
324			clock-names = "apb_pclk";
325			#dma-cells = <2>;
326		};
327
328		reboot {
329			compatible = "syscon-reboot";
330			regmap = <&timer>;
331			offset = <0x34>;
332			mask = <1>;
333		};
334	};
335};
336