1// SPDX-License-Identifier: GPL-2.0
2
3#include <dt-bindings/clock/jz4770-cgu.h>
4
5/ {
6	#address-cells = <1>;
7	#size-cells = <1>;
8	compatible = "ingenic,jz4770";
9
10	cpuintc: interrupt-controller {
11		#address-cells = <0>;
12		#interrupt-cells = <1>;
13		interrupt-controller;
14		compatible = "mti,cpu-interrupt-controller";
15	};
16
17	intc: interrupt-controller@10001000 {
18		compatible = "ingenic,jz4770-intc";
19		reg = <0x10001000 0x40>;
20
21		interrupt-controller;
22		#interrupt-cells = <1>;
23
24		interrupt-parent = <&cpuintc>;
25		interrupts = <2>;
26	};
27
28	ext: ext {
29		compatible = "fixed-clock";
30		#clock-cells = <0>;
31	};
32
33	osc32k: osc32k {
34		compatible = "fixed-clock";
35		#clock-cells = <0>;
36		clock-frequency = <32768>;
37	};
38
39	cgu: jz4770-cgu@10000000 {
40		compatible = "ingenic,jz4770-cgu";
41		reg = <0x10000000 0x100>;
42
43		clocks = <&ext>, <&osc32k>;
44		clock-names = "ext", "osc32k";
45
46		#clock-cells = <1>;
47	};
48
49	pinctrl: pin-controller@10010000 {
50		compatible = "ingenic,jz4770-pinctrl";
51		reg = <0x10010000 0x600>;
52
53		#address-cells = <1>;
54		#size-cells = <0>;
55
56		gpa: gpio@0 {
57			compatible = "ingenic,jz4770-gpio";
58			reg = <0>;
59
60			gpio-controller;
61			gpio-ranges = <&pinctrl 0 0 32>;
62			#gpio-cells = <2>;
63
64			interrupt-controller;
65			#interrupt-cells = <2>;
66
67			interrupt-parent = <&intc>;
68			interrupts = <17>;
69		};
70
71		gpb: gpio@1 {
72			compatible = "ingenic,jz4770-gpio";
73			reg = <1>;
74
75			gpio-controller;
76			gpio-ranges = <&pinctrl 0 32 32>;
77			#gpio-cells = <2>;
78
79			interrupt-controller;
80			#interrupt-cells = <2>;
81
82			interrupt-parent = <&intc>;
83			interrupts = <16>;
84		};
85
86		gpc: gpio@2 {
87			compatible = "ingenic,jz4770-gpio";
88			reg = <2>;
89
90			gpio-controller;
91			gpio-ranges = <&pinctrl 0 64 32>;
92			#gpio-cells = <2>;
93
94			interrupt-controller;
95			#interrupt-cells = <2>;
96
97			interrupt-parent = <&intc>;
98			interrupts = <15>;
99		};
100
101		gpd: gpio@3 {
102			compatible = "ingenic,jz4770-gpio";
103			reg = <3>;
104
105			gpio-controller;
106			gpio-ranges = <&pinctrl 0 96 32>;
107			#gpio-cells = <2>;
108
109			interrupt-controller;
110			#interrupt-cells = <2>;
111
112			interrupt-parent = <&intc>;
113			interrupts = <14>;
114		};
115
116		gpe: gpio@4 {
117			compatible = "ingenic,jz4770-gpio";
118			reg = <4>;
119
120			gpio-controller;
121			gpio-ranges = <&pinctrl 0 128 32>;
122			#gpio-cells = <2>;
123
124			interrupt-controller;
125			#interrupt-cells = <2>;
126
127			interrupt-parent = <&intc>;
128			interrupts = <13>;
129		};
130
131		gpf: gpio@5 {
132			compatible = "ingenic,jz4770-gpio";
133			reg = <5>;
134
135			gpio-controller;
136			gpio-ranges = <&pinctrl 0 160 32>;
137			#gpio-cells = <2>;
138
139			interrupt-controller;
140			#interrupt-cells = <2>;
141
142			interrupt-parent = <&intc>;
143			interrupts = <12>;
144		};
145	};
146
147	uart0: serial@10030000 {
148		compatible = "ingenic,jz4770-uart";
149		reg = <0x10030000 0x100>;
150
151		clocks = <&ext>, <&cgu JZ4770_CLK_UART0>;
152		clock-names = "baud", "module";
153
154		interrupt-parent = <&intc>;
155		interrupts = <5>;
156
157		status = "disabled";
158	};
159
160	uart1: serial@10031000 {
161		compatible = "ingenic,jz4770-uart";
162		reg = <0x10031000 0x100>;
163
164		clocks = <&ext>, <&cgu JZ4770_CLK_UART1>;
165		clock-names = "baud", "module";
166
167		interrupt-parent = <&intc>;
168		interrupts = <4>;
169
170		status = "disabled";
171	};
172
173	uart2: serial@10032000 {
174		compatible = "ingenic,jz4770-uart";
175		reg = <0x10032000 0x100>;
176
177		clocks = <&ext>, <&cgu JZ4770_CLK_UART2>;
178		clock-names = "baud", "module";
179
180		interrupt-parent = <&intc>;
181		interrupts = <3>;
182
183		status = "disabled";
184	};
185
186	uart3: serial@10033000 {
187		compatible = "ingenic,jz4770-uart";
188		reg = <0x10033000 0x100>;
189
190		clocks = <&ext>, <&cgu JZ4770_CLK_UART3>;
191		clock-names = "baud", "module";
192
193		interrupt-parent = <&intc>;
194		interrupts = <2>;
195
196		status = "disabled";
197	};
198
199	dmac0: dma-controller@13420000 {
200		compatible = "ingenic,jz4770-dma";
201		reg = <0x13420000 0xC0
202		       0x13420300 0x20>;
203
204		#dma-cells = <1>;
205
206		clocks = <&cgu JZ4770_CLK_DMA>;
207		interrupt-parent = <&intc>;
208		interrupts = <24>;
209
210		/* Disable dmac0 until we have something that uses it */
211		status = "disabled";
212	};
213
214	dmac1: dma-controller@13420100 {
215		compatible = "ingenic,jz4770-dma";
216		reg = <0x13420100 0xC0
217		       0x13420400 0x20>;
218
219		#dma-cells = <1>;
220
221		clocks = <&cgu JZ4770_CLK_DMA>;
222		interrupt-parent = <&intc>;
223		interrupts = <23>;
224
225		/* Disable dmac1 until we have something that uses it */
226		status = "disabled";
227	};
228
229	uhc: uhc@13430000 {
230		compatible = "generic-ohci";
231		reg = <0x13430000 0x1000>;
232
233		clocks = <&cgu JZ4770_CLK_UHC>, <&cgu JZ4770_CLK_UHC_PHY>;
234		assigned-clocks = <&cgu JZ4770_CLK_UHC>;
235		assigned-clock-rates = <48000000>;
236
237		interrupt-parent = <&intc>;
238		interrupts = <20>;
239
240		status = "disabled";
241	};
242};
243