1// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
2/*
3 * Actions Semi S500 SoC
4 *
5 * Copyright (c) 2016-2017 Andreas Färber
6 */
7
8#include <dt-bindings/interrupt-controller/arm-gic.h>
9#include <dt-bindings/power/owl-s500-powergate.h>
10
11/ {
12	compatible = "actions,s500";
13	interrupt-parent = <&gic>;
14	#address-cells = <1>;
15	#size-cells = <1>;
16
17	aliases {
18	};
19
20	chosen {
21	};
22
23	cpus {
24		#address-cells = <1>;
25		#size-cells = <0>;
26
27		cpu0: cpu@0 {
28			device_type = "cpu";
29			compatible = "arm,cortex-a9";
30			reg = <0x0>;
31			enable-method = "actions,s500-smp";
32		};
33
34		cpu1: cpu@1 {
35			device_type = "cpu";
36			compatible = "arm,cortex-a9";
37			reg = <0x1>;
38			enable-method = "actions,s500-smp";
39		};
40
41		cpu2: cpu@2 {
42			device_type = "cpu";
43			compatible = "arm,cortex-a9";
44			reg = <0x2>;
45			enable-method = "actions,s500-smp";
46			power-domains = <&sps S500_PD_CPU2>;
47		};
48
49		cpu3: cpu@3 {
50			device_type = "cpu";
51			compatible = "arm,cortex-a9";
52			reg = <0x3>;
53			enable-method = "actions,s500-smp";
54			power-domains = <&sps S500_PD_CPU3>;
55		};
56	};
57
58	arm-pmu {
59		compatible = "arm,cortex-a9-pmu";
60		interrupts = <GIC_SPI 4 IRQ_TYPE_LEVEL_HIGH>,
61		             <GIC_SPI 5 IRQ_TYPE_LEVEL_HIGH>,
62		             <GIC_SPI 6 IRQ_TYPE_LEVEL_HIGH>,
63		             <GIC_SPI 7 IRQ_TYPE_LEVEL_HIGH>;
64		interrupt-affinity = <&cpu0>, <&cpu1>, <&cpu2>, <&cpu3>;
65	};
66
67	hosc: hosc {
68		compatible = "fixed-clock";
69		clock-frequency = <24000000>;
70		#clock-cells = <0>;
71	};
72
73	soc {
74		compatible = "simple-bus";
75		#address-cells = <1>;
76		#size-cells = <1>;
77		ranges;
78
79		scu: scu@b0020000 {
80			compatible = "arm,cortex-a9-scu";
81			reg = <0xb0020000 0x100>;
82		};
83
84		global_timer: timer@b0020200 {
85			compatible = "arm,cortex-a9-global-timer";
86			reg = <0xb0020200 0x100>;
87			interrupts = <GIC_PPI 0 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_EDGE_RISING)>;
88			status = "disabled";
89		};
90
91		twd_timer: timer@b0020600 {
92			compatible = "arm,cortex-a9-twd-timer";
93			reg = <0xb0020600 0x20>;
94			interrupts = <GIC_PPI 2 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_EDGE_RISING)>;
95			status = "disabled";
96		};
97
98		twd_wdt: wdt@b0020620 {
99			compatible = "arm,cortex-a9-twd-wdt";
100			reg = <0xb0020620 0xe0>;
101			interrupts = <GIC_PPI 3 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_EDGE_RISING)>;
102			status = "disabled";
103		};
104
105		gic: interrupt-controller@b0021000 {
106			compatible = "arm,cortex-a9-gic";
107			reg = <0xb0021000 0x1000>,
108			      <0xb0020100 0x0100>;
109			interrupt-controller;
110			#interrupt-cells = <3>;
111		};
112
113		l2: cache-controller@b0022000 {
114			compatible = "arm,pl310-cache";
115			reg = <0xb0022000 0x1000>;
116			cache-unified;
117			cache-level = <2>;
118			interrupts = <GIC_SPI 55 IRQ_TYPE_LEVEL_HIGH>;
119			arm,tag-latency = <3 3 2>;
120			arm,data-latency = <5 3 3>;
121		};
122
123		uart0: serial@b0120000 {
124			compatible = "actions,s500-uart", "actions,owl-uart";
125			reg = <0xb0120000 0x2000>;
126			interrupts = <GIC_SPI 29 IRQ_TYPE_LEVEL_HIGH>;
127			status = "disabled";
128		};
129
130		uart1: serial@b0122000 {
131			compatible = "actions,s500-uart", "actions,owl-uart";
132			reg = <0xb0122000 0x2000>;
133			interrupts = <GIC_SPI 30 IRQ_TYPE_LEVEL_HIGH>;
134			status = "disabled";
135		};
136
137		uart2: serial@b0124000 {
138			compatible = "actions,s500-uart", "actions,owl-uart";
139			reg = <0xb0124000 0x2000>;
140			interrupts = <GIC_SPI 31 IRQ_TYPE_LEVEL_HIGH>;
141			status = "disabled";
142		};
143
144		uart3: serial@b0126000 {
145			compatible = "actions,s500-uart", "actions,owl-uart";
146			reg = <0xb0126000 0x2000>;
147			interrupts = <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>;
148			status = "disabled";
149		};
150
151		uart4: serial@b0128000 {
152			compatible = "actions,s500-uart", "actions,owl-uart";
153			reg = <0xb0128000 0x2000>;
154			interrupts = <GIC_SPI 33 IRQ_TYPE_LEVEL_HIGH>;
155			status = "disabled";
156		};
157
158		uart5: serial@b012a000 {
159			compatible = "actions,s500-uart", "actions,owl-uart";
160			reg = <0xb012a000 0x2000>;
161			interrupts = <GIC_SPI 34 IRQ_TYPE_LEVEL_HIGH>;
162			status = "disabled";
163		};
164
165		uart6: serial@b012c000 {
166			compatible = "actions,s500-uart", "actions,owl-uart";
167			reg = <0xb012c000 0x2000>;
168			interrupts = <GIC_SPI 35 IRQ_TYPE_LEVEL_HIGH>;
169			status = "disabled";
170		};
171
172		timer: timer@b0168000 {
173			compatible = "actions,s500-timer";
174			reg = <0xb0168000 0x8000>;
175			interrupts = <GIC_SPI  8 IRQ_TYPE_LEVEL_HIGH>,
176			             <GIC_SPI  9 IRQ_TYPE_LEVEL_HIGH>,
177			             <GIC_SPI 10 IRQ_TYPE_LEVEL_HIGH>,
178			             <GIC_SPI 11 IRQ_TYPE_LEVEL_HIGH>;
179			interrupt-names = "2hz0", "2hz1", "timer0", "timer1";
180		};
181
182		sps: power-controller@b01b0100 {
183			compatible = "actions,s500-sps";
184			reg = <0xb01b0100 0x100>;
185			#power-domain-cells = <1>;
186		};
187	};
188};
189