xref: /linux/arch/arm64/boot/dts/freescale/s32g2.dtsi (revision 001821b0e79716c4e17c71d8e053a23599a7a508)
1// SPDX-License-Identifier: GPL-2.0-or-later OR MIT
2/*
3 * NXP S32G2 SoC family
4 *
5 * Copyright (c) 2021 SUSE LLC
6 * Copyright 2017-2021, 2024 NXP
7 */
8
9#include <dt-bindings/interrupt-controller/arm-gic.h>
10
11/ {
12	compatible = "nxp,s32g2";
13	interrupt-parent = <&gic>;
14	#address-cells = <2>;
15	#size-cells = <2>;
16
17	reserved-memory  {
18		#address-cells = <2>;
19		#size-cells = <2>;
20		ranges;
21
22		scmi_buf: shm@d0000000 {
23			compatible = "arm,scmi-shmem";
24			reg = <0x0 0xd0000000 0x0 0x80>;
25			no-map;
26		};
27	};
28
29	cpus {
30		#address-cells = <1>;
31		#size-cells = <0>;
32
33		cpu0: cpu@0 {
34			device_type = "cpu";
35			compatible = "arm,cortex-a53";
36			reg = <0x0>;
37			enable-method = "psci";
38			next-level-cache = <&cluster0_l2>;
39		};
40
41		cpu1: cpu@1 {
42			device_type = "cpu";
43			compatible = "arm,cortex-a53";
44			reg = <0x1>;
45			enable-method = "psci";
46			next-level-cache = <&cluster0_l2>;
47		};
48
49		cpu2: cpu@100 {
50			device_type = "cpu";
51			compatible = "arm,cortex-a53";
52			reg = <0x100>;
53			enable-method = "psci";
54			next-level-cache = <&cluster1_l2>;
55		};
56
57		cpu3: cpu@101 {
58			device_type = "cpu";
59			compatible = "arm,cortex-a53";
60			reg = <0x101>;
61			enable-method = "psci";
62			next-level-cache = <&cluster1_l2>;
63		};
64
65		cluster0_l2: l2-cache0 {
66			compatible = "cache";
67			cache-level = <2>;
68			cache-unified;
69		};
70
71		cluster1_l2: l2-cache1 {
72			compatible = "cache";
73			cache-level = <2>;
74			cache-unified;
75		};
76	};
77
78	pmu {
79		compatible = "arm,cortex-a53-pmu";
80		interrupts = <GIC_PPI 7 IRQ_TYPE_LEVEL_HIGH>;
81	};
82
83	timer {
84		compatible = "arm,armv8-timer";
85		interrupts = <GIC_PPI 13 IRQ_TYPE_LEVEL_LOW>,
86			     <GIC_PPI 14 IRQ_TYPE_LEVEL_LOW>,
87			     <GIC_PPI 11 IRQ_TYPE_LEVEL_LOW>,
88			     <GIC_PPI 10 IRQ_TYPE_LEVEL_LOW>;
89	};
90
91	firmware {
92		scmi {
93			compatible = "arm,scmi-smc";
94			arm,smc-id = <0xc20000fe>;
95			#address-cells = <1>;
96			#size-cells = <0>;
97			shmem = <&scmi_buf>;
98
99			clks: protocol@14 {
100				reg = <0x14>;
101				#clock-cells = <1>;
102			};
103		};
104
105		psci {
106			compatible = "arm,psci-1.0";
107			method = "smc";
108		};
109	};
110
111	soc@0 {
112		compatible = "simple-bus";
113		#address-cells = <1>;
114		#size-cells = <1>;
115		ranges = <0 0 0 0x80000000>;
116
117		uart0: serial@401c8000 {
118			compatible = "nxp,s32g2-linflexuart",
119				     "fsl,s32v234-linflexuart";
120			reg = <0x401c8000 0x3000>;
121			interrupts = <GIC_SPI 82 IRQ_TYPE_EDGE_RISING>;
122			status = "disabled";
123		};
124
125		uart1: serial@401cc000 {
126			compatible = "nxp,s32g2-linflexuart",
127				     "fsl,s32v234-linflexuart";
128			reg = <0x401cc000 0x3000>;
129			interrupts = <GIC_SPI 83 IRQ_TYPE_EDGE_RISING>;
130			status = "disabled";
131		};
132
133		uart2: serial@402bc000 {
134			compatible = "nxp,s32g2-linflexuart",
135				     "fsl,s32v234-linflexuart";
136			reg = <0x402bc000 0x3000>;
137			interrupts = <GIC_SPI 84 IRQ_TYPE_EDGE_RISING>;
138			status = "disabled";
139		};
140
141		usdhc0: mmc@402f0000 {
142			compatible = "nxp,s32g2-usdhc";
143			reg = <0x402f0000 0x1000>;
144			interrupts = <GIC_SPI 36 IRQ_TYPE_LEVEL_HIGH>;
145			clocks = <&clks 32>, <&clks 31>, <&clks 33>;
146			clock-names = "ipg", "ahb", "per";
147			bus-width = <8>;
148			status = "disabled";
149		};
150
151		gic: interrupt-controller@50800000 {
152			compatible = "arm,gic-v3";
153			reg = <0x50800000 0x10000>,
154			      <0x50880000 0x80000>,
155			      <0x50400000 0x2000>,
156			      <0x50410000 0x2000>,
157			      <0x50420000 0x2000>;
158			interrupts = <GIC_PPI 9 IRQ_TYPE_LEVEL_HIGH>;
159			interrupt-controller;
160			#interrupt-cells = <3>;
161		};
162	};
163};
164