xref: /linux/arch/arm64/boot/dts/renesas/r9a07g043u.dtsi (revision 90d32e92011eaae8e70a9169b4e7acf4ca8f9d3a)
1// SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
2/*
3 * Device Tree Source for the RZ/G2UL SoC
4 *
5 * Copyright (C) 2022 Renesas Electronics Corp.
6 */
7
8#include <dt-bindings/interrupt-controller/arm-gic.h>
9
10#define SOC_PERIPHERAL_IRQ(nr)		GIC_SPI nr
11
12#include "r9a07g043.dtsi"
13
14/ {
15	cpus {
16		#address-cells = <1>;
17		#size-cells = <0>;
18
19		cpu0: cpu@0 {
20			compatible = "arm,cortex-a55";
21			reg = <0>;
22			device_type = "cpu";
23			#cooling-cells = <2>;
24			next-level-cache = <&L3_CA55>;
25			enable-method = "psci";
26			clocks = <&cpg CPG_CORE R9A07G043_CLK_I>;
27			operating-points-v2 = <&cluster0_opp>;
28		};
29
30		L3_CA55: cache-controller-0 {
31			compatible = "cache";
32			cache-unified;
33			cache-size = <0x40000>;
34			cache-level = <3>;
35		};
36	};
37
38	pmu {
39		compatible = "arm,cortex-a55-pmu";
40		interrupts-extended = <&gic GIC_PPI 7 IRQ_TYPE_LEVEL_LOW>;
41	};
42
43	psci {
44		compatible = "arm,psci-1.0", "arm,psci-0.2";
45		method = "smc";
46	};
47
48	timer {
49		compatible = "arm,armv8-timer";
50		interrupts-extended = <&gic GIC_PPI 13 IRQ_TYPE_LEVEL_LOW>,
51				      <&gic GIC_PPI 14 IRQ_TYPE_LEVEL_LOW>,
52				      <&gic GIC_PPI 11 IRQ_TYPE_LEVEL_LOW>,
53				      <&gic GIC_PPI 10 IRQ_TYPE_LEVEL_LOW>;
54	};
55};
56
57&soc {
58	interrupt-parent = <&gic>;
59
60	cru: video@10830000 {
61		compatible = "renesas,r9a07g043-cru", "renesas,rzg2l-cru";
62		reg = <0 0x10830000 0 0x400>;
63		clocks = <&cpg CPG_MOD R9A07G043_CRU_VCLK>,
64			 <&cpg CPG_MOD R9A07G043_CRU_PCLK>,
65			 <&cpg CPG_MOD R9A07G043_CRU_ACLK>;
66		clock-names = "video", "apb", "axi";
67		interrupts = <SOC_PERIPHERAL_IRQ(167) IRQ_TYPE_LEVEL_HIGH>,
68			     <SOC_PERIPHERAL_IRQ(168) IRQ_TYPE_LEVEL_HIGH>,
69			     <SOC_PERIPHERAL_IRQ(169) IRQ_TYPE_LEVEL_HIGH>;
70		interrupt-names = "image_conv", "image_conv_err", "axi_mst_err";
71		resets = <&cpg R9A07G043_CRU_PRESETN>,
72			 <&cpg R9A07G043_CRU_ARESETN>;
73		reset-names = "presetn", "aresetn";
74		power-domains = <&cpg>;
75		status = "disabled";
76
77		ports {
78			#address-cells = <1>;
79			#size-cells = <0>;
80
81			port@1 {
82				#address-cells = <1>;
83				#size-cells = <0>;
84
85				reg = <1>;
86				crucsi2: endpoint@0 {
87					reg = <0>;
88					remote-endpoint = <&csi2cru>;
89				};
90			};
91		};
92	};
93
94	csi2: csi2@10830400 {
95		compatible = "renesas,r9a07g043-csi2", "renesas,rzg2l-csi2";
96		reg = <0 0x10830400 0 0xfc00>;
97		interrupts = <SOC_PERIPHERAL_IRQ(166) IRQ_TYPE_LEVEL_HIGH>;
98		clocks = <&cpg CPG_MOD R9A07G043_CRU_SYSCLK>,
99			 <&cpg CPG_MOD R9A07G043_CRU_VCLK>,
100			 <&cpg CPG_MOD R9A07G043_CRU_PCLK>;
101		clock-names = "system", "video", "apb";
102		resets = <&cpg R9A07G043_CRU_PRESETN>,
103			 <&cpg R9A07G043_CRU_CMN_RSTB>;
104		reset-names = "presetn", "cmn-rstb";
105		power-domains = <&cpg>;
106		status = "disabled";
107
108		ports {
109			#address-cells = <1>;
110			#size-cells = <0>;
111
112			port@0 {
113				reg = <0>;
114			};
115
116			port@1 {
117				#address-cells = <1>;
118				#size-cells = <0>;
119				reg = <1>;
120
121				csi2cru: endpoint@0 {
122					reg = <0>;
123					remote-endpoint = <&crucsi2>;
124				};
125			};
126		};
127	};
128
129	irqc: interrupt-controller@110a0000 {
130		compatible = "renesas,r9a07g043u-irqc",
131			     "renesas,rzg2l-irqc";
132		reg = <0 0x110a0000 0 0x10000>;
133		#interrupt-cells = <2>;
134		#address-cells = <0>;
135		interrupt-controller;
136		interrupts = <SOC_PERIPHERAL_IRQ(0) IRQ_TYPE_LEVEL_HIGH>,
137			     <SOC_PERIPHERAL_IRQ(1) IRQ_TYPE_LEVEL_HIGH>,
138			     <SOC_PERIPHERAL_IRQ(2) IRQ_TYPE_LEVEL_HIGH>,
139			     <SOC_PERIPHERAL_IRQ(3) IRQ_TYPE_LEVEL_HIGH>,
140			     <SOC_PERIPHERAL_IRQ(4) IRQ_TYPE_LEVEL_HIGH>,
141			     <SOC_PERIPHERAL_IRQ(5) IRQ_TYPE_LEVEL_HIGH>,
142			     <SOC_PERIPHERAL_IRQ(6) IRQ_TYPE_LEVEL_HIGH>,
143			     <SOC_PERIPHERAL_IRQ(7) IRQ_TYPE_LEVEL_HIGH>,
144			     <SOC_PERIPHERAL_IRQ(8) IRQ_TYPE_LEVEL_HIGH>,
145			     <SOC_PERIPHERAL_IRQ(444) IRQ_TYPE_LEVEL_HIGH>,
146			     <SOC_PERIPHERAL_IRQ(445) IRQ_TYPE_LEVEL_HIGH>,
147			     <SOC_PERIPHERAL_IRQ(446) IRQ_TYPE_LEVEL_HIGH>,
148			     <SOC_PERIPHERAL_IRQ(447) IRQ_TYPE_LEVEL_HIGH>,
149			     <SOC_PERIPHERAL_IRQ(448) IRQ_TYPE_LEVEL_HIGH>,
150			     <SOC_PERIPHERAL_IRQ(449) IRQ_TYPE_LEVEL_HIGH>,
151			     <SOC_PERIPHERAL_IRQ(450) IRQ_TYPE_LEVEL_HIGH>,
152			     <SOC_PERIPHERAL_IRQ(451) IRQ_TYPE_LEVEL_HIGH>,
153			     <SOC_PERIPHERAL_IRQ(452) IRQ_TYPE_LEVEL_HIGH>,
154			     <SOC_PERIPHERAL_IRQ(453) IRQ_TYPE_LEVEL_HIGH>,
155			     <SOC_PERIPHERAL_IRQ(454) IRQ_TYPE_LEVEL_HIGH>,
156			     <SOC_PERIPHERAL_IRQ(455) IRQ_TYPE_LEVEL_HIGH>,
157			     <SOC_PERIPHERAL_IRQ(456) IRQ_TYPE_LEVEL_HIGH>,
158			     <SOC_PERIPHERAL_IRQ(457) IRQ_TYPE_LEVEL_HIGH>,
159			     <SOC_PERIPHERAL_IRQ(458) IRQ_TYPE_LEVEL_HIGH>,
160			     <SOC_PERIPHERAL_IRQ(459) IRQ_TYPE_LEVEL_HIGH>,
161			     <SOC_PERIPHERAL_IRQ(460) IRQ_TYPE_LEVEL_HIGH>,
162			     <SOC_PERIPHERAL_IRQ(461) IRQ_TYPE_LEVEL_HIGH>,
163			     <SOC_PERIPHERAL_IRQ(462) IRQ_TYPE_LEVEL_HIGH>,
164			     <SOC_PERIPHERAL_IRQ(463) IRQ_TYPE_LEVEL_HIGH>,
165			     <SOC_PERIPHERAL_IRQ(464) IRQ_TYPE_LEVEL_HIGH>,
166			     <SOC_PERIPHERAL_IRQ(465) IRQ_TYPE_LEVEL_HIGH>,
167			     <SOC_PERIPHERAL_IRQ(466) IRQ_TYPE_LEVEL_HIGH>,
168			     <SOC_PERIPHERAL_IRQ(467) IRQ_TYPE_LEVEL_HIGH>,
169			     <SOC_PERIPHERAL_IRQ(468) IRQ_TYPE_LEVEL_HIGH>,
170			     <SOC_PERIPHERAL_IRQ(469) IRQ_TYPE_LEVEL_HIGH>,
171			     <SOC_PERIPHERAL_IRQ(470) IRQ_TYPE_LEVEL_HIGH>,
172			     <SOC_PERIPHERAL_IRQ(471) IRQ_TYPE_LEVEL_HIGH>,
173			     <SOC_PERIPHERAL_IRQ(472) IRQ_TYPE_LEVEL_HIGH>,
174			     <SOC_PERIPHERAL_IRQ(473) IRQ_TYPE_LEVEL_HIGH>,
175			     <SOC_PERIPHERAL_IRQ(474) IRQ_TYPE_LEVEL_HIGH>,
176			     <SOC_PERIPHERAL_IRQ(475) IRQ_TYPE_LEVEL_HIGH>,
177			     <SOC_PERIPHERAL_IRQ(25) IRQ_TYPE_EDGE_RISING>,
178			     <SOC_PERIPHERAL_IRQ(34) IRQ_TYPE_EDGE_RISING>,
179			     <SOC_PERIPHERAL_IRQ(35) IRQ_TYPE_EDGE_RISING>,
180			     <SOC_PERIPHERAL_IRQ(36) IRQ_TYPE_EDGE_RISING>,
181			     <SOC_PERIPHERAL_IRQ(37) IRQ_TYPE_EDGE_RISING>,
182			     <SOC_PERIPHERAL_IRQ(38) IRQ_TYPE_EDGE_RISING>,
183			     <SOC_PERIPHERAL_IRQ(39) IRQ_TYPE_EDGE_RISING>;
184		interrupt-names = "nmi",
185				  "irq0", "irq1", "irq2", "irq3",
186				  "irq4", "irq5", "irq6", "irq7",
187				  "tint0", "tint1", "tint2", "tint3",
188				  "tint4", "tint5", "tint6", "tint7",
189				  "tint8", "tint9", "tint10", "tint11",
190				  "tint12", "tint13", "tint14", "tint15",
191				  "tint16", "tint17", "tint18", "tint19",
192				  "tint20", "tint21", "tint22", "tint23",
193				  "tint24", "tint25", "tint26", "tint27",
194				  "tint28", "tint29", "tint30", "tint31",
195				  "bus-err", "ec7tie1-0", "ec7tie2-0",
196				  "ec7tiovf-0", "ec7tie1-1", "ec7tie2-1",
197				  "ec7tiovf-1";
198		clocks = <&cpg CPG_MOD R9A07G043_IA55_CLK>,
199			<&cpg CPG_MOD R9A07G043_IA55_PCLK>;
200		clock-names = "clk", "pclk";
201		power-domains = <&cpg>;
202		resets = <&cpg R9A07G043_IA55_RESETN>;
203	};
204
205	gic: interrupt-controller@11900000 {
206		compatible = "arm,gic-v3";
207		#interrupt-cells = <3>;
208		#address-cells = <0>;
209		interrupt-controller;
210		reg = <0x0 0x11900000 0 0x40000>,
211		      <0x0 0x11940000 0 0x60000>;
212		interrupts = <GIC_PPI 9 IRQ_TYPE_LEVEL_LOW>;
213	};
214};
215
216&sysc {
217	interrupts = <SOC_PERIPHERAL_IRQ(42) IRQ_TYPE_LEVEL_HIGH>,
218		     <SOC_PERIPHERAL_IRQ(43) IRQ_TYPE_LEVEL_HIGH>,
219		     <SOC_PERIPHERAL_IRQ(44) IRQ_TYPE_LEVEL_HIGH>,
220		     <SOC_PERIPHERAL_IRQ(45) IRQ_TYPE_LEVEL_HIGH>;
221	interrupt-names = "lpm_int", "ca55stbydone_int",
222			  "cm33stbyr_int", "ca55_deny";
223};
224