xref: /linux/arch/arm64/boot/dts/exynos/exynosautov920.dtsi (revision 566ab427f827b0256d3e8ce0235d088e6a9c28bd)
1// SPDX-License-Identifier: GPL-2.0
2/*
3 * Samsung's ExynosAutov920 SoC device tree source
4 *
5 * Copyright (c) 2023 Samsung Electronics Co., Ltd.
6 *
7 */
8
9#include <dt-bindings/clock/samsung,exynosautov920.h>
10#include <dt-bindings/interrupt-controller/arm-gic.h>
11#include <dt-bindings/soc/samsung,exynos-usi.h>
12
13/ {
14	compatible = "samsung,exynosautov920";
15	#address-cells = <2>;
16	#size-cells = <1>;
17
18	interrupt-parent = <&gic>;
19
20	aliases {
21		pinctrl0 = &pinctrl_alive;
22		pinctrl1 = &pinctrl_aud;
23		pinctrl2 = &pinctrl_hsi0;
24		pinctrl3 = &pinctrl_hsi1;
25		pinctrl4 = &pinctrl_hsi2;
26		pinctrl5 = &pinctrl_hsi2ufs;
27		pinctrl6 = &pinctrl_peric0;
28		pinctrl7 = &pinctrl_peric1;
29	};
30
31	arm-pmu {
32		compatible = "arm,cortex-a78-pmu";
33		interrupts = <GIC_PPI 7 IRQ_TYPE_LEVEL_LOW>;
34	};
35
36	xtcxo: clock {
37		compatible = "fixed-clock";
38		#clock-cells = <0>;
39		clock-output-names = "oscclk";
40	};
41
42	cpus: cpus {
43		#address-cells = <2>;
44		#size-cells = <0>;
45
46		cpu-map {
47			cluster0 {
48				core0 {
49					cpu = <&cpu0>;
50				};
51				core1 {
52					cpu = <&cpu1>;
53				};
54				core2 {
55					cpu = <&cpu2>;
56				};
57				core3 {
58					cpu = <&cpu3>;
59				};
60			};
61
62			cluster1 {
63				core0 {
64					cpu = <&cpu4>;
65				};
66				core1 {
67					cpu = <&cpu5>;
68				};
69				core2 {
70					cpu = <&cpu6>;
71				};
72				core3 {
73					cpu = <&cpu7>;
74				};
75			};
76
77			cluster2 {
78				core0 {
79					cpu = <&cpu8>;
80				};
81				core1 {
82					cpu = <&cpu9>;
83				};
84			};
85		};
86
87		cpu0: cpu@0 {
88			device_type = "cpu";
89			compatible = "arm,cortex-a78ae";
90			reg = <0x0 0x0>;
91			enable-method = "psci";
92		};
93
94		cpu1: cpu@100 {
95			device_type = "cpu";
96			compatible = "arm,cortex-a78ae";
97			reg = <0x0 0x100>;
98			enable-method = "psci";
99		};
100
101		cpu2: cpu@200 {
102			device_type = "cpu";
103			compatible = "arm,cortex-a78ae";
104			reg = <0x0 0x200>;
105			enable-method = "psci";
106		};
107
108		cpu3: cpu@300 {
109			device_type = "cpu";
110			compatible = "arm,cortex-a78ae";
111			reg = <0x0 0x300>;
112			enable-method = "psci";
113		};
114
115		cpu4: cpu@10000 {
116			device_type = "cpu";
117			compatible = "arm,cortex-a78ae";
118			reg = <0x0 0x10000>;
119			enable-method = "psci";
120		};
121
122		cpu5: cpu@10100 {
123			device_type = "cpu";
124			compatible = "arm,cortex-a78ae";
125			reg = <0x0 0x10100>;
126			enable-method = "psci";
127		};
128
129		cpu6: cpu@10200 {
130			device_type = "cpu";
131			compatible = "arm,cortex-a78ae";
132			reg = <0x0 0x10200>;
133			enable-method = "psci";
134		};
135
136		cpu7: cpu@10300 {
137			device_type = "cpu";
138			compatible = "arm,cortex-a78ae";
139			reg = <0x0 0x10300>;
140			enable-method = "psci";
141		};
142
143		cpu8: cpu@20000 {
144			device_type = "cpu";
145			compatible = "arm,cortex-a78ae";
146			reg = <0x0 0x20000>;
147			enable-method = "psci";
148		};
149
150		cpu9: cpu@20100 {
151			device_type = "cpu";
152			compatible = "arm,cortex-a78ae";
153			reg = <0x0 0x20100>;
154			enable-method = "psci";
155		};
156	};
157
158	psci {
159		compatible = "arm,psci-1.0";
160		method = "smc";
161	};
162
163	soc: soc@0 {
164		compatible = "simple-bus";
165		#address-cells = <1>;
166		#size-cells = <1>;
167		ranges = <0x0 0x0 0x0 0x20000000>;
168
169		chipid@10000000 {
170			compatible = "samsung,exynosautov920-chipid",
171				     "samsung,exynos850-chipid";
172			reg = <0x10000000 0x24>;
173		};
174
175		gic: interrupt-controller@10400000 {
176			compatible = "arm,gic-v3";
177			#interrupt-cells = <3>;
178			#address-cells = <0>;
179			interrupt-controller;
180			reg = <0x10400000 0x10000>,
181			      <0x10460000 0x140000>;
182			interrupts = <GIC_PPI 9 IRQ_TYPE_LEVEL_HIGH>;
183		};
184
185		cmu_peric0: clock-controller@10800000 {
186			compatible = "samsung,exynosautov920-cmu-peric0";
187			reg = <0x10800000 0x8000>;
188			#clock-cells = <1>;
189
190			clocks = <&xtcxo>,
191				 <&cmu_top DOUT_CLKCMU_PERIC0_NOC>,
192				 <&cmu_top DOUT_CLKCMU_PERIC0_IP>;
193			clock-names = "oscclk",
194				      "noc",
195				      "ip";
196		};
197
198		syscon_peric0: syscon@10820000 {
199			compatible = "samsung,exynosautov920-peric0-sysreg",
200				     "syscon";
201			reg = <0x10820000 0x2000>;
202		};
203
204		pinctrl_peric0: pinctrl@10830000 {
205			compatible = "samsung,exynosautov920-pinctrl";
206			reg = <0x10830000 0x10000>;
207			interrupts = <GIC_SPI 753 IRQ_TYPE_LEVEL_HIGH>;
208		};
209
210		usi_0: usi@108800c0 {
211			compatible = "samsung,exynosautov920-usi",
212				     "samsung,exynos850-usi";
213			reg = <0x108800c0 0x20>;
214			samsung,sysreg = <&syscon_peric0 0x1000>;
215			samsung,mode = <USI_V2_UART>;
216			#address-cells = <1>;
217			#size-cells = <1>;
218			ranges;
219			clocks = <&cmu_peric0 CLK_MOUT_PERIC0_NOC_USER>,
220				 <&cmu_peric0 CLK_DOUT_PERIC0_USI00_USI>;
221			clock-names = "pclk", "ipclk";
222			status = "disabled";
223
224			serial_0: serial@10880000 {
225				compatible = "samsung,exynosautov920-uart",
226					     "samsung,exynos850-uart";
227				reg = <0x10880000 0xc0>;
228				interrupts = <GIC_SPI 764 IRQ_TYPE_LEVEL_HIGH>;
229				pinctrl-names = "default";
230				pinctrl-0 = <&uart0_bus>;
231				clocks = <&cmu_peric0 CLK_MOUT_PERIC0_NOC_USER>,
232					 <&cmu_peric0 CLK_DOUT_PERIC0_USI00_USI>;
233				clock-names = "uart", "clk_uart_baud0";
234				samsung,uart-fifosize = <256>;
235				status = "disabled";
236			};
237		};
238
239		pwm: pwm@109b0000 {
240			compatible = "samsung,exynosautov920-pwm",
241				     "samsung,exynos4210-pwm";
242			reg = <0x109b0000 0x100>;
243			samsung,pwm-outputs = <0>, <1>, <2>, <3>;
244			#pwm-cells = <3>;
245			clocks = <&xtcxo>;
246			clock-names = "timers";
247			status = "disabled";
248		};
249
250		syscon_peric1: syscon@10c20000 {
251			compatible = "samsung,exynosautov920-peric1-sysreg",
252				     "syscon";
253			reg = <0x10c20000 0x2000>;
254		};
255
256		pinctrl_peric1: pinctrl@10c30000 {
257			compatible = "samsung,exynosautov920-pinctrl";
258			reg = <0x10c30000 0x10000>;
259			interrupts = <GIC_SPI 781 IRQ_TYPE_LEVEL_HIGH>;
260		};
261
262		cmu_top: clock-controller@11000000 {
263			compatible = "samsung,exynosautov920-cmu-top";
264			reg = <0x11000000 0x8000>;
265			#clock-cells = <1>;
266
267			clocks = <&xtcxo>;
268			clock-names = "oscclk";
269		};
270
271		pinctrl_alive: pinctrl@11850000 {
272			compatible = "samsung,exynosautov920-pinctrl";
273			reg = <0x11850000 0x10000>;
274
275			wakeup-interrupt-controller {
276				compatible = "samsung,exynosautov920-wakeup-eint";
277			};
278		};
279
280		pmu_system_controller: system-controller@11860000 {
281			compatible = "samsung,exynosautov920-pmu",
282				     "samsung,exynos7-pmu","syscon";
283			reg = <0x11860000 0x10000>;
284		};
285
286		pinctrl_hsi0: pinctrl@16040000 {
287			compatible = "samsung,exynosautov920-pinctrl";
288			reg = <0x16040000 0x10000>;
289			interrupts = <GIC_SPI 442 IRQ_TYPE_LEVEL_HIGH>;
290		};
291
292		pinctrl_hsi1: pinctrl@16450000 {
293			compatible = "samsung,exynosautov920-pinctrl";
294			reg = <0x16450000 0x10000>;
295			interrupts = <GIC_SPI 456 IRQ_TYPE_LEVEL_HIGH>;
296		};
297
298		pinctrl_hsi2: pinctrl@16c10000 {
299			compatible = "samsung,exynosautov920-pinctrl";
300			reg = <0x16c10000 0x10000>;
301			interrupts = <GIC_SPI 602 IRQ_TYPE_LEVEL_HIGH>;
302		};
303
304		pinctrl_hsi2ufs: pinctrl@16d20000 {
305			compatible = "samsung,exynosautov920-pinctrl";
306			reg = <0x16d20000 0x10000>;
307			interrupts = <GIC_SPI 603 IRQ_TYPE_LEVEL_HIGH>;
308		};
309
310		pinctrl_aud: pinctrl@1a460000 {
311			compatible = "samsung,exynosautov920-pinctrl";
312			reg = <0x1a460000 0x10000>;
313		};
314	};
315
316	timer {
317		compatible = "arm,armv8-timer";
318		interrupts = <GIC_PPI 13 IRQ_TYPE_LEVEL_LOW>,
319			     <GIC_PPI 14 IRQ_TYPE_LEVEL_LOW>,
320			     <GIC_PPI 11 IRQ_TYPE_LEVEL_LOW>,
321			     <GIC_PPI 10 IRQ_TYPE_LEVEL_LOW>,
322			     <GIC_PPI 12 IRQ_TYPE_LEVEL_LOW>;
323	};
324};
325
326#include "exynosautov920-pinctrl.dtsi"
327