xref: /linux/arch/arm64/boot/dts/allwinner/sun50i-h616.dtsi (revision 7f71507851fc7764b36a3221839607d3a45c2025)
1// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
2// Copyright (C) 2020 Arm Ltd.
3// based on the H6 dtsi, which is:
4//   Copyright (C) 2017 Icenowy Zheng <icenowy@aosc.io>
5
6#include <dt-bindings/interrupt-controller/arm-gic.h>
7#include <dt-bindings/clock/sun50i-h616-ccu.h>
8#include <dt-bindings/clock/sun50i-h6-r-ccu.h>
9#include <dt-bindings/clock/sun6i-rtc.h>
10#include <dt-bindings/reset/sun50i-h616-ccu.h>
11#include <dt-bindings/reset/sun50i-h6-r-ccu.h>
12#include <dt-bindings/thermal/thermal.h>
13
14/ {
15	interrupt-parent = <&gic>;
16	#address-cells = <2>;
17	#size-cells = <2>;
18
19	cpus {
20		#address-cells = <1>;
21		#size-cells = <0>;
22
23		cpu0: cpu@0 {
24			compatible = "arm,cortex-a53";
25			device_type = "cpu";
26			reg = <0>;
27			enable-method = "psci";
28			clocks = <&ccu CLK_CPUX>;
29			#cooling-cells = <2>;
30			i-cache-size = <0x8000>;
31			i-cache-line-size = <64>;
32			i-cache-sets = <256>;
33			d-cache-size = <0x8000>;
34			d-cache-line-size = <64>;
35			d-cache-sets = <128>;
36			next-level-cache = <&l2_cache>;
37		};
38
39		cpu1: cpu@1 {
40			compatible = "arm,cortex-a53";
41			device_type = "cpu";
42			reg = <1>;
43			enable-method = "psci";
44			clocks = <&ccu CLK_CPUX>;
45			#cooling-cells = <2>;
46			i-cache-size = <0x8000>;
47			i-cache-line-size = <64>;
48			i-cache-sets = <256>;
49			d-cache-size = <0x8000>;
50			d-cache-line-size = <64>;
51			d-cache-sets = <128>;
52			next-level-cache = <&l2_cache>;
53		};
54
55		cpu2: cpu@2 {
56			compatible = "arm,cortex-a53";
57			device_type = "cpu";
58			reg = <2>;
59			enable-method = "psci";
60			clocks = <&ccu CLK_CPUX>;
61			#cooling-cells = <2>;
62			i-cache-size = <0x8000>;
63			i-cache-line-size = <64>;
64			i-cache-sets = <256>;
65			d-cache-size = <0x8000>;
66			d-cache-line-size = <64>;
67			d-cache-sets = <128>;
68			next-level-cache = <&l2_cache>;
69		};
70
71		cpu3: cpu@3 {
72			compatible = "arm,cortex-a53";
73			device_type = "cpu";
74			reg = <3>;
75			enable-method = "psci";
76			clocks = <&ccu CLK_CPUX>;
77			#cooling-cells = <2>;
78			i-cache-size = <0x8000>;
79			i-cache-line-size = <64>;
80			i-cache-sets = <256>;
81			d-cache-size = <0x8000>;
82			d-cache-line-size = <64>;
83			d-cache-sets = <128>;
84			next-level-cache = <&l2_cache>;
85		};
86
87		l2_cache: l2-cache {
88			compatible = "cache";
89			cache-level = <2>;
90			cache-unified;
91			cache-size = <0x40000>;
92			cache-line-size = <64>;
93			cache-sets = <256>;
94		};
95	};
96
97	reserved-memory {
98		#address-cells = <2>;
99		#size-cells = <2>;
100		ranges;
101
102		/*
103		 * 256 KiB reserved for Trusted Firmware-A (BL31).
104		 * This is added by BL31 itself, but some bootloaders fail
105		 * to propagate this into the DTB handed to kernels.
106		 */
107		secmon@40000000 {
108			reg = <0x0 0x40000000 0x0 0x40000>;
109			no-map;
110		};
111	};
112
113	osc24M: osc24M-clk {
114		#clock-cells = <0>;
115		compatible = "fixed-clock";
116		clock-frequency = <24000000>;
117		clock-output-names = "osc24M";
118	};
119
120	pmu {
121		compatible = "arm,cortex-a53-pmu";
122		interrupts = <GIC_SPI 140 IRQ_TYPE_LEVEL_HIGH>,
123			     <GIC_SPI 141 IRQ_TYPE_LEVEL_HIGH>,
124			     <GIC_SPI 142 IRQ_TYPE_LEVEL_HIGH>,
125			     <GIC_SPI 143 IRQ_TYPE_LEVEL_HIGH>;
126		interrupt-affinity = <&cpu0>, <&cpu1>, <&cpu2>, <&cpu3>;
127	};
128
129	psci {
130		compatible = "arm,psci-0.2";
131		method = "smc";
132	};
133
134	timer {
135		compatible = "arm,armv8-timer";
136		arm,no-tick-in-suspend;
137		interrupts = <GIC_PPI 13
138			(GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>,
139			     <GIC_PPI 14
140			(GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>,
141			     <GIC_PPI 11
142			(GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>,
143			     <GIC_PPI 10
144			(GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>;
145	};
146
147	soc {
148		compatible = "simple-bus";
149		#address-cells = <1>;
150		#size-cells = <1>;
151		ranges = <0x0 0x0 0x0 0x40000000>;
152
153		crypto: crypto@1904000 {
154			compatible = "allwinner,sun50i-h616-crypto";
155			reg = <0x01904000 0x800>;
156			interrupts = <GIC_SPI 91 IRQ_TYPE_LEVEL_HIGH>;
157			clocks = <&ccu CLK_BUS_CE>, <&ccu CLK_CE>,
158				 <&ccu CLK_MBUS_CE>, <&rtc CLK_IOSC>;
159			clock-names = "bus", "mod", "ram", "trng";
160			resets = <&ccu RST_BUS_CE>;
161		};
162
163		syscon: syscon@3000000 {
164			compatible = "allwinner,sun50i-h616-system-control";
165			reg = <0x03000000 0x1000>;
166			#address-cells = <1>;
167			#size-cells = <1>;
168			ranges;
169
170			sram_c: sram@28000 {
171				compatible = "mmio-sram";
172				reg = <0x00028000 0x30000>;
173				#address-cells = <1>;
174				#size-cells = <1>;
175				ranges = <0 0x00028000 0x30000>;
176			};
177		};
178
179		ccu: clock@3001000 {
180			compatible = "allwinner,sun50i-h616-ccu";
181			reg = <0x03001000 0x1000>;
182			clocks = <&osc24M>, <&rtc CLK_OSC32K>, <&rtc CLK_IOSC>;
183			clock-names = "hosc", "losc", "iosc";
184			#clock-cells = <1>;
185			#reset-cells = <1>;
186		};
187
188		dma: dma-controller@3002000 {
189			compatible = "allwinner,sun50i-h616-dma",
190				     "allwinner,sun50i-a100-dma";
191			reg = <0x03002000 0x1000>;
192			interrupts = <GIC_SPI 42 IRQ_TYPE_LEVEL_HIGH>;
193			clocks = <&ccu CLK_BUS_DMA>, <&ccu CLK_MBUS_DMA>;
194			clock-names = "bus", "mbus";
195			dma-channels = <16>;
196			dma-requests = <49>;
197			resets = <&ccu RST_BUS_DMA>;
198			#dma-cells = <1>;
199		};
200
201		sid: efuse@3006000 {
202			compatible = "allwinner,sun50i-h616-sid", "allwinner,sun50i-a64-sid";
203			reg = <0x03006000 0x1000>;
204			#address-cells = <1>;
205			#size-cells = <1>;
206
207			ths_calibration: thermal-sensor-calibration@14 {
208				reg = <0x14 0x8>;
209			};
210
211			cpu_speed_grade: cpu-speed-grade@0 {
212				reg = <0x0 2>;
213			};
214		};
215
216		watchdog: watchdog@30090a0 {
217			compatible = "allwinner,sun50i-h616-wdt",
218				     "allwinner,sun6i-a31-wdt";
219			reg = <0x030090a0 0x20>;
220			interrupts = <GIC_SPI 50 IRQ_TYPE_LEVEL_HIGH>;
221			clocks = <&osc24M>;
222		};
223
224		pio: pinctrl@300b000 {
225			compatible = "allwinner,sun50i-h616-pinctrl";
226			reg = <0x0300b000 0x400>;
227			interrupts = <GIC_SPI 51 IRQ_TYPE_LEVEL_HIGH>,
228				     <GIC_SPI 52 IRQ_TYPE_LEVEL_HIGH>,
229				     <GIC_SPI 53 IRQ_TYPE_LEVEL_HIGH>,
230				     <GIC_SPI 43 IRQ_TYPE_LEVEL_HIGH>,
231				     <GIC_SPI 54 IRQ_TYPE_LEVEL_HIGH>,
232				     <GIC_SPI 55 IRQ_TYPE_LEVEL_HIGH>,
233				     <GIC_SPI 56 IRQ_TYPE_LEVEL_HIGH>,
234				     <GIC_SPI 57 IRQ_TYPE_LEVEL_HIGH>;
235			clocks = <&ccu CLK_APB1>, <&osc24M>, <&rtc CLK_OSC32K>;
236			clock-names = "apb", "hosc", "losc";
237			gpio-controller;
238			#gpio-cells = <3>;
239			interrupt-controller;
240			#interrupt-cells = <3>;
241
242			ext_rgmii_pins: rgmii-pins {
243				pins = "PI0", "PI1", "PI2", "PI3", "PI4",
244				       "PI5", "PI7", "PI8", "PI9", "PI10",
245				       "PI11", "PI12", "PI13", "PI14", "PI15",
246				       "PI16";
247				function = "emac0";
248				drive-strength = <40>;
249			};
250
251			i2c0_pins: i2c0-pins {
252				pins = "PI5", "PI6";
253				function = "i2c0";
254			};
255
256			i2c3_ph_pins: i2c3-ph-pins {
257				pins = "PH4", "PH5";
258				function = "i2c3";
259			};
260
261			ir_rx_pin: ir-rx-pin {
262				pins = "PH10";
263				function = "ir_rx";
264			};
265
266			mmc0_pins: mmc0-pins {
267				pins = "PF0", "PF1", "PF2", "PF3",
268				       "PF4", "PF5";
269				function = "mmc0";
270				drive-strength = <30>;
271				bias-pull-up;
272			};
273
274			/omit-if-no-ref/
275			mmc1_pins: mmc1-pins {
276				pins = "PG0", "PG1", "PG2", "PG3",
277				       "PG4", "PG5";
278				function = "mmc1";
279				drive-strength = <30>;
280				bias-pull-up;
281			};
282
283			mmc2_pins: mmc2-pins {
284				pins = "PC0", "PC1", "PC5", "PC6",
285				       "PC8", "PC9", "PC10", "PC11",
286				       "PC13", "PC14", "PC15", "PC16";
287				function = "mmc2";
288				drive-strength = <30>;
289				bias-pull-up;
290			};
291
292			/omit-if-no-ref/
293			spi0_pins: spi0-pins {
294				pins = "PC0", "PC2", "PC4";
295				function = "spi0";
296			};
297
298			/omit-if-no-ref/
299			spi0_cs0_pin: spi0-cs0-pin {
300				pins = "PC3";
301				function = "spi0";
302			};
303
304			/omit-if-no-ref/
305			spi1_pins: spi1-pins {
306				pins = "PH6", "PH7", "PH8";
307				function = "spi1";
308			};
309
310			/omit-if-no-ref/
311			spi1_cs0_pin: spi1-cs0-pin {
312				pins = "PH5";
313				function = "spi1";
314			};
315
316			spdif_tx_pin: spdif-tx-pin {
317				pins = "PH4";
318				function = "spdif";
319			};
320
321			uart0_ph_pins: uart0-ph-pins {
322				pins = "PH0", "PH1";
323				function = "uart0";
324			};
325
326			/omit-if-no-ref/
327			uart1_pins: uart1-pins {
328				pins = "PG6", "PG7";
329				function = "uart1";
330			};
331
332			/omit-if-no-ref/
333			uart1_rts_cts_pins: uart1-rts-cts-pins {
334				pins = "PG8", "PG9";
335				function = "uart1";
336			};
337
338			/omit-if-no-ref/
339			x32clk_fanout_pin: x32clk-fanout-pin {
340				pins = "PG10";
341				function = "clock";
342			};
343		};
344
345		gic: interrupt-controller@3021000 {
346			compatible = "arm,gic-400";
347			reg = <0x03021000 0x1000>,
348			      <0x03022000 0x2000>,
349			      <0x03024000 0x2000>,
350			      <0x03026000 0x2000>;
351			interrupts = <GIC_PPI 9 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>;
352			interrupt-controller;
353			#interrupt-cells = <3>;
354		};
355
356		iommu: iommu@30f0000 {
357			compatible = "allwinner,sun50i-h616-iommu";
358			reg = <0x030f0000 0x10000>;
359			interrupts = <GIC_SPI 61 IRQ_TYPE_LEVEL_HIGH>;
360			clocks = <&ccu CLK_BUS_IOMMU>;
361			resets = <&ccu RST_BUS_IOMMU>;
362			#iommu-cells = <1>;
363		};
364
365		mmc0: mmc@4020000 {
366			compatible = "allwinner,sun50i-h616-mmc",
367				     "allwinner,sun50i-a100-mmc";
368			reg = <0x04020000 0x1000>;
369			clocks = <&ccu CLK_BUS_MMC0>, <&ccu CLK_MMC0>;
370			clock-names = "ahb", "mmc";
371			resets = <&ccu RST_BUS_MMC0>;
372			reset-names = "ahb";
373			interrupts = <GIC_SPI 35 IRQ_TYPE_LEVEL_HIGH>;
374			pinctrl-names = "default";
375			pinctrl-0 = <&mmc0_pins>;
376			status = "disabled";
377			max-frequency = <150000000>;
378			cap-sd-highspeed;
379			cap-mmc-highspeed;
380			mmc-ddr-3_3v;
381			cap-sdio-irq;
382			#address-cells = <1>;
383			#size-cells = <0>;
384		};
385
386		mmc1: mmc@4021000 {
387			compatible = "allwinner,sun50i-h616-mmc",
388				     "allwinner,sun50i-a100-mmc";
389			reg = <0x04021000 0x1000>;
390			clocks = <&ccu CLK_BUS_MMC1>, <&ccu CLK_MMC1>;
391			clock-names = "ahb", "mmc";
392			resets = <&ccu RST_BUS_MMC1>;
393			reset-names = "ahb";
394			interrupts = <GIC_SPI 36 IRQ_TYPE_LEVEL_HIGH>;
395			pinctrl-names = "default";
396			pinctrl-0 = <&mmc1_pins>;
397			status = "disabled";
398			max-frequency = <150000000>;
399			cap-sd-highspeed;
400			cap-mmc-highspeed;
401			mmc-ddr-3_3v;
402			cap-sdio-irq;
403			#address-cells = <1>;
404			#size-cells = <0>;
405		};
406
407		mmc2: mmc@4022000 {
408			compatible = "allwinner,sun50i-h616-emmc",
409				     "allwinner,sun50i-a100-emmc";
410			reg = <0x04022000 0x1000>;
411			clocks = <&ccu CLK_BUS_MMC2>, <&ccu CLK_MMC2>;
412			clock-names = "ahb", "mmc";
413			resets = <&ccu RST_BUS_MMC2>;
414			reset-names = "ahb";
415			interrupts = <GIC_SPI 37 IRQ_TYPE_LEVEL_HIGH>;
416			pinctrl-names = "default";
417			pinctrl-0 = <&mmc2_pins>;
418			status = "disabled";
419			max-frequency = <150000000>;
420			cap-sd-highspeed;
421			cap-mmc-highspeed;
422			mmc-ddr-3_3v;
423			cap-sdio-irq;
424			#address-cells = <1>;
425			#size-cells = <0>;
426		};
427
428		uart0: serial@5000000 {
429			compatible = "snps,dw-apb-uart";
430			reg = <0x05000000 0x400>;
431			interrupts = <GIC_SPI 0 IRQ_TYPE_LEVEL_HIGH>;
432			reg-shift = <2>;
433			reg-io-width = <4>;
434			clocks = <&ccu CLK_BUS_UART0>;
435			dmas = <&dma 14>, <&dma 14>;
436			dma-names = "tx", "rx";
437			resets = <&ccu RST_BUS_UART0>;
438			status = "disabled";
439		};
440
441		uart1: serial@5000400 {
442			compatible = "snps,dw-apb-uart";
443			reg = <0x05000400 0x400>;
444			interrupts = <GIC_SPI 1 IRQ_TYPE_LEVEL_HIGH>;
445			reg-shift = <2>;
446			reg-io-width = <4>;
447			clocks = <&ccu CLK_BUS_UART1>;
448			dmas = <&dma 15>, <&dma 15>;
449			dma-names = "tx", "rx";
450			resets = <&ccu RST_BUS_UART1>;
451			status = "disabled";
452		};
453
454		uart2: serial@5000800 {
455			compatible = "snps,dw-apb-uart";
456			reg = <0x05000800 0x400>;
457			interrupts = <GIC_SPI 2 IRQ_TYPE_LEVEL_HIGH>;
458			reg-shift = <2>;
459			reg-io-width = <4>;
460			clocks = <&ccu CLK_BUS_UART2>;
461			dmas = <&dma 16>, <&dma 16>;
462			dma-names = "tx", "rx";
463			resets = <&ccu RST_BUS_UART2>;
464			status = "disabled";
465		};
466
467		uart3: serial@5000c00 {
468			compatible = "snps,dw-apb-uart";
469			reg = <0x05000c00 0x400>;
470			interrupts = <GIC_SPI 3 IRQ_TYPE_LEVEL_HIGH>;
471			reg-shift = <2>;
472			reg-io-width = <4>;
473			clocks = <&ccu CLK_BUS_UART3>;
474			dmas = <&dma 17>, <&dma 17>;
475			dma-names = "tx", "rx";
476			resets = <&ccu RST_BUS_UART3>;
477			status = "disabled";
478		};
479
480		uart4: serial@5001000 {
481			compatible = "snps,dw-apb-uart";
482			reg = <0x05001000 0x400>;
483			interrupts = <GIC_SPI 4 IRQ_TYPE_LEVEL_HIGH>;
484			reg-shift = <2>;
485			reg-io-width = <4>;
486			clocks = <&ccu CLK_BUS_UART4>;
487			dmas = <&dma 18>, <&dma 18>;
488			dma-names = "tx", "rx";
489			resets = <&ccu RST_BUS_UART4>;
490			status = "disabled";
491		};
492
493		uart5: serial@5001400 {
494			compatible = "snps,dw-apb-uart";
495			reg = <0x05001400 0x400>;
496			interrupts = <GIC_SPI 5 IRQ_TYPE_LEVEL_HIGH>;
497			reg-shift = <2>;
498			reg-io-width = <4>;
499			clocks = <&ccu CLK_BUS_UART5>;
500			dmas = <&dma 19>, <&dma 19>;
501			dma-names = "tx", "rx";
502			resets = <&ccu RST_BUS_UART5>;
503			status = "disabled";
504		};
505
506		i2c0: i2c@5002000 {
507			compatible = "allwinner,sun50i-h616-i2c",
508				     "allwinner,sun8i-v536-i2c",
509				     "allwinner,sun6i-a31-i2c";
510			reg = <0x05002000 0x400>;
511			interrupts = <GIC_SPI 6 IRQ_TYPE_LEVEL_HIGH>;
512			clocks = <&ccu CLK_BUS_I2C0>;
513			dmas = <&dma 43>, <&dma 43>;
514			dma-names = "rx", "tx";
515			resets = <&ccu RST_BUS_I2C0>;
516			pinctrl-names = "default";
517			pinctrl-0 = <&i2c0_pins>;
518			status = "disabled";
519			#address-cells = <1>;
520			#size-cells = <0>;
521		};
522
523		i2c1: i2c@5002400 {
524			compatible = "allwinner,sun50i-h616-i2c",
525				     "allwinner,sun8i-v536-i2c",
526				     "allwinner,sun6i-a31-i2c";
527			reg = <0x05002400 0x400>;
528			interrupts = <GIC_SPI 7 IRQ_TYPE_LEVEL_HIGH>;
529			clocks = <&ccu CLK_BUS_I2C1>;
530			dmas = <&dma 44>, <&dma 44>;
531			dma-names = "rx", "tx";
532			resets = <&ccu RST_BUS_I2C1>;
533			status = "disabled";
534			#address-cells = <1>;
535			#size-cells = <0>;
536		};
537
538		i2c2: i2c@5002800 {
539			compatible = "allwinner,sun50i-h616-i2c",
540				     "allwinner,sun8i-v536-i2c",
541				     "allwinner,sun6i-a31-i2c";
542			reg = <0x05002800 0x400>;
543			interrupts = <GIC_SPI 8 IRQ_TYPE_LEVEL_HIGH>;
544			clocks = <&ccu CLK_BUS_I2C2>;
545			dmas = <&dma 45>, <&dma 45>;
546			dma-names = "rx", "tx";
547			resets = <&ccu RST_BUS_I2C2>;
548			status = "disabled";
549			#address-cells = <1>;
550			#size-cells = <0>;
551		};
552
553		i2c3: i2c@5002c00 {
554			compatible = "allwinner,sun50i-h616-i2c",
555				     "allwinner,sun8i-v536-i2c",
556				     "allwinner,sun6i-a31-i2c";
557			reg = <0x05002c00 0x400>;
558			interrupts = <GIC_SPI 9 IRQ_TYPE_LEVEL_HIGH>;
559			clocks = <&ccu CLK_BUS_I2C3>;
560			dmas = <&dma 46>, <&dma 46>;
561			dma-names = "rx", "tx";
562			resets = <&ccu RST_BUS_I2C3>;
563			status = "disabled";
564			#address-cells = <1>;
565			#size-cells = <0>;
566		};
567
568		i2c4: i2c@5003000 {
569			compatible = "allwinner,sun50i-h616-i2c",
570				     "allwinner,sun8i-v536-i2c",
571				     "allwinner,sun6i-a31-i2c";
572			reg = <0x05003000 0x400>;
573			interrupts = <GIC_SPI 10 IRQ_TYPE_LEVEL_HIGH>;
574			clocks = <&ccu CLK_BUS_I2C4>;
575			dmas = <&dma 47>, <&dma 47>;
576			dma-names = "rx", "tx";
577			resets = <&ccu RST_BUS_I2C4>;
578			status = "disabled";
579			#address-cells = <1>;
580			#size-cells = <0>;
581		};
582
583		spi0: spi@5010000 {
584			compatible = "allwinner,sun50i-h616-spi",
585				     "allwinner,sun8i-h3-spi";
586			reg = <0x05010000 0x1000>;
587			interrupts = <GIC_SPI 12 IRQ_TYPE_LEVEL_HIGH>;
588			clocks = <&ccu CLK_BUS_SPI0>, <&ccu CLK_SPI0>;
589			clock-names = "ahb", "mod";
590			dmas = <&dma 22>, <&dma 22>;
591			dma-names = "rx", "tx";
592			resets = <&ccu RST_BUS_SPI0>;
593			status = "disabled";
594			#address-cells = <1>;
595			#size-cells = <0>;
596		};
597
598		spi1: spi@5011000 {
599			compatible = "allwinner,sun50i-h616-spi",
600				     "allwinner,sun8i-h3-spi";
601			reg = <0x05011000 0x1000>;
602			interrupts = <GIC_SPI 13 IRQ_TYPE_LEVEL_HIGH>;
603			clocks = <&ccu CLK_BUS_SPI1>, <&ccu CLK_SPI1>;
604			clock-names = "ahb", "mod";
605			dmas = <&dma 23>, <&dma 23>;
606			dma-names = "rx", "tx";
607			resets = <&ccu RST_BUS_SPI1>;
608			status = "disabled";
609			#address-cells = <1>;
610			#size-cells = <0>;
611		};
612
613		emac0: ethernet@5020000 {
614			compatible = "allwinner,sun50i-h616-emac0",
615				     "allwinner,sun50i-a64-emac";
616			reg = <0x05020000 0x10000>;
617			interrupts = <GIC_SPI 14 IRQ_TYPE_LEVEL_HIGH>;
618			interrupt-names = "macirq";
619			clocks = <&ccu CLK_BUS_EMAC0>;
620			clock-names = "stmmaceth";
621			resets = <&ccu RST_BUS_EMAC0>;
622			reset-names = "stmmaceth";
623			syscon = <&syscon>;
624			status = "disabled";
625
626			mdio0: mdio {
627				compatible = "snps,dwmac-mdio";
628				#address-cells = <1>;
629				#size-cells = <0>;
630			};
631		};
632
633		gpadc: adc@5070000 {
634			compatible = "allwinner,sun50i-h616-gpadc",
635				     "allwinner,sun20i-d1-gpadc";
636			reg = <0x05070000 0x400>;
637			clocks = <&ccu CLK_BUS_GPADC>;
638			resets = <&ccu RST_BUS_GPADC>;
639			interrupts = <GIC_SPI 18 IRQ_TYPE_LEVEL_HIGH>;
640			status = "disabled";
641			#io-channel-cells = <1>;
642		};
643
644		ths: thermal-sensor@5070400 {
645			compatible = "allwinner,sun50i-h616-ths";
646			reg = <0x05070400 0x400>;
647			interrupts = <GIC_SPI 19 IRQ_TYPE_LEVEL_HIGH>;
648			clocks = <&ccu CLK_BUS_THS>;
649			clock-names = "bus";
650			resets = <&ccu RST_BUS_THS>;
651			nvmem-cells = <&ths_calibration>;
652			nvmem-cell-names = "calibration";
653			allwinner,sram = <&syscon>;
654			#thermal-sensor-cells = <1>;
655		};
656
657		lradc: lradc@5070800 {
658			compatible = "allwinner,sun50i-h616-lradc",
659				     "allwinner,sun50i-r329-lradc";
660			reg = <0x05070800 0x400>;
661			interrupts = <GIC_SPI 20 IRQ_TYPE_LEVEL_HIGH>;
662			clocks = <&ccu CLK_BUS_KEYADC>;
663			resets = <&ccu RST_BUS_KEYADC>;
664			status = "disabled";
665		};
666
667		spdif: spdif@5093000 {
668			compatible = "allwinner,sun50i-h616-spdif";
669			reg = <0x05093000 0x400>;
670			interrupts = <GIC_SPI 21 IRQ_TYPE_LEVEL_HIGH>;
671			clocks = <&ccu CLK_BUS_SPDIF>, <&ccu CLK_SPDIF>;
672			clock-names = "apb", "spdif";
673			resets = <&ccu RST_BUS_SPDIF>;
674			dmas = <&dma 2>;
675			dma-names = "tx";
676			pinctrl-names = "default";
677			pinctrl-0 = <&spdif_tx_pin>;
678			#sound-dai-cells = <0>;
679			status = "disabled";
680		};
681
682		codec: codec@5096000 {
683			#sound-dai-cells = <0>;
684			compatible = "allwinner,sun50i-h616-codec";
685			reg = <0x05096000 0x31c>;
686			interrupts = <GIC_SPI 58 IRQ_TYPE_LEVEL_HIGH>;
687			clocks = <&ccu CLK_BUS_AUDIO_CODEC>,
688				 <&ccu CLK_AUDIO_CODEC_1X>;
689			clock-names = "apb", "codec";
690			resets = <&ccu RST_BUS_AUDIO_CODEC>;
691			dmas = <&dma 6>;
692			dma-names = "tx";
693			status = "disabled";
694		};
695
696		usbotg: usb@5100000 {
697			compatible = "allwinner,sun50i-h616-musb",
698				     "allwinner,sun8i-h3-musb";
699			reg = <0x05100000 0x0400>;
700			clocks = <&ccu CLK_BUS_OTG>;
701			resets = <&ccu RST_BUS_OTG>;
702			interrupts = <GIC_SPI 25 IRQ_TYPE_LEVEL_HIGH>;
703			interrupt-names = "mc";
704			phys = <&usbphy 0>;
705			phy-names = "usb";
706			extcon = <&usbphy 0>;
707			status = "disabled";
708		};
709
710		usbphy: phy@5100400 {
711			compatible = "allwinner,sun50i-h616-usb-phy";
712			reg = <0x05100400 0x24>,
713			      <0x05101800 0x14>,
714			      <0x05200800 0x14>,
715			      <0x05310800 0x14>,
716			      <0x05311800 0x14>;
717			reg-names = "phy_ctrl",
718				    "pmu0",
719				    "pmu1",
720				    "pmu2",
721				    "pmu3";
722			clocks = <&ccu CLK_USB_PHY0>,
723				 <&ccu CLK_USB_PHY1>,
724				 <&ccu CLK_USB_PHY2>,
725				 <&ccu CLK_USB_PHY3>,
726				 <&ccu CLK_BUS_EHCI2>;
727			clock-names = "usb0_phy",
728				      "usb1_phy",
729				      "usb2_phy",
730				      "usb3_phy",
731				      "pmu2_clk";
732			resets = <&ccu RST_USB_PHY0>,
733				 <&ccu RST_USB_PHY1>,
734				 <&ccu RST_USB_PHY2>,
735				 <&ccu RST_USB_PHY3>;
736			reset-names = "usb0_reset",
737				      "usb1_reset",
738				      "usb2_reset",
739				      "usb3_reset";
740			status = "disabled";
741			#phy-cells = <1>;
742		};
743
744		ehci0: usb@5101000 {
745			compatible = "allwinner,sun50i-h616-ehci",
746				     "generic-ehci";
747			reg = <0x05101000 0x100>;
748			interrupts = <GIC_SPI 26 IRQ_TYPE_LEVEL_HIGH>;
749			clocks = <&ccu CLK_BUS_OHCI0>,
750				 <&ccu CLK_BUS_EHCI0>,
751				 <&ccu CLK_USB_OHCI0>;
752			resets = <&ccu RST_BUS_OHCI0>,
753				 <&ccu RST_BUS_EHCI0>;
754			phys = <&usbphy 0>;
755			phy-names = "usb";
756			status = "disabled";
757		};
758
759		ohci0: usb@5101400 {
760			compatible = "allwinner,sun50i-h616-ohci",
761				     "generic-ohci";
762			reg = <0x05101400 0x100>;
763			interrupts = <GIC_SPI 27 IRQ_TYPE_LEVEL_HIGH>;
764			clocks = <&ccu CLK_BUS_OHCI0>,
765				 <&ccu CLK_USB_OHCI0>;
766			resets = <&ccu RST_BUS_OHCI0>;
767			phys = <&usbphy 0>;
768			phy-names = "usb";
769			status = "disabled";
770		};
771
772		ehci1: usb@5200000 {
773			compatible = "allwinner,sun50i-h616-ehci",
774				     "generic-ehci";
775			reg = <0x05200000 0x100>;
776			interrupts = <GIC_SPI 28 IRQ_TYPE_LEVEL_HIGH>;
777			clocks = <&ccu CLK_BUS_OHCI1>,
778				 <&ccu CLK_BUS_EHCI1>,
779				 <&ccu CLK_USB_OHCI1>;
780			resets = <&ccu RST_BUS_OHCI1>,
781				 <&ccu RST_BUS_EHCI1>;
782			phys = <&usbphy 1>;
783			phy-names = "usb";
784			status = "disabled";
785		};
786
787		ohci1: usb@5200400 {
788			compatible = "allwinner,sun50i-h616-ohci",
789				     "generic-ohci";
790			reg = <0x05200400 0x100>;
791			interrupts = <GIC_SPI 29 IRQ_TYPE_LEVEL_HIGH>;
792			clocks = <&ccu CLK_BUS_OHCI1>,
793				 <&ccu CLK_USB_OHCI1>;
794			resets = <&ccu RST_BUS_OHCI1>;
795			phys = <&usbphy 1>;
796			phy-names = "usb";
797			status = "disabled";
798		};
799
800		ehci2: usb@5310000 {
801			compatible = "allwinner,sun50i-h616-ehci",
802				     "generic-ehci";
803			reg = <0x05310000 0x100>;
804			interrupts = <GIC_SPI 30 IRQ_TYPE_LEVEL_HIGH>;
805			clocks = <&ccu CLK_BUS_OHCI2>,
806				 <&ccu CLK_BUS_EHCI2>,
807				 <&ccu CLK_USB_OHCI2>;
808			resets = <&ccu RST_BUS_OHCI2>,
809				 <&ccu RST_BUS_EHCI2>;
810			phys = <&usbphy 2>;
811			phy-names = "usb";
812			status = "disabled";
813		};
814
815		ohci2: usb@5310400 {
816			compatible = "allwinner,sun50i-h616-ohci",
817				     "generic-ohci";
818			reg = <0x05310400 0x100>;
819			interrupts = <GIC_SPI 31 IRQ_TYPE_LEVEL_HIGH>;
820			clocks = <&ccu CLK_BUS_OHCI2>,
821				 <&ccu CLK_USB_OHCI2>;
822			resets = <&ccu RST_BUS_OHCI2>;
823			phys = <&usbphy 2>;
824			phy-names = "usb";
825			status = "disabled";
826		};
827
828		ehci3: usb@5311000 {
829			compatible = "allwinner,sun50i-h616-ehci",
830				     "generic-ehci";
831			reg = <0x05311000 0x100>;
832			interrupts = <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>;
833			clocks = <&ccu CLK_BUS_OHCI3>,
834				 <&ccu CLK_BUS_EHCI3>,
835				 <&ccu CLK_USB_OHCI3>;
836			resets = <&ccu RST_BUS_OHCI3>,
837				 <&ccu RST_BUS_EHCI3>;
838			phys = <&usbphy 3>;
839			phy-names = "usb";
840			status = "disabled";
841		};
842
843		ohci3: usb@5311400 {
844			compatible = "allwinner,sun50i-h616-ohci",
845				     "generic-ohci";
846			reg = <0x05311400 0x100>;
847			interrupts = <GIC_SPI 33 IRQ_TYPE_LEVEL_HIGH>;
848			clocks = <&ccu CLK_BUS_OHCI3>,
849				 <&ccu CLK_USB_OHCI3>;
850			resets = <&ccu RST_BUS_OHCI3>;
851			phys = <&usbphy 3>;
852			phy-names = "usb";
853			status = "disabled";
854		};
855
856		rtc: rtc@7000000 {
857			compatible = "allwinner,sun50i-h616-rtc";
858			reg = <0x07000000 0x400>;
859			interrupts = <GIC_SPI 104 IRQ_TYPE_LEVEL_HIGH>;
860			clocks = <&r_ccu CLK_R_APB1_RTC>, <&osc24M>,
861				 <&ccu CLK_PLL_SYSTEM_32K>;
862			clock-names = "bus", "hosc",
863				      "pll-32k";
864			#clock-cells = <1>;
865		};
866
867		r_ccu: clock@7010000 {
868			compatible = "allwinner,sun50i-h616-r-ccu";
869			reg = <0x07010000 0x210>;
870			clocks = <&osc24M>, <&rtc CLK_OSC32K>, <&rtc CLK_IOSC>,
871				 <&ccu CLK_PLL_PERIPH0>;
872			clock-names = "hosc", "losc", "iosc", "pll-periph";
873			#clock-cells = <1>;
874			#reset-cells = <1>;
875		};
876
877		nmi_intc: interrupt-controller@7010320 {
878			compatible = "allwinner,sun50i-h616-nmi",
879				     "allwinner,sun9i-a80-nmi";
880			reg = <0x07010320 0xc>;
881			interrupt-controller;
882			#interrupt-cells = <2>;
883			interrupts = <GIC_SPI 103 IRQ_TYPE_LEVEL_HIGH>;
884		};
885
886		r_pio: pinctrl@7022000 {
887			compatible = "allwinner,sun50i-h616-r-pinctrl";
888			reg = <0x07022000 0x400>;
889			clocks = <&r_ccu CLK_R_APB1>, <&osc24M>,
890				 <&rtc CLK_OSC32K>;
891			clock-names = "apb", "hosc", "losc";
892			gpio-controller;
893			#gpio-cells = <3>;
894
895			/omit-if-no-ref/
896			r_i2c_pins: r-i2c-pins {
897				pins = "PL0", "PL1";
898				function = "s_i2c";
899			};
900
901			r_rsb_pins: r-rsb-pins {
902				pins = "PL0", "PL1";
903				function = "s_rsb";
904			};
905		};
906
907		ir: ir@7040000 {
908			compatible = "allwinner,sun50i-h616-ir",
909				     "allwinner,sun6i-a31-ir";
910			reg = <0x07040000 0x400>;
911			interrupts = <GIC_SPI 106 IRQ_TYPE_LEVEL_HIGH>;
912			clocks = <&r_ccu CLK_R_APB1_IR>,
913				 <&r_ccu CLK_IR>;
914			clock-names = "apb", "ir";
915			resets = <&r_ccu RST_R_APB1_IR>;
916			pinctrl-names = "default";
917			pinctrl-0 = <&ir_rx_pin>;
918			status = "disabled";
919		};
920
921		r_i2c: i2c@7081400 {
922			compatible = "allwinner,sun50i-h616-i2c",
923				     "allwinner,sun8i-v536-i2c",
924				     "allwinner,sun6i-a31-i2c";
925			reg = <0x07081400 0x400>;
926			interrupts = <GIC_SPI 105 IRQ_TYPE_LEVEL_HIGH>;
927			clocks = <&r_ccu CLK_R_APB2_I2C>;
928			dmas = <&dma 48>, <&dma 48>;
929			dma-names = "rx", "tx";
930			resets = <&r_ccu RST_R_APB2_I2C>;
931			pinctrl-names = "default";
932			pinctrl-0 = <&r_i2c_pins>;
933			status = "disabled";
934			#address-cells = <1>;
935			#size-cells = <0>;
936		};
937
938		r_rsb: rsb@7083000 {
939			compatible = "allwinner,sun50i-h616-rsb",
940				     "allwinner,sun8i-a23-rsb";
941			reg = <0x07083000 0x400>;
942			interrupts = <GIC_SPI 109 IRQ_TYPE_LEVEL_HIGH>;
943			clocks = <&r_ccu CLK_R_APB2_RSB>;
944			clock-frequency = <3000000>;
945			resets = <&r_ccu RST_R_APB2_RSB>;
946			pinctrl-names = "default";
947			pinctrl-0 = <&r_rsb_pins>;
948			status = "disabled";
949			#address-cells = <1>;
950			#size-cells = <0>;
951		};
952	};
953
954	thermal-zones {
955		cpu-thermal {
956			polling-delay-passive = <500>;
957			polling-delay = <1000>;
958			thermal-sensors = <&ths 2>;
959			sustainable-power = <1000>;
960
961			trips {
962				cpu_threshold: cpu-trip-0 {
963					temperature = <60000>;
964					type = "passive";
965					hysteresis = <0>;
966				};
967				cpu_target: cpu-trip-1 {
968					temperature = <70000>;
969					type = "passive";
970					hysteresis = <0>;
971				};
972				cpu_critical: cpu-trip-2 {
973					temperature = <110000>;
974					type = "critical";
975					hysteresis = <0>;
976				};
977			};
978		};
979
980		gpu-thermal {
981			polling-delay-passive = <500>;
982			polling-delay = <1000>;
983			thermal-sensors = <&ths 0>;
984			sustainable-power = <1100>;
985
986			trips {
987				gpu_temp_critical: gpu-trip-0 {
988					temperature = <110000>;
989					type = "critical";
990					hysteresis = <0>;
991				};
992			};
993		};
994
995		ve-thermal {
996			polling-delay-passive = <0>;
997			polling-delay = <0>;
998			thermal-sensors = <&ths 1>;
999
1000			trips {
1001				ve_temp_critical: ve-trip-0 {
1002					temperature = <110000>;
1003					type = "critical";
1004					hysteresis = <0>;
1005				};
1006			};
1007		};
1008
1009		ddr-thermal {
1010			polling-delay-passive = <0>;
1011			polling-delay = <0>;
1012			thermal-sensors = <&ths 3>;
1013
1014			trips {
1015				ddr_temp_critical: ddr-trip-0 {
1016					temperature = <110000>;
1017					type = "critical";
1018					hysteresis = <0>;
1019				};
1020			};
1021		};
1022	};
1023};
1024