xref: /linux/scripts/dtc/include-prefixes/riscv/starfive/jh7110.dtsi (revision 5e7922abddd4aab1dd604aa3fc7905d2c638c92b)
160bf0a39SEmil Renner Berthing// SPDX-License-Identifier: GPL-2.0 OR MIT
260bf0a39SEmil Renner Berthing/*
360bf0a39SEmil Renner Berthing * Copyright (C) 2022 StarFive Technology Co., Ltd.
460bf0a39SEmil Renner Berthing * Copyright (C) 2022 Emil Renner Berthing <kernel@esmil.dk>
560bf0a39SEmil Renner Berthing */
660bf0a39SEmil Renner Berthing
760bf0a39SEmil Renner Berthing/dts-v1/;
860bf0a39SEmil Renner Berthing#include <dt-bindings/clock/starfive,jh7110-crg.h>
93d90131fSXingyu Wu#include <dt-bindings/power/starfive,jh7110-pmu.h>
1060bf0a39SEmil Renner Berthing#include <dt-bindings/reset/starfive,jh7110-crg.h>
11f2b539afSHal Feng#include <dt-bindings/thermal/thermal.h>
1260bf0a39SEmil Renner Berthing
1360bf0a39SEmil Renner Berthing/ {
1460bf0a39SEmil Renner Berthing	compatible = "starfive,jh7110";
1560bf0a39SEmil Renner Berthing	#address-cells = <2>;
1660bf0a39SEmil Renner Berthing	#size-cells = <2>;
1760bf0a39SEmil Renner Berthing
18*5e7922abSJisheng Zhang	cpus: cpus {
1960bf0a39SEmil Renner Berthing		#address-cells = <1>;
2060bf0a39SEmil Renner Berthing		#size-cells = <0>;
2160bf0a39SEmil Renner Berthing
2260bf0a39SEmil Renner Berthing		S7_0: cpu@0 {
2360bf0a39SEmil Renner Berthing			compatible = "sifive,s7", "riscv";
2460bf0a39SEmil Renner Berthing			reg = <0>;
2560bf0a39SEmil Renner Berthing			device_type = "cpu";
2660bf0a39SEmil Renner Berthing			i-cache-block-size = <64>;
2760bf0a39SEmil Renner Berthing			i-cache-sets = <64>;
2860bf0a39SEmil Renner Berthing			i-cache-size = <16384>;
2960bf0a39SEmil Renner Berthing			next-level-cache = <&ccache>;
3060bf0a39SEmil Renner Berthing			riscv,isa = "rv64imac_zba_zbb";
3181b5948cSConor Dooley			riscv,isa-base = "rv64i";
3281b5948cSConor Dooley			riscv,isa-extensions = "i", "m", "a", "c", "zba", "zbb", "zicntr", "zicsr",
3381b5948cSConor Dooley					       "zifencei", "zihpm";
3460bf0a39SEmil Renner Berthing			status = "disabled";
3560bf0a39SEmil Renner Berthing
3660bf0a39SEmil Renner Berthing			cpu0_intc: interrupt-controller {
3760bf0a39SEmil Renner Berthing				compatible = "riscv,cpu-intc";
3860bf0a39SEmil Renner Berthing				interrupt-controller;
3960bf0a39SEmil Renner Berthing				#interrupt-cells = <1>;
4060bf0a39SEmil Renner Berthing			};
4160bf0a39SEmil Renner Berthing		};
4260bf0a39SEmil Renner Berthing
4360bf0a39SEmil Renner Berthing		U74_1: cpu@1 {
4460bf0a39SEmil Renner Berthing			compatible = "sifive,u74-mc", "riscv";
4560bf0a39SEmil Renner Berthing			reg = <1>;
4660bf0a39SEmil Renner Berthing			d-cache-block-size = <64>;
4760bf0a39SEmil Renner Berthing			d-cache-sets = <64>;
4860bf0a39SEmil Renner Berthing			d-cache-size = <32768>;
4960bf0a39SEmil Renner Berthing			d-tlb-sets = <1>;
5060bf0a39SEmil Renner Berthing			d-tlb-size = <40>;
5160bf0a39SEmil Renner Berthing			device_type = "cpu";
5260bf0a39SEmil Renner Berthing			i-cache-block-size = <64>;
5360bf0a39SEmil Renner Berthing			i-cache-sets = <64>;
5460bf0a39SEmil Renner Berthing			i-cache-size = <32768>;
5560bf0a39SEmil Renner Berthing			i-tlb-sets = <1>;
5660bf0a39SEmil Renner Berthing			i-tlb-size = <40>;
5760bf0a39SEmil Renner Berthing			mmu-type = "riscv,sv39";
5860bf0a39SEmil Renner Berthing			next-level-cache = <&ccache>;
5960bf0a39SEmil Renner Berthing			riscv,isa = "rv64imafdc_zba_zbb";
6081b5948cSConor Dooley			riscv,isa-base = "rv64i";
6181b5948cSConor Dooley			riscv,isa-extensions = "i", "m", "a", "f", "d", "c", "zba", "zbb", "zicntr",
6281b5948cSConor Dooley					       "zicsr", "zifencei", "zihpm";
6360bf0a39SEmil Renner Berthing			tlb-split;
64e2c510d6SMason Huo			operating-points-v2 = <&cpu_opp>;
65e2c510d6SMason Huo			clocks = <&syscrg JH7110_SYSCLK_CPU_CORE>;
66e2c510d6SMason Huo			clock-names = "cpu";
67f2b539afSHal Feng			#cooling-cells = <2>;
6860bf0a39SEmil Renner Berthing
6960bf0a39SEmil Renner Berthing			cpu1_intc: interrupt-controller {
7060bf0a39SEmil Renner Berthing				compatible = "riscv,cpu-intc";
7160bf0a39SEmil Renner Berthing				interrupt-controller;
7260bf0a39SEmil Renner Berthing				#interrupt-cells = <1>;
7360bf0a39SEmil Renner Berthing			};
7460bf0a39SEmil Renner Berthing		};
7560bf0a39SEmil Renner Berthing
7660bf0a39SEmil Renner Berthing		U74_2: cpu@2 {
7760bf0a39SEmil Renner Berthing			compatible = "sifive,u74-mc", "riscv";
7860bf0a39SEmil Renner Berthing			reg = <2>;
7960bf0a39SEmil Renner Berthing			d-cache-block-size = <64>;
8060bf0a39SEmil Renner Berthing			d-cache-sets = <64>;
8160bf0a39SEmil Renner Berthing			d-cache-size = <32768>;
8260bf0a39SEmil Renner Berthing			d-tlb-sets = <1>;
8360bf0a39SEmil Renner Berthing			d-tlb-size = <40>;
8460bf0a39SEmil Renner Berthing			device_type = "cpu";
8560bf0a39SEmil Renner Berthing			i-cache-block-size = <64>;
8660bf0a39SEmil Renner Berthing			i-cache-sets = <64>;
8760bf0a39SEmil Renner Berthing			i-cache-size = <32768>;
8860bf0a39SEmil Renner Berthing			i-tlb-sets = <1>;
8960bf0a39SEmil Renner Berthing			i-tlb-size = <40>;
9060bf0a39SEmil Renner Berthing			mmu-type = "riscv,sv39";
9160bf0a39SEmil Renner Berthing			next-level-cache = <&ccache>;
9260bf0a39SEmil Renner Berthing			riscv,isa = "rv64imafdc_zba_zbb";
9381b5948cSConor Dooley			riscv,isa-base = "rv64i";
9481b5948cSConor Dooley			riscv,isa-extensions = "i", "m", "a", "f", "d", "c", "zba", "zbb", "zicntr",
9581b5948cSConor Dooley					       "zicsr", "zifencei", "zihpm";
9660bf0a39SEmil Renner Berthing			tlb-split;
97e2c510d6SMason Huo			operating-points-v2 = <&cpu_opp>;
98e2c510d6SMason Huo			clocks = <&syscrg JH7110_SYSCLK_CPU_CORE>;
99e2c510d6SMason Huo			clock-names = "cpu";
100f2b539afSHal Feng			#cooling-cells = <2>;
10160bf0a39SEmil Renner Berthing
10260bf0a39SEmil Renner Berthing			cpu2_intc: interrupt-controller {
10360bf0a39SEmil Renner Berthing				compatible = "riscv,cpu-intc";
10460bf0a39SEmil Renner Berthing				interrupt-controller;
10560bf0a39SEmil Renner Berthing				#interrupt-cells = <1>;
10660bf0a39SEmil Renner Berthing			};
10760bf0a39SEmil Renner Berthing		};
10860bf0a39SEmil Renner Berthing
10960bf0a39SEmil Renner Berthing		U74_3: cpu@3 {
11060bf0a39SEmil Renner Berthing			compatible = "sifive,u74-mc", "riscv";
11160bf0a39SEmil Renner Berthing			reg = <3>;
11260bf0a39SEmil Renner Berthing			d-cache-block-size = <64>;
11360bf0a39SEmil Renner Berthing			d-cache-sets = <64>;
11460bf0a39SEmil Renner Berthing			d-cache-size = <32768>;
11560bf0a39SEmil Renner Berthing			d-tlb-sets = <1>;
11660bf0a39SEmil Renner Berthing			d-tlb-size = <40>;
11760bf0a39SEmil Renner Berthing			device_type = "cpu";
11860bf0a39SEmil Renner Berthing			i-cache-block-size = <64>;
11960bf0a39SEmil Renner Berthing			i-cache-sets = <64>;
12060bf0a39SEmil Renner Berthing			i-cache-size = <32768>;
12160bf0a39SEmil Renner Berthing			i-tlb-sets = <1>;
12260bf0a39SEmil Renner Berthing			i-tlb-size = <40>;
12360bf0a39SEmil Renner Berthing			mmu-type = "riscv,sv39";
12460bf0a39SEmil Renner Berthing			next-level-cache = <&ccache>;
12560bf0a39SEmil Renner Berthing			riscv,isa = "rv64imafdc_zba_zbb";
12681b5948cSConor Dooley			riscv,isa-base = "rv64i";
12781b5948cSConor Dooley			riscv,isa-extensions = "i", "m", "a", "f", "d", "c", "zba", "zbb", "zicntr",
12881b5948cSConor Dooley					       "zicsr", "zifencei", "zihpm";
12960bf0a39SEmil Renner Berthing			tlb-split;
130e2c510d6SMason Huo			operating-points-v2 = <&cpu_opp>;
131e2c510d6SMason Huo			clocks = <&syscrg JH7110_SYSCLK_CPU_CORE>;
132e2c510d6SMason Huo			clock-names = "cpu";
133f2b539afSHal Feng			#cooling-cells = <2>;
13460bf0a39SEmil Renner Berthing
13560bf0a39SEmil Renner Berthing			cpu3_intc: interrupt-controller {
13660bf0a39SEmil Renner Berthing				compatible = "riscv,cpu-intc";
13760bf0a39SEmil Renner Berthing				interrupt-controller;
13860bf0a39SEmil Renner Berthing				#interrupt-cells = <1>;
13960bf0a39SEmil Renner Berthing			};
14060bf0a39SEmil Renner Berthing		};
14160bf0a39SEmil Renner Berthing
14260bf0a39SEmil Renner Berthing		U74_4: cpu@4 {
14360bf0a39SEmil Renner Berthing			compatible = "sifive,u74-mc", "riscv";
14460bf0a39SEmil Renner Berthing			reg = <4>;
14560bf0a39SEmil Renner Berthing			d-cache-block-size = <64>;
14660bf0a39SEmil Renner Berthing			d-cache-sets = <64>;
14760bf0a39SEmil Renner Berthing			d-cache-size = <32768>;
14860bf0a39SEmil Renner Berthing			d-tlb-sets = <1>;
14960bf0a39SEmil Renner Berthing			d-tlb-size = <40>;
15060bf0a39SEmil Renner Berthing			device_type = "cpu";
15160bf0a39SEmil Renner Berthing			i-cache-block-size = <64>;
15260bf0a39SEmil Renner Berthing			i-cache-sets = <64>;
15360bf0a39SEmil Renner Berthing			i-cache-size = <32768>;
15460bf0a39SEmil Renner Berthing			i-tlb-sets = <1>;
15560bf0a39SEmil Renner Berthing			i-tlb-size = <40>;
15660bf0a39SEmil Renner Berthing			mmu-type = "riscv,sv39";
15760bf0a39SEmil Renner Berthing			next-level-cache = <&ccache>;
15860bf0a39SEmil Renner Berthing			riscv,isa = "rv64imafdc_zba_zbb";
15981b5948cSConor Dooley			riscv,isa-base = "rv64i";
16081b5948cSConor Dooley			riscv,isa-extensions = "i", "m", "a", "f", "d", "c", "zba", "zbb", "zicntr",
16181b5948cSConor Dooley					       "zicsr", "zifencei", "zihpm";
16260bf0a39SEmil Renner Berthing			tlb-split;
163e2c510d6SMason Huo			operating-points-v2 = <&cpu_opp>;
164e2c510d6SMason Huo			clocks = <&syscrg JH7110_SYSCLK_CPU_CORE>;
165e2c510d6SMason Huo			clock-names = "cpu";
166f2b539afSHal Feng			#cooling-cells = <2>;
16760bf0a39SEmil Renner Berthing
16860bf0a39SEmil Renner Berthing			cpu4_intc: interrupt-controller {
16960bf0a39SEmil Renner Berthing				compatible = "riscv,cpu-intc";
17060bf0a39SEmil Renner Berthing				interrupt-controller;
17160bf0a39SEmil Renner Berthing				#interrupt-cells = <1>;
17260bf0a39SEmil Renner Berthing			};
17360bf0a39SEmil Renner Berthing		};
17460bf0a39SEmil Renner Berthing
17560bf0a39SEmil Renner Berthing		cpu-map {
17660bf0a39SEmil Renner Berthing			cluster0 {
17760bf0a39SEmil Renner Berthing				core0 {
17860bf0a39SEmil Renner Berthing					cpu = <&S7_0>;
17960bf0a39SEmil Renner Berthing				};
18060bf0a39SEmil Renner Berthing
18160bf0a39SEmil Renner Berthing				core1 {
18260bf0a39SEmil Renner Berthing					cpu = <&U74_1>;
18360bf0a39SEmil Renner Berthing				};
18460bf0a39SEmil Renner Berthing
18560bf0a39SEmil Renner Berthing				core2 {
18660bf0a39SEmil Renner Berthing					cpu = <&U74_2>;
18760bf0a39SEmil Renner Berthing				};
18860bf0a39SEmil Renner Berthing
18960bf0a39SEmil Renner Berthing				core3 {
19060bf0a39SEmil Renner Berthing					cpu = <&U74_3>;
19160bf0a39SEmil Renner Berthing				};
19260bf0a39SEmil Renner Berthing
19360bf0a39SEmil Renner Berthing				core4 {
19460bf0a39SEmil Renner Berthing					cpu = <&U74_4>;
19560bf0a39SEmil Renner Berthing				};
19660bf0a39SEmil Renner Berthing			};
19760bf0a39SEmil Renner Berthing		};
19860bf0a39SEmil Renner Berthing	};
19960bf0a39SEmil Renner Berthing
200e2c510d6SMason Huo	cpu_opp: opp-table-0 {
201e2c510d6SMason Huo			compatible = "operating-points-v2";
202e2c510d6SMason Huo			opp-shared;
203e2c510d6SMason Huo			opp-375000000 {
204e2c510d6SMason Huo					opp-hz = /bits/ 64 <375000000>;
205e2c510d6SMason Huo					opp-microvolt = <800000>;
206e2c510d6SMason Huo			};
207e2c510d6SMason Huo			opp-500000000 {
208e2c510d6SMason Huo					opp-hz = /bits/ 64 <500000000>;
209e2c510d6SMason Huo					opp-microvolt = <800000>;
210e2c510d6SMason Huo			};
211e2c510d6SMason Huo			opp-750000000 {
212e2c510d6SMason Huo					opp-hz = /bits/ 64 <750000000>;
213e2c510d6SMason Huo					opp-microvolt = <800000>;
214e2c510d6SMason Huo			};
215e2c510d6SMason Huo			opp-1500000000 {
216e2c510d6SMason Huo					opp-hz = /bits/ 64 <1500000000>;
217e2c510d6SMason Huo					opp-microvolt = <1040000>;
218e2c510d6SMason Huo			};
219e2c510d6SMason Huo	};
220e2c510d6SMason Huo
221f2b539afSHal Feng	thermal-zones {
222f2b539afSHal Feng		cpu-thermal {
223f2b539afSHal Feng			polling-delay-passive = <250>;
224f2b539afSHal Feng			polling-delay = <15000>;
225f2b539afSHal Feng
226f2b539afSHal Feng			thermal-sensors = <&sfctemp>;
227f2b539afSHal Feng
228f2b539afSHal Feng			cooling-maps {
229f2b539afSHal Feng				map0 {
230f2b539afSHal Feng					trip = <&cpu_alert0>;
231f2b539afSHal Feng					cooling-device =
232f2b539afSHal Feng						<&U74_1 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>,
233f2b539afSHal Feng						<&U74_2 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>,
234f2b539afSHal Feng						<&U74_3 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>,
235f2b539afSHal Feng						<&U74_4 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>;
236f2b539afSHal Feng				};
237f2b539afSHal Feng			};
238f2b539afSHal Feng
239f2b539afSHal Feng			trips {
240f0360647SKrzysztof Kozlowski				cpu_alert0: cpu-alert0 {
241f2b539afSHal Feng					/* milliCelsius */
242f2b539afSHal Feng					temperature = <85000>;
243f2b539afSHal Feng					hysteresis = <2000>;
244f2b539afSHal Feng					type = "passive";
245f2b539afSHal Feng				};
246f2b539afSHal Feng
247f0360647SKrzysztof Kozlowski				cpu-crit {
248f2b539afSHal Feng					/* milliCelsius */
249f2b539afSHal Feng					temperature = <100000>;
250f2b539afSHal Feng					hysteresis = <2000>;
251f2b539afSHal Feng					type = "critical";
252f2b539afSHal Feng				};
253f2b539afSHal Feng			};
254f2b539afSHal Feng		};
255f2b539afSHal Feng	};
256f2b539afSHal Feng
25743f09605SXingyu Wu	dvp_clk: dvp-clock {
25843f09605SXingyu Wu		compatible = "fixed-clock";
25943f09605SXingyu Wu		clock-output-names = "dvp_clk";
26043f09605SXingyu Wu		#clock-cells = <0>;
26143f09605SXingyu Wu	};
26260bf0a39SEmil Renner Berthing	gmac0_rgmii_rxin: gmac0-rgmii-rxin-clock {
26360bf0a39SEmil Renner Berthing		compatible = "fixed-clock";
26460bf0a39SEmil Renner Berthing		clock-output-names = "gmac0_rgmii_rxin";
26560bf0a39SEmil Renner Berthing		#clock-cells = <0>;
26660bf0a39SEmil Renner Berthing	};
26760bf0a39SEmil Renner Berthing
26860bf0a39SEmil Renner Berthing	gmac0_rmii_refin: gmac0-rmii-refin-clock {
26960bf0a39SEmil Renner Berthing		compatible = "fixed-clock";
27060bf0a39SEmil Renner Berthing		clock-output-names = "gmac0_rmii_refin";
27160bf0a39SEmil Renner Berthing		#clock-cells = <0>;
27260bf0a39SEmil Renner Berthing	};
27360bf0a39SEmil Renner Berthing
27460bf0a39SEmil Renner Berthing	gmac1_rgmii_rxin: gmac1-rgmii-rxin-clock {
27560bf0a39SEmil Renner Berthing		compatible = "fixed-clock";
27660bf0a39SEmil Renner Berthing		clock-output-names = "gmac1_rgmii_rxin";
27760bf0a39SEmil Renner Berthing		#clock-cells = <0>;
27860bf0a39SEmil Renner Berthing	};
27960bf0a39SEmil Renner Berthing
28060bf0a39SEmil Renner Berthing	gmac1_rmii_refin: gmac1-rmii-refin-clock {
28160bf0a39SEmil Renner Berthing		compatible = "fixed-clock";
28260bf0a39SEmil Renner Berthing		clock-output-names = "gmac1_rmii_refin";
28360bf0a39SEmil Renner Berthing		#clock-cells = <0>;
28460bf0a39SEmil Renner Berthing	};
28560bf0a39SEmil Renner Berthing
28643f09605SXingyu Wu	hdmitx0_pixelclk: hdmitx0-pixel-clock {
28743f09605SXingyu Wu		compatible = "fixed-clock";
28843f09605SXingyu Wu		clock-output-names = "hdmitx0_pixelclk";
28943f09605SXingyu Wu		#clock-cells = <0>;
29043f09605SXingyu Wu	};
29143f09605SXingyu Wu
29260bf0a39SEmil Renner Berthing	i2srx_bclk_ext: i2srx-bclk-ext-clock {
29360bf0a39SEmil Renner Berthing		compatible = "fixed-clock";
29460bf0a39SEmil Renner Berthing		clock-output-names = "i2srx_bclk_ext";
29560bf0a39SEmil Renner Berthing		#clock-cells = <0>;
29660bf0a39SEmil Renner Berthing	};
29760bf0a39SEmil Renner Berthing
29860bf0a39SEmil Renner Berthing	i2srx_lrck_ext: i2srx-lrck-ext-clock {
29960bf0a39SEmil Renner Berthing		compatible = "fixed-clock";
30060bf0a39SEmil Renner Berthing		clock-output-names = "i2srx_lrck_ext";
30160bf0a39SEmil Renner Berthing		#clock-cells = <0>;
30260bf0a39SEmil Renner Berthing	};
30360bf0a39SEmil Renner Berthing
30460bf0a39SEmil Renner Berthing	i2stx_bclk_ext: i2stx-bclk-ext-clock {
30560bf0a39SEmil Renner Berthing		compatible = "fixed-clock";
30660bf0a39SEmil Renner Berthing		clock-output-names = "i2stx_bclk_ext";
30760bf0a39SEmil Renner Berthing		#clock-cells = <0>;
30860bf0a39SEmil Renner Berthing	};
30960bf0a39SEmil Renner Berthing
31060bf0a39SEmil Renner Berthing	i2stx_lrck_ext: i2stx-lrck-ext-clock {
31160bf0a39SEmil Renner Berthing		compatible = "fixed-clock";
31260bf0a39SEmil Renner Berthing		clock-output-names = "i2stx_lrck_ext";
31360bf0a39SEmil Renner Berthing		#clock-cells = <0>;
31460bf0a39SEmil Renner Berthing	};
31560bf0a39SEmil Renner Berthing
31660bf0a39SEmil Renner Berthing	mclk_ext: mclk-ext-clock {
31760bf0a39SEmil Renner Berthing		compatible = "fixed-clock";
31860bf0a39SEmil Renner Berthing		clock-output-names = "mclk_ext";
31960bf0a39SEmil Renner Berthing		#clock-cells = <0>;
32060bf0a39SEmil Renner Berthing	};
32160bf0a39SEmil Renner Berthing
32260bf0a39SEmil Renner Berthing	osc: oscillator {
32360bf0a39SEmil Renner Berthing		compatible = "fixed-clock";
32460bf0a39SEmil Renner Berthing		clock-output-names = "osc";
32560bf0a39SEmil Renner Berthing		#clock-cells = <0>;
32660bf0a39SEmil Renner Berthing	};
32760bf0a39SEmil Renner Berthing
32860bf0a39SEmil Renner Berthing	rtc_osc: rtc-oscillator {
32960bf0a39SEmil Renner Berthing		compatible = "fixed-clock";
33060bf0a39SEmil Renner Berthing		clock-output-names = "rtc_osc";
33160bf0a39SEmil Renner Berthing		#clock-cells = <0>;
33260bf0a39SEmil Renner Berthing	};
33360bf0a39SEmil Renner Berthing
3341ff166c9SSamin Guo	stmmac_axi_setup: stmmac-axi-config {
3351ff166c9SSamin Guo		snps,lpi_en;
336f331eb1fSSamin Guo		snps,wr_osr_lmt = <15>;
337f331eb1fSSamin Guo		snps,rd_osr_lmt = <15>;
3381ff166c9SSamin Guo		snps,blen = <256 128 64 32 0 0 0>;
3391ff166c9SSamin Guo	};
3401ff166c9SSamin Guo
34160bf0a39SEmil Renner Berthing	tdm_ext: tdm-ext-clock {
34260bf0a39SEmil Renner Berthing		compatible = "fixed-clock";
34360bf0a39SEmil Renner Berthing		clock-output-names = "tdm_ext";
34460bf0a39SEmil Renner Berthing		#clock-cells = <0>;
34560bf0a39SEmil Renner Berthing	};
34660bf0a39SEmil Renner Berthing
34760bf0a39SEmil Renner Berthing	soc {
34860bf0a39SEmil Renner Berthing		compatible = "simple-bus";
34960bf0a39SEmil Renner Berthing		interrupt-parent = <&plic>;
35060bf0a39SEmil Renner Berthing		#address-cells = <2>;
35160bf0a39SEmil Renner Berthing		#size-cells = <2>;
35260bf0a39SEmil Renner Berthing		ranges;
35360bf0a39SEmil Renner Berthing
35460bf0a39SEmil Renner Berthing		clint: timer@2000000 {
35560bf0a39SEmil Renner Berthing			compatible = "starfive,jh7110-clint", "sifive,clint0";
35660bf0a39SEmil Renner Berthing			reg = <0x0 0x2000000 0x0 0x10000>;
35760bf0a39SEmil Renner Berthing			interrupts-extended = <&cpu0_intc 3>, <&cpu0_intc 7>,
35860bf0a39SEmil Renner Berthing					      <&cpu1_intc 3>, <&cpu1_intc 7>,
35960bf0a39SEmil Renner Berthing					      <&cpu2_intc 3>, <&cpu2_intc 7>,
36060bf0a39SEmil Renner Berthing					      <&cpu3_intc 3>, <&cpu3_intc 7>,
36160bf0a39SEmil Renner Berthing					      <&cpu4_intc 3>, <&cpu4_intc 7>;
36260bf0a39SEmil Renner Berthing		};
36360bf0a39SEmil Renner Berthing
36460bf0a39SEmil Renner Berthing		ccache: cache-controller@2010000 {
36560bf0a39SEmil Renner Berthing			compatible = "starfive,jh7110-ccache", "sifive,ccache0", "cache";
36660bf0a39SEmil Renner Berthing			reg = <0x0 0x2010000 0x0 0x4000>;
36760bf0a39SEmil Renner Berthing			interrupts = <1>, <3>, <4>, <2>;
36860bf0a39SEmil Renner Berthing			cache-block-size = <64>;
36960bf0a39SEmil Renner Berthing			cache-level = <2>;
37060bf0a39SEmil Renner Berthing			cache-sets = <2048>;
37160bf0a39SEmil Renner Berthing			cache-size = <2097152>;
37260bf0a39SEmil Renner Berthing			cache-unified;
37360bf0a39SEmil Renner Berthing		};
37460bf0a39SEmil Renner Berthing
37560bf0a39SEmil Renner Berthing		plic: interrupt-controller@c000000 {
37660bf0a39SEmil Renner Berthing			compatible = "starfive,jh7110-plic", "sifive,plic-1.0.0";
37760bf0a39SEmil Renner Berthing			reg = <0x0 0xc000000 0x0 0x4000000>;
37860bf0a39SEmil Renner Berthing			interrupts-extended = <&cpu0_intc 11>,
37960bf0a39SEmil Renner Berthing					      <&cpu1_intc 11>, <&cpu1_intc 9>,
38060bf0a39SEmil Renner Berthing					      <&cpu2_intc 11>, <&cpu2_intc 9>,
38160bf0a39SEmil Renner Berthing					      <&cpu3_intc 11>, <&cpu3_intc 9>,
38260bf0a39SEmil Renner Berthing					      <&cpu4_intc 11>, <&cpu4_intc 9>;
38360bf0a39SEmil Renner Berthing			interrupt-controller;
38460bf0a39SEmil Renner Berthing			#interrupt-cells = <1>;
38560bf0a39SEmil Renner Berthing			#address-cells = <0>;
38660bf0a39SEmil Renner Berthing			riscv,ndev = <136>;
38760bf0a39SEmil Renner Berthing		};
38860bf0a39SEmil Renner Berthing
38960bf0a39SEmil Renner Berthing		uart0: serial@10000000 {
39060bf0a39SEmil Renner Berthing			compatible = "snps,dw-apb-uart";
39160bf0a39SEmil Renner Berthing			reg = <0x0 0x10000000 0x0 0x10000>;
39260bf0a39SEmil Renner Berthing			clocks = <&syscrg JH7110_SYSCLK_UART0_CORE>,
39360bf0a39SEmil Renner Berthing				 <&syscrg JH7110_SYSCLK_UART0_APB>;
39460bf0a39SEmil Renner Berthing			clock-names = "baudclk", "apb_pclk";
39560bf0a39SEmil Renner Berthing			resets = <&syscrg JH7110_SYSRST_UART0_APB>;
39660bf0a39SEmil Renner Berthing			interrupts = <32>;
39760bf0a39SEmil Renner Berthing			reg-io-width = <4>;
39860bf0a39SEmil Renner Berthing			reg-shift = <2>;
39960bf0a39SEmil Renner Berthing			status = "disabled";
40060bf0a39SEmil Renner Berthing		};
40160bf0a39SEmil Renner Berthing
40260bf0a39SEmil Renner Berthing		uart1: serial@10010000 {
40360bf0a39SEmil Renner Berthing			compatible = "snps,dw-apb-uart";
40460bf0a39SEmil Renner Berthing			reg = <0x0 0x10010000 0x0 0x10000>;
40560bf0a39SEmil Renner Berthing			clocks = <&syscrg JH7110_SYSCLK_UART1_CORE>,
40660bf0a39SEmil Renner Berthing				 <&syscrg JH7110_SYSCLK_UART1_APB>;
40760bf0a39SEmil Renner Berthing			clock-names = "baudclk", "apb_pclk";
40860bf0a39SEmil Renner Berthing			resets = <&syscrg JH7110_SYSRST_UART1_APB>;
40960bf0a39SEmil Renner Berthing			interrupts = <33>;
41060bf0a39SEmil Renner Berthing			reg-io-width = <4>;
41160bf0a39SEmil Renner Berthing			reg-shift = <2>;
41260bf0a39SEmil Renner Berthing			status = "disabled";
41360bf0a39SEmil Renner Berthing		};
41460bf0a39SEmil Renner Berthing
41560bf0a39SEmil Renner Berthing		uart2: serial@10020000 {
41660bf0a39SEmil Renner Berthing			compatible = "snps,dw-apb-uart";
41760bf0a39SEmil Renner Berthing			reg = <0x0 0x10020000 0x0 0x10000>;
41860bf0a39SEmil Renner Berthing			clocks = <&syscrg JH7110_SYSCLK_UART2_CORE>,
41960bf0a39SEmil Renner Berthing				 <&syscrg JH7110_SYSCLK_UART2_APB>;
42060bf0a39SEmil Renner Berthing			clock-names = "baudclk", "apb_pclk";
42160bf0a39SEmil Renner Berthing			resets = <&syscrg JH7110_SYSRST_UART2_APB>;
42260bf0a39SEmil Renner Berthing			interrupts = <34>;
42360bf0a39SEmil Renner Berthing			reg-io-width = <4>;
42460bf0a39SEmil Renner Berthing			reg-shift = <2>;
42560bf0a39SEmil Renner Berthing			status = "disabled";
42660bf0a39SEmil Renner Berthing		};
42760bf0a39SEmil Renner Berthing
42860bf0a39SEmil Renner Berthing		i2c0: i2c@10030000 {
42960bf0a39SEmil Renner Berthing			compatible = "snps,designware-i2c";
43060bf0a39SEmil Renner Berthing			reg = <0x0 0x10030000 0x0 0x10000>;
43160bf0a39SEmil Renner Berthing			clocks = <&syscrg JH7110_SYSCLK_I2C0_APB>;
43260bf0a39SEmil Renner Berthing			clock-names = "ref";
43360bf0a39SEmil Renner Berthing			resets = <&syscrg JH7110_SYSRST_I2C0_APB>;
43460bf0a39SEmil Renner Berthing			interrupts = <35>;
43560bf0a39SEmil Renner Berthing			#address-cells = <1>;
43660bf0a39SEmil Renner Berthing			#size-cells = <0>;
43760bf0a39SEmil Renner Berthing			status = "disabled";
43860bf0a39SEmil Renner Berthing		};
43960bf0a39SEmil Renner Berthing
44060bf0a39SEmil Renner Berthing		i2c1: i2c@10040000 {
44160bf0a39SEmil Renner Berthing			compatible = "snps,designware-i2c";
44260bf0a39SEmil Renner Berthing			reg = <0x0 0x10040000 0x0 0x10000>;
44360bf0a39SEmil Renner Berthing			clocks = <&syscrg JH7110_SYSCLK_I2C1_APB>;
44460bf0a39SEmil Renner Berthing			clock-names = "ref";
44560bf0a39SEmil Renner Berthing			resets = <&syscrg JH7110_SYSRST_I2C1_APB>;
44660bf0a39SEmil Renner Berthing			interrupts = <36>;
44760bf0a39SEmil Renner Berthing			#address-cells = <1>;
44860bf0a39SEmil Renner Berthing			#size-cells = <0>;
44960bf0a39SEmil Renner Berthing			status = "disabled";
45060bf0a39SEmil Renner Berthing		};
45160bf0a39SEmil Renner Berthing
45260bf0a39SEmil Renner Berthing		i2c2: i2c@10050000 {
45360bf0a39SEmil Renner Berthing			compatible = "snps,designware-i2c";
45460bf0a39SEmil Renner Berthing			reg = <0x0 0x10050000 0x0 0x10000>;
45560bf0a39SEmil Renner Berthing			clocks = <&syscrg JH7110_SYSCLK_I2C2_APB>;
45660bf0a39SEmil Renner Berthing			clock-names = "ref";
45760bf0a39SEmil Renner Berthing			resets = <&syscrg JH7110_SYSRST_I2C2_APB>;
45860bf0a39SEmil Renner Berthing			interrupts = <37>;
45960bf0a39SEmil Renner Berthing			#address-cells = <1>;
46060bf0a39SEmil Renner Berthing			#size-cells = <0>;
46160bf0a39SEmil Renner Berthing			status = "disabled";
46260bf0a39SEmil Renner Berthing		};
46360bf0a39SEmil Renner Berthing
46474fb20c8SWilliam Qiu		spi0: spi@10060000 {
46574fb20c8SWilliam Qiu			compatible = "arm,pl022", "arm,primecell";
46674fb20c8SWilliam Qiu			reg = <0x0 0x10060000 0x0 0x10000>;
46774fb20c8SWilliam Qiu			clocks = <&syscrg JH7110_SYSCLK_SPI0_APB>,
46874fb20c8SWilliam Qiu				 <&syscrg JH7110_SYSCLK_SPI0_APB>;
46974fb20c8SWilliam Qiu			clock-names = "sspclk", "apb_pclk";
47074fb20c8SWilliam Qiu			resets = <&syscrg JH7110_SYSRST_SPI0_APB>;
47174fb20c8SWilliam Qiu			interrupts = <38>;
47274fb20c8SWilliam Qiu			arm,primecell-periphid = <0x00041022>;
47374fb20c8SWilliam Qiu			num-cs = <1>;
47474fb20c8SWilliam Qiu			#address-cells = <1>;
47574fb20c8SWilliam Qiu			#size-cells = <0>;
47674fb20c8SWilliam Qiu			status = "disabled";
47774fb20c8SWilliam Qiu		};
47874fb20c8SWilliam Qiu
47974fb20c8SWilliam Qiu		spi1: spi@10070000 {
48074fb20c8SWilliam Qiu			compatible = "arm,pl022", "arm,primecell";
48174fb20c8SWilliam Qiu			reg = <0x0 0x10070000 0x0 0x10000>;
48274fb20c8SWilliam Qiu			clocks = <&syscrg JH7110_SYSCLK_SPI1_APB>,
48374fb20c8SWilliam Qiu				 <&syscrg JH7110_SYSCLK_SPI1_APB>;
48474fb20c8SWilliam Qiu			clock-names = "sspclk", "apb_pclk";
48574fb20c8SWilliam Qiu			resets = <&syscrg JH7110_SYSRST_SPI1_APB>;
48674fb20c8SWilliam Qiu			interrupts = <39>;
48774fb20c8SWilliam Qiu			arm,primecell-periphid = <0x00041022>;
48874fb20c8SWilliam Qiu			num-cs = <1>;
48974fb20c8SWilliam Qiu			#address-cells = <1>;
49074fb20c8SWilliam Qiu			#size-cells = <0>;
49174fb20c8SWilliam Qiu			status = "disabled";
49274fb20c8SWilliam Qiu		};
49374fb20c8SWilliam Qiu
49474fb20c8SWilliam Qiu		spi2: spi@10080000 {
49574fb20c8SWilliam Qiu			compatible = "arm,pl022", "arm,primecell";
49674fb20c8SWilliam Qiu			reg = <0x0 0x10080000 0x0 0x10000>;
49774fb20c8SWilliam Qiu			clocks = <&syscrg JH7110_SYSCLK_SPI2_APB>,
49874fb20c8SWilliam Qiu				 <&syscrg JH7110_SYSCLK_SPI2_APB>;
49974fb20c8SWilliam Qiu			clock-names = "sspclk", "apb_pclk";
50074fb20c8SWilliam Qiu			resets = <&syscrg JH7110_SYSRST_SPI2_APB>;
50174fb20c8SWilliam Qiu			interrupts = <40>;
50274fb20c8SWilliam Qiu			arm,primecell-periphid = <0x00041022>;
50374fb20c8SWilliam Qiu			num-cs = <1>;
50474fb20c8SWilliam Qiu			#address-cells = <1>;
50574fb20c8SWilliam Qiu			#size-cells = <0>;
50674fb20c8SWilliam Qiu			status = "disabled";
50774fb20c8SWilliam Qiu		};
50874fb20c8SWilliam Qiu
509e7c304c0SWalker Chen		tdm: tdm@10090000 {
510e7c304c0SWalker Chen			compatible = "starfive,jh7110-tdm";
511e7c304c0SWalker Chen			reg = <0x0 0x10090000 0x0 0x1000>;
512e7c304c0SWalker Chen			clocks = <&syscrg JH7110_SYSCLK_TDM_AHB>,
513e7c304c0SWalker Chen				 <&syscrg JH7110_SYSCLK_TDM_APB>,
514e7c304c0SWalker Chen				 <&syscrg JH7110_SYSCLK_TDM_INTERNAL>,
515e7c304c0SWalker Chen				 <&syscrg JH7110_SYSCLK_TDM_TDM>,
516e7c304c0SWalker Chen				 <&syscrg JH7110_SYSCLK_MCLK_INNER>,
517e7c304c0SWalker Chen				 <&tdm_ext>;
518e7c304c0SWalker Chen			clock-names = "tdm_ahb", "tdm_apb",
519e7c304c0SWalker Chen				      "tdm_internal", "tdm",
520e7c304c0SWalker Chen				      "mclk_inner", "tdm_ext";
521e7c304c0SWalker Chen			resets = <&syscrg JH7110_SYSRST_TDM_AHB>,
522e7c304c0SWalker Chen				 <&syscrg JH7110_SYSRST_TDM_APB>,
523e7c304c0SWalker Chen				 <&syscrg JH7110_SYSRST_TDM_CORE>;
524e7c304c0SWalker Chen			dmas = <&dma 20>, <&dma 21>;
525e7c304c0SWalker Chen			dma-names = "rx","tx";
526e7c304c0SWalker Chen			#sound-dai-cells = <0>;
527e7c304c0SWalker Chen			status = "disabled";
528e7c304c0SWalker Chen		};
529e7c304c0SWalker Chen
53092cfc358SXingyu Wu		i2srx: i2s@100e0000 {
53192cfc358SXingyu Wu			compatible = "starfive,jh7110-i2srx";
53292cfc358SXingyu Wu			reg = <0x0 0x100e0000 0x0 0x1000>;
53392cfc358SXingyu Wu			clocks = <&syscrg JH7110_SYSCLK_I2SRX_BCLK_MST>,
53492cfc358SXingyu Wu				 <&syscrg JH7110_SYSCLK_I2SRX_APB>,
53592cfc358SXingyu Wu				 <&syscrg JH7110_SYSCLK_MCLK>,
53692cfc358SXingyu Wu				 <&syscrg JH7110_SYSCLK_MCLK_INNER>,
53792cfc358SXingyu Wu				 <&mclk_ext>,
53892cfc358SXingyu Wu				 <&syscrg JH7110_SYSCLK_I2SRX_BCLK>,
53992cfc358SXingyu Wu				 <&syscrg JH7110_SYSCLK_I2SRX_LRCK>,
54092cfc358SXingyu Wu				 <&i2srx_bclk_ext>,
54192cfc358SXingyu Wu				 <&i2srx_lrck_ext>;
54292cfc358SXingyu Wu			clock-names = "i2sclk", "apb", "mclk",
54392cfc358SXingyu Wu				      "mclk_inner", "mclk_ext", "bclk",
54492cfc358SXingyu Wu				      "lrck", "bclk_ext", "lrck_ext";
54592cfc358SXingyu Wu			resets = <&syscrg JH7110_SYSRST_I2SRX_APB>,
54692cfc358SXingyu Wu				 <&syscrg JH7110_SYSRST_I2SRX_BCLK>;
54792cfc358SXingyu Wu			dmas = <0>, <&dma 24>;
54892cfc358SXingyu Wu			dma-names = "tx", "rx";
54992cfc358SXingyu Wu			starfive,syscon = <&sys_syscon 0x18 0x2>;
55092cfc358SXingyu Wu			#sound-dai-cells = <0>;
55192cfc358SXingyu Wu			status = "disabled";
55292cfc358SXingyu Wu		};
55392cfc358SXingyu Wu
554be326beeSHal Feng		pwmdac: pwmdac@100b0000 {
555be326beeSHal Feng			compatible = "starfive,jh7110-pwmdac";
556be326beeSHal Feng			reg = <0x0 0x100b0000 0x0 0x1000>;
557be326beeSHal Feng			clocks = <&syscrg JH7110_SYSCLK_PWMDAC_APB>,
558be326beeSHal Feng				 <&syscrg JH7110_SYSCLK_PWMDAC_CORE>;
559be326beeSHal Feng			clock-names = "apb", "core";
560be326beeSHal Feng			resets = <&syscrg JH7110_SYSRST_PWMDAC_APB>;
561be326beeSHal Feng			dmas = <&dma 22>;
562be326beeSHal Feng			dma-names = "tx";
563be326beeSHal Feng			#sound-dai-cells = <0>;
564be326beeSHal Feng			status = "disabled";
565be326beeSHal Feng		};
566be326beeSHal Feng
567e126aa3aSMinda Chen		usb0: usb@10100000 {
568e126aa3aSMinda Chen			compatible = "starfive,jh7110-usb";
569e126aa3aSMinda Chen			ranges = <0x0 0x0 0x10100000 0x100000>;
570e126aa3aSMinda Chen			#address-cells = <1>;
571e126aa3aSMinda Chen			#size-cells = <1>;
572e126aa3aSMinda Chen			starfive,stg-syscon = <&stg_syscon 0x4>;
573e126aa3aSMinda Chen			clocks = <&stgcrg JH7110_STGCLK_USB0_LPM>,
574e126aa3aSMinda Chen				 <&stgcrg JH7110_STGCLK_USB0_STB>,
575e126aa3aSMinda Chen				 <&stgcrg JH7110_STGCLK_USB0_APB>,
576e126aa3aSMinda Chen				 <&stgcrg JH7110_STGCLK_USB0_AXI>,
577e126aa3aSMinda Chen				 <&stgcrg JH7110_STGCLK_USB0_UTMI_APB>;
578e126aa3aSMinda Chen			clock-names = "lpm", "stb", "apb", "axi", "utmi_apb";
579e126aa3aSMinda Chen			resets = <&stgcrg JH7110_STGRST_USB0_PWRUP>,
580e126aa3aSMinda Chen				 <&stgcrg JH7110_STGRST_USB0_APB>,
581e126aa3aSMinda Chen				 <&stgcrg JH7110_STGRST_USB0_AXI>,
582e126aa3aSMinda Chen				 <&stgcrg JH7110_STGRST_USB0_UTMI_APB>;
583e126aa3aSMinda Chen			reset-names = "pwrup", "apb", "axi", "utmi_apb";
584e126aa3aSMinda Chen			status = "disabled";
585e126aa3aSMinda Chen
586e126aa3aSMinda Chen			usb_cdns3: usb@0 {
587e126aa3aSMinda Chen				compatible = "cdns,usb3";
588e126aa3aSMinda Chen				reg = <0x0 0x10000>,
589e126aa3aSMinda Chen				      <0x10000 0x10000>,
590e126aa3aSMinda Chen				      <0x20000 0x10000>;
591e126aa3aSMinda Chen				reg-names = "otg", "xhci", "dev";
592e126aa3aSMinda Chen				interrupts = <100>, <108>, <110>;
593e126aa3aSMinda Chen				interrupt-names = "host", "peripheral", "otg";
594e126aa3aSMinda Chen				phys = <&usbphy0>;
595e126aa3aSMinda Chen				phy-names = "cdns3,usb2-phy";
596e126aa3aSMinda Chen			};
597e126aa3aSMinda Chen		};
598e126aa3aSMinda Chen
599c2a10081SMinda Chen		usbphy0: phy@10200000 {
600c2a10081SMinda Chen			compatible = "starfive,jh7110-usb-phy";
601c2a10081SMinda Chen			reg = <0x0 0x10200000 0x0 0x10000>;
602c2a10081SMinda Chen			clocks = <&syscrg JH7110_SYSCLK_USB_125M>,
603c2a10081SMinda Chen				 <&stgcrg JH7110_STGCLK_USB0_APP_125>;
604c2a10081SMinda Chen			clock-names = "125m", "app_125m";
605c2a10081SMinda Chen			#phy-cells = <0>;
606c2a10081SMinda Chen		};
607c2a10081SMinda Chen
608c2a10081SMinda Chen		pciephy0: phy@10210000 {
609c2a10081SMinda Chen			compatible = "starfive,jh7110-pcie-phy";
610c2a10081SMinda Chen			reg = <0x0 0x10210000 0x0 0x10000>;
611c2a10081SMinda Chen			#phy-cells = <0>;
612c2a10081SMinda Chen		};
613c2a10081SMinda Chen
614c2a10081SMinda Chen		pciephy1: phy@10220000 {
615c2a10081SMinda Chen			compatible = "starfive,jh7110-pcie-phy";
616c2a10081SMinda Chen			reg = <0x0 0x10220000 0x0 0x10000>;
617c2a10081SMinda Chen			#phy-cells = <0>;
618c2a10081SMinda Chen		};
619c2a10081SMinda Chen
6203d90131fSXingyu Wu		stgcrg: clock-controller@10230000 {
6213d90131fSXingyu Wu			compatible = "starfive,jh7110-stgcrg";
6223d90131fSXingyu Wu			reg = <0x0 0x10230000 0x0 0x10000>;
6233d90131fSXingyu Wu			clocks = <&osc>,
6243d90131fSXingyu Wu				 <&syscrg JH7110_SYSCLK_HIFI4_CORE>,
6253d90131fSXingyu Wu				 <&syscrg JH7110_SYSCLK_STG_AXIAHB>,
6263d90131fSXingyu Wu				 <&syscrg JH7110_SYSCLK_USB_125M>,
6273d90131fSXingyu Wu				 <&syscrg JH7110_SYSCLK_CPU_BUS>,
6283d90131fSXingyu Wu				 <&syscrg JH7110_SYSCLK_HIFI4_AXI>,
6293d90131fSXingyu Wu				 <&syscrg JH7110_SYSCLK_NOCSTG_BUS>,
6303d90131fSXingyu Wu				 <&syscrg JH7110_SYSCLK_APB_BUS>;
6313d90131fSXingyu Wu			clock-names = "osc", "hifi4_core",
6323d90131fSXingyu Wu				      "stg_axiahb", "usb_125m",
6333d90131fSXingyu Wu				      "cpu_bus", "hifi4_axi",
6343d90131fSXingyu Wu				      "nocstg_bus", "apb_bus";
6353d90131fSXingyu Wu			#clock-cells = <1>;
6363d90131fSXingyu Wu			#reset-cells = <1>;
6373d90131fSXingyu Wu		};
6383d90131fSXingyu Wu
6393fcbcfc4SWilliam Qiu		stg_syscon: syscon@10240000 {
6403fcbcfc4SWilliam Qiu			compatible = "starfive,jh7110-stg-syscon", "syscon";
6413fcbcfc4SWilliam Qiu			reg = <0x0 0x10240000 0x0 0x1000>;
6423fcbcfc4SWilliam Qiu		};
6433fcbcfc4SWilliam Qiu
64460bf0a39SEmil Renner Berthing		uart3: serial@12000000 {
64560bf0a39SEmil Renner Berthing			compatible = "snps,dw-apb-uart";
64660bf0a39SEmil Renner Berthing			reg = <0x0 0x12000000 0x0 0x10000>;
64760bf0a39SEmil Renner Berthing			clocks = <&syscrg JH7110_SYSCLK_UART3_CORE>,
64860bf0a39SEmil Renner Berthing				 <&syscrg JH7110_SYSCLK_UART3_APB>;
64960bf0a39SEmil Renner Berthing			clock-names = "baudclk", "apb_pclk";
65060bf0a39SEmil Renner Berthing			resets = <&syscrg JH7110_SYSRST_UART3_APB>;
65160bf0a39SEmil Renner Berthing			interrupts = <45>;
65260bf0a39SEmil Renner Berthing			reg-io-width = <4>;
65360bf0a39SEmil Renner Berthing			reg-shift = <2>;
65460bf0a39SEmil Renner Berthing			status = "disabled";
65560bf0a39SEmil Renner Berthing		};
65660bf0a39SEmil Renner Berthing
65760bf0a39SEmil Renner Berthing		uart4: serial@12010000 {
65860bf0a39SEmil Renner Berthing			compatible = "snps,dw-apb-uart";
65960bf0a39SEmil Renner Berthing			reg = <0x0 0x12010000 0x0 0x10000>;
66060bf0a39SEmil Renner Berthing			clocks = <&syscrg JH7110_SYSCLK_UART4_CORE>,
66160bf0a39SEmil Renner Berthing				 <&syscrg JH7110_SYSCLK_UART4_APB>;
66260bf0a39SEmil Renner Berthing			clock-names = "baudclk", "apb_pclk";
66360bf0a39SEmil Renner Berthing			resets = <&syscrg JH7110_SYSRST_UART4_APB>;
66460bf0a39SEmil Renner Berthing			interrupts = <46>;
66560bf0a39SEmil Renner Berthing			reg-io-width = <4>;
66660bf0a39SEmil Renner Berthing			reg-shift = <2>;
66760bf0a39SEmil Renner Berthing			status = "disabled";
66860bf0a39SEmil Renner Berthing		};
66960bf0a39SEmil Renner Berthing
67060bf0a39SEmil Renner Berthing		uart5: serial@12020000 {
67160bf0a39SEmil Renner Berthing			compatible = "snps,dw-apb-uart";
67260bf0a39SEmil Renner Berthing			reg = <0x0 0x12020000 0x0 0x10000>;
67360bf0a39SEmil Renner Berthing			clocks = <&syscrg JH7110_SYSCLK_UART5_CORE>,
67460bf0a39SEmil Renner Berthing				 <&syscrg JH7110_SYSCLK_UART5_APB>;
67560bf0a39SEmil Renner Berthing			clock-names = "baudclk", "apb_pclk";
67660bf0a39SEmil Renner Berthing			resets = <&syscrg JH7110_SYSRST_UART5_APB>;
67760bf0a39SEmil Renner Berthing			interrupts = <47>;
67860bf0a39SEmil Renner Berthing			reg-io-width = <4>;
67960bf0a39SEmil Renner Berthing			reg-shift = <2>;
68060bf0a39SEmil Renner Berthing			status = "disabled";
68160bf0a39SEmil Renner Berthing		};
68260bf0a39SEmil Renner Berthing
68360bf0a39SEmil Renner Berthing		i2c3: i2c@12030000 {
68460bf0a39SEmil Renner Berthing			compatible = "snps,designware-i2c";
68560bf0a39SEmil Renner Berthing			reg = <0x0 0x12030000 0x0 0x10000>;
68660bf0a39SEmil Renner Berthing			clocks = <&syscrg JH7110_SYSCLK_I2C3_APB>;
68760bf0a39SEmil Renner Berthing			clock-names = "ref";
68860bf0a39SEmil Renner Berthing			resets = <&syscrg JH7110_SYSRST_I2C3_APB>;
68960bf0a39SEmil Renner Berthing			interrupts = <48>;
69060bf0a39SEmil Renner Berthing			#address-cells = <1>;
69160bf0a39SEmil Renner Berthing			#size-cells = <0>;
69260bf0a39SEmil Renner Berthing			status = "disabled";
69360bf0a39SEmil Renner Berthing		};
69460bf0a39SEmil Renner Berthing
69560bf0a39SEmil Renner Berthing		i2c4: i2c@12040000 {
69660bf0a39SEmil Renner Berthing			compatible = "snps,designware-i2c";
69760bf0a39SEmil Renner Berthing			reg = <0x0 0x12040000 0x0 0x10000>;
69860bf0a39SEmil Renner Berthing			clocks = <&syscrg JH7110_SYSCLK_I2C4_APB>;
69960bf0a39SEmil Renner Berthing			clock-names = "ref";
70060bf0a39SEmil Renner Berthing			resets = <&syscrg JH7110_SYSRST_I2C4_APB>;
70160bf0a39SEmil Renner Berthing			interrupts = <49>;
70260bf0a39SEmil Renner Berthing			#address-cells = <1>;
70360bf0a39SEmil Renner Berthing			#size-cells = <0>;
70460bf0a39SEmil Renner Berthing			status = "disabled";
70560bf0a39SEmil Renner Berthing		};
70660bf0a39SEmil Renner Berthing
70760bf0a39SEmil Renner Berthing		i2c5: i2c@12050000 {
70860bf0a39SEmil Renner Berthing			compatible = "snps,designware-i2c";
70960bf0a39SEmil Renner Berthing			reg = <0x0 0x12050000 0x0 0x10000>;
71060bf0a39SEmil Renner Berthing			clocks = <&syscrg JH7110_SYSCLK_I2C5_APB>;
71160bf0a39SEmil Renner Berthing			clock-names = "ref";
71260bf0a39SEmil Renner Berthing			resets = <&syscrg JH7110_SYSRST_I2C5_APB>;
71360bf0a39SEmil Renner Berthing			interrupts = <50>;
71460bf0a39SEmil Renner Berthing			#address-cells = <1>;
71560bf0a39SEmil Renner Berthing			#size-cells = <0>;
71660bf0a39SEmil Renner Berthing			status = "disabled";
71760bf0a39SEmil Renner Berthing		};
71860bf0a39SEmil Renner Berthing
71960bf0a39SEmil Renner Berthing		i2c6: i2c@12060000 {
72060bf0a39SEmil Renner Berthing			compatible = "snps,designware-i2c";
72160bf0a39SEmil Renner Berthing			reg = <0x0 0x12060000 0x0 0x10000>;
72260bf0a39SEmil Renner Berthing			clocks = <&syscrg JH7110_SYSCLK_I2C6_APB>;
72360bf0a39SEmil Renner Berthing			clock-names = "ref";
72460bf0a39SEmil Renner Berthing			resets = <&syscrg JH7110_SYSRST_I2C6_APB>;
72560bf0a39SEmil Renner Berthing			interrupts = <51>;
72660bf0a39SEmil Renner Berthing			#address-cells = <1>;
72760bf0a39SEmil Renner Berthing			#size-cells = <0>;
72860bf0a39SEmil Renner Berthing			status = "disabled";
72960bf0a39SEmil Renner Berthing		};
73060bf0a39SEmil Renner Berthing
73174fb20c8SWilliam Qiu		spi3: spi@12070000 {
73274fb20c8SWilliam Qiu			compatible = "arm,pl022", "arm,primecell";
73374fb20c8SWilliam Qiu			reg = <0x0 0x12070000 0x0 0x10000>;
73474fb20c8SWilliam Qiu			clocks = <&syscrg JH7110_SYSCLK_SPI3_APB>,
73574fb20c8SWilliam Qiu				 <&syscrg JH7110_SYSCLK_SPI3_APB>;
73674fb20c8SWilliam Qiu			clock-names = "sspclk", "apb_pclk";
73774fb20c8SWilliam Qiu			resets = <&syscrg JH7110_SYSRST_SPI3_APB>;
73874fb20c8SWilliam Qiu			interrupts = <52>;
73974fb20c8SWilliam Qiu			arm,primecell-periphid = <0x00041022>;
74074fb20c8SWilliam Qiu			num-cs = <1>;
74174fb20c8SWilliam Qiu			#address-cells = <1>;
74274fb20c8SWilliam Qiu			#size-cells = <0>;
74374fb20c8SWilliam Qiu			status = "disabled";
74474fb20c8SWilliam Qiu		};
74574fb20c8SWilliam Qiu
74674fb20c8SWilliam Qiu		spi4: spi@12080000 {
74774fb20c8SWilliam Qiu			compatible = "arm,pl022", "arm,primecell";
74874fb20c8SWilliam Qiu			reg = <0x0 0x12080000 0x0 0x10000>;
74974fb20c8SWilliam Qiu			clocks = <&syscrg JH7110_SYSCLK_SPI4_APB>,
75074fb20c8SWilliam Qiu				 <&syscrg JH7110_SYSCLK_SPI4_APB>;
75174fb20c8SWilliam Qiu			clock-names = "sspclk", "apb_pclk";
75274fb20c8SWilliam Qiu			resets = <&syscrg JH7110_SYSRST_SPI4_APB>;
75374fb20c8SWilliam Qiu			interrupts = <53>;
75474fb20c8SWilliam Qiu			arm,primecell-periphid = <0x00041022>;
75574fb20c8SWilliam Qiu			num-cs = <1>;
75674fb20c8SWilliam Qiu			#address-cells = <1>;
75774fb20c8SWilliam Qiu			#size-cells = <0>;
75874fb20c8SWilliam Qiu			status = "disabled";
75974fb20c8SWilliam Qiu		};
76074fb20c8SWilliam Qiu
76174fb20c8SWilliam Qiu		spi5: spi@12090000 {
76274fb20c8SWilliam Qiu			compatible = "arm,pl022", "arm,primecell";
76374fb20c8SWilliam Qiu			reg = <0x0 0x12090000 0x0 0x10000>;
76474fb20c8SWilliam Qiu			clocks = <&syscrg JH7110_SYSCLK_SPI5_APB>,
76574fb20c8SWilliam Qiu				 <&syscrg JH7110_SYSCLK_SPI5_APB>;
76674fb20c8SWilliam Qiu			clock-names = "sspclk", "apb_pclk";
76774fb20c8SWilliam Qiu			resets = <&syscrg JH7110_SYSRST_SPI5_APB>;
76874fb20c8SWilliam Qiu			interrupts = <54>;
76974fb20c8SWilliam Qiu			arm,primecell-periphid = <0x00041022>;
77074fb20c8SWilliam Qiu			num-cs = <1>;
77174fb20c8SWilliam Qiu			#address-cells = <1>;
77274fb20c8SWilliam Qiu			#size-cells = <0>;
77374fb20c8SWilliam Qiu			status = "disabled";
77474fb20c8SWilliam Qiu		};
77574fb20c8SWilliam Qiu
77674fb20c8SWilliam Qiu		spi6: spi@120a0000 {
77774fb20c8SWilliam Qiu			compatible = "arm,pl022", "arm,primecell";
77874fb20c8SWilliam Qiu			reg = <0x0 0x120A0000 0x0 0x10000>;
77974fb20c8SWilliam Qiu			clocks = <&syscrg JH7110_SYSCLK_SPI6_APB>,
78074fb20c8SWilliam Qiu				 <&syscrg JH7110_SYSCLK_SPI6_APB>;
78174fb20c8SWilliam Qiu			clock-names = "sspclk", "apb_pclk";
78274fb20c8SWilliam Qiu			resets = <&syscrg JH7110_SYSRST_SPI6_APB>;
78374fb20c8SWilliam Qiu			interrupts = <55>;
78474fb20c8SWilliam Qiu			arm,primecell-periphid = <0x00041022>;
78574fb20c8SWilliam Qiu			num-cs = <1>;
78674fb20c8SWilliam Qiu			#address-cells = <1>;
78774fb20c8SWilliam Qiu			#size-cells = <0>;
78874fb20c8SWilliam Qiu			status = "disabled";
78974fb20c8SWilliam Qiu		};
79074fb20c8SWilliam Qiu
79192cfc358SXingyu Wu		i2stx0: i2s@120b0000 {
79292cfc358SXingyu Wu			compatible = "starfive,jh7110-i2stx0";
79392cfc358SXingyu Wu			reg = <0x0 0x120b0000 0x0 0x1000>;
79492cfc358SXingyu Wu			clocks = <&syscrg JH7110_SYSCLK_I2STX0_BCLK_MST>,
79592cfc358SXingyu Wu				 <&syscrg JH7110_SYSCLK_I2STX0_APB>,
79692cfc358SXingyu Wu				 <&syscrg JH7110_SYSCLK_MCLK>,
79792cfc358SXingyu Wu				 <&syscrg JH7110_SYSCLK_MCLK_INNER>,
79892cfc358SXingyu Wu				 <&mclk_ext>;
79992cfc358SXingyu Wu			clock-names = "i2sclk", "apb", "mclk",
80092cfc358SXingyu Wu				      "mclk_inner","mclk_ext";
80192cfc358SXingyu Wu			resets = <&syscrg JH7110_SYSRST_I2STX0_APB>,
80292cfc358SXingyu Wu				 <&syscrg JH7110_SYSRST_I2STX0_BCLK>;
80392cfc358SXingyu Wu			dmas = <&dma 47>;
80492cfc358SXingyu Wu			dma-names = "tx";
80592cfc358SXingyu Wu			#sound-dai-cells = <0>;
80692cfc358SXingyu Wu			status = "disabled";
80792cfc358SXingyu Wu		};
80892cfc358SXingyu Wu
80992cfc358SXingyu Wu		i2stx1: i2s@120c0000 {
81092cfc358SXingyu Wu			compatible = "starfive,jh7110-i2stx1";
81192cfc358SXingyu Wu			reg = <0x0 0x120c0000 0x0 0x1000>;
81292cfc358SXingyu Wu			clocks = <&syscrg JH7110_SYSCLK_I2STX1_BCLK_MST>,
81392cfc358SXingyu Wu				 <&syscrg JH7110_SYSCLK_I2STX1_APB>,
81492cfc358SXingyu Wu				 <&syscrg JH7110_SYSCLK_MCLK>,
81592cfc358SXingyu Wu				 <&syscrg JH7110_SYSCLK_MCLK_INNER>,
81692cfc358SXingyu Wu				 <&mclk_ext>,
81792cfc358SXingyu Wu				 <&syscrg JH7110_SYSCLK_I2STX1_BCLK>,
81892cfc358SXingyu Wu				 <&syscrg JH7110_SYSCLK_I2STX1_LRCK>,
81992cfc358SXingyu Wu				 <&i2stx_bclk_ext>,
82092cfc358SXingyu Wu				 <&i2stx_lrck_ext>;
82192cfc358SXingyu Wu			clock-names = "i2sclk", "apb", "mclk",
82292cfc358SXingyu Wu				      "mclk_inner", "mclk_ext", "bclk",
82392cfc358SXingyu Wu				      "lrck", "bclk_ext", "lrck_ext";
82492cfc358SXingyu Wu			resets = <&syscrg JH7110_SYSRST_I2STX1_APB>,
82592cfc358SXingyu Wu				 <&syscrg JH7110_SYSRST_I2STX1_BCLK>;
82692cfc358SXingyu Wu			dmas = <&dma 48>;
82792cfc358SXingyu Wu			dma-names = "tx";
82892cfc358SXingyu Wu			#sound-dai-cells = <0>;
82992cfc358SXingyu Wu			status = "disabled";
83092cfc358SXingyu Wu		};
83192cfc358SXingyu Wu
8328d01f741SWilliam Qiu		pwm: pwm@120d0000 {
8338d01f741SWilliam Qiu			compatible = "starfive,jh7110-pwm", "opencores,pwm-v1";
8348d01f741SWilliam Qiu			reg = <0x0 0x120d0000 0x0 0x10000>;
8358d01f741SWilliam Qiu			clocks = <&syscrg JH7110_SYSCLK_PWM_APB>;
8368d01f741SWilliam Qiu			resets = <&syscrg JH7110_SYSRST_PWM_APB>;
8378d01f741SWilliam Qiu			#pwm-cells = <3>;
8388d01f741SWilliam Qiu			status = "disabled";
8398d01f741SWilliam Qiu		};
8408d01f741SWilliam Qiu
841f2b539afSHal Feng		sfctemp: temperature-sensor@120e0000 {
842f2b539afSHal Feng			compatible = "starfive,jh7110-temp";
843f2b539afSHal Feng			reg = <0x0 0x120e0000 0x0 0x10000>;
844f2b539afSHal Feng			clocks = <&syscrg JH7110_SYSCLK_TEMP_CORE>,
845f2b539afSHal Feng				 <&syscrg JH7110_SYSCLK_TEMP_APB>;
846f2b539afSHal Feng			clock-names = "sense", "bus";
847f2b539afSHal Feng			resets = <&syscrg JH7110_SYSRST_TEMP_CORE>,
848f2b539afSHal Feng				 <&syscrg JH7110_SYSRST_TEMP_APB>;
849f2b539afSHal Feng			reset-names = "sense", "bus";
850f2b539afSHal Feng			#thermal-sensor-cells = <0>;
851f2b539afSHal Feng		};
852f2b539afSHal Feng
853466a8851SConor Dooley		qspi: spi@13010000 {
854466a8851SConor Dooley			compatible = "starfive,jh7110-qspi", "cdns,qspi-nor";
855466a8851SConor Dooley			reg = <0x0 0x13010000 0x0 0x10000>,
856466a8851SConor Dooley			      <0x0 0x21000000 0x0 0x400000>;
857466a8851SConor Dooley			interrupts = <25>;
858466a8851SConor Dooley			clocks = <&syscrg JH7110_SYSCLK_QSPI_REF>,
859466a8851SConor Dooley				 <&syscrg JH7110_SYSCLK_QSPI_AHB>,
860466a8851SConor Dooley				 <&syscrg JH7110_SYSCLK_QSPI_APB>;
861466a8851SConor Dooley			clock-names = "ref", "ahb", "apb";
862466a8851SConor Dooley			resets = <&syscrg JH7110_SYSRST_QSPI_APB>,
863466a8851SConor Dooley				 <&syscrg JH7110_SYSRST_QSPI_AHB>,
864466a8851SConor Dooley				 <&syscrg JH7110_SYSRST_QSPI_REF>;
865466a8851SConor Dooley			reset-names = "qspi", "qspi-ocp", "rstc_ref";
866466a8851SConor Dooley			cdns,fifo-depth = <256>;
867466a8851SConor Dooley			cdns,fifo-width = <4>;
868466a8851SConor Dooley			cdns,trigger-address = <0x0>;
869466a8851SConor Dooley			status = "disabled";
870466a8851SConor Dooley		};
871466a8851SConor Dooley
87260bf0a39SEmil Renner Berthing		syscrg: clock-controller@13020000 {
87360bf0a39SEmil Renner Berthing			compatible = "starfive,jh7110-syscrg";
87460bf0a39SEmil Renner Berthing			reg = <0x0 0x13020000 0x0 0x10000>;
87560bf0a39SEmil Renner Berthing			clocks = <&osc>, <&gmac1_rmii_refin>,
87660bf0a39SEmil Renner Berthing				 <&gmac1_rgmii_rxin>,
87760bf0a39SEmil Renner Berthing				 <&i2stx_bclk_ext>, <&i2stx_lrck_ext>,
87860bf0a39SEmil Renner Berthing				 <&i2srx_bclk_ext>, <&i2srx_lrck_ext>,
8793e6670a2SXingyu Wu				 <&tdm_ext>, <&mclk_ext>,
8803e6670a2SXingyu Wu				 <&pllclk JH7110_PLLCLK_PLL0_OUT>,
8813e6670a2SXingyu Wu				 <&pllclk JH7110_PLLCLK_PLL1_OUT>,
8823e6670a2SXingyu Wu				 <&pllclk JH7110_PLLCLK_PLL2_OUT>;
88360bf0a39SEmil Renner Berthing			clock-names = "osc", "gmac1_rmii_refin",
88460bf0a39SEmil Renner Berthing				      "gmac1_rgmii_rxin",
88560bf0a39SEmil Renner Berthing				      "i2stx_bclk_ext", "i2stx_lrck_ext",
88660bf0a39SEmil Renner Berthing				      "i2srx_bclk_ext", "i2srx_lrck_ext",
8873e6670a2SXingyu Wu				      "tdm_ext", "mclk_ext",
8883e6670a2SXingyu Wu				      "pll0_out", "pll1_out", "pll2_out";
88960bf0a39SEmil Renner Berthing			#clock-cells = <1>;
89060bf0a39SEmil Renner Berthing			#reset-cells = <1>;
89160bf0a39SEmil Renner Berthing		};
89260bf0a39SEmil Renner Berthing
8933fcbcfc4SWilliam Qiu		sys_syscon: syscon@13030000 {
8943fcbcfc4SWilliam Qiu			compatible = "starfive,jh7110-sys-syscon", "syscon", "simple-mfd";
8953fcbcfc4SWilliam Qiu			reg = <0x0 0x13030000 0x0 0x1000>;
8963fcbcfc4SWilliam Qiu
8973fcbcfc4SWilliam Qiu			pllclk: clock-controller {
8983fcbcfc4SWilliam Qiu				compatible = "starfive,jh7110-pll";
8993fcbcfc4SWilliam Qiu				clocks = <&osc>;
9003fcbcfc4SWilliam Qiu				#clock-cells = <1>;
9013fcbcfc4SWilliam Qiu			};
9023fcbcfc4SWilliam Qiu		};
9033fcbcfc4SWilliam Qiu
90460bf0a39SEmil Renner Berthing		sysgpio: pinctrl@13040000 {
90560bf0a39SEmil Renner Berthing			compatible = "starfive,jh7110-sys-pinctrl";
90660bf0a39SEmil Renner Berthing			reg = <0x0 0x13040000 0x0 0x10000>;
90760bf0a39SEmil Renner Berthing			clocks = <&syscrg JH7110_SYSCLK_IOMUX_APB>;
90860bf0a39SEmil Renner Berthing			resets = <&syscrg JH7110_SYSRST_IOMUX_APB>;
90960bf0a39SEmil Renner Berthing			interrupts = <86>;
91060bf0a39SEmil Renner Berthing			interrupt-controller;
91160bf0a39SEmil Renner Berthing			#interrupt-cells = <2>;
91260bf0a39SEmil Renner Berthing			gpio-controller;
91360bf0a39SEmil Renner Berthing			#gpio-cells = <2>;
91460bf0a39SEmil Renner Berthing		};
91560bf0a39SEmil Renner Berthing
9166361b7deSXingyu Wu		watchdog@13070000 {
9176361b7deSXingyu Wu			compatible = "starfive,jh7110-wdt";
9186361b7deSXingyu Wu			reg = <0x0 0x13070000 0x0 0x10000>;
9196361b7deSXingyu Wu			clocks = <&syscrg JH7110_SYSCLK_WDT_APB>,
9206361b7deSXingyu Wu				 <&syscrg JH7110_SYSCLK_WDT_CORE>;
9216361b7deSXingyu Wu			clock-names = "apb", "core";
9226361b7deSXingyu Wu			resets = <&syscrg JH7110_SYSRST_WDT_APB>,
9236361b7deSXingyu Wu				 <&syscrg JH7110_SYSRST_WDT_CORE>;
9246361b7deSXingyu Wu		};
9256361b7deSXingyu Wu
926e2c07765SJia Jie Ho		crypto: crypto@16000000 {
927e2c07765SJia Jie Ho			compatible = "starfive,jh7110-crypto";
928e2c07765SJia Jie Ho			reg = <0x0 0x16000000 0x0 0x4000>;
929e2c07765SJia Jie Ho			clocks = <&stgcrg JH7110_STGCLK_SEC_AHB>,
930e2c07765SJia Jie Ho				 <&stgcrg JH7110_STGCLK_SEC_MISC_AHB>;
931e2c07765SJia Jie Ho			clock-names = "hclk", "ahb";
932e2c07765SJia Jie Ho			interrupts = <28>;
933e2c07765SJia Jie Ho			resets = <&stgcrg JH7110_STGRST_SEC_AHB>;
934e2c07765SJia Jie Ho			dmas = <&sdma 1 2>, <&sdma 0 2>;
935e2c07765SJia Jie Ho			dma-names = "tx", "rx";
936e2c07765SJia Jie Ho		};
937e2c07765SJia Jie Ho
938e2c07765SJia Jie Ho		sdma: dma-controller@16008000 {
939e2c07765SJia Jie Ho			compatible = "arm,pl080", "arm,primecell";
940e2c07765SJia Jie Ho			arm,primecell-periphid = <0x00041080>;
941e2c07765SJia Jie Ho			reg = <0x0 0x16008000 0x0 0x4000>;
942e2c07765SJia Jie Ho			interrupts = <29>;
943e2c07765SJia Jie Ho			clocks = <&stgcrg JH7110_STGCLK_SEC_AHB>;
944e2c07765SJia Jie Ho			clock-names = "apb_pclk";
945e2c07765SJia Jie Ho			resets = <&stgcrg JH7110_STGRST_SEC_AHB>;
946e2c07765SJia Jie Ho			lli-bus-interface-ahb1;
947e2c07765SJia Jie Ho			mem-bus-interface-ahb1;
948e2c07765SJia Jie Ho			memcpy-burst-size = <256>;
949e2c07765SJia Jie Ho			memcpy-bus-width = <32>;
950e2c07765SJia Jie Ho			#dma-cells = <2>;
951e2c07765SJia Jie Ho		};
952e2c07765SJia Jie Ho
95387ddf5b1SJia Jie Ho		rng: rng@1600c000 {
95487ddf5b1SJia Jie Ho			compatible = "starfive,jh7110-trng";
95587ddf5b1SJia Jie Ho			reg = <0x0 0x1600C000 0x0 0x4000>;
95687ddf5b1SJia Jie Ho			clocks = <&stgcrg JH7110_STGCLK_SEC_AHB>,
95787ddf5b1SJia Jie Ho				 <&stgcrg JH7110_STGCLK_SEC_MISC_AHB>;
95887ddf5b1SJia Jie Ho			clock-names = "hclk", "ahb";
95987ddf5b1SJia Jie Ho			resets = <&stgcrg JH7110_STGRST_SEC_AHB>;
96087ddf5b1SJia Jie Ho			interrupts = <30>;
96187ddf5b1SJia Jie Ho		};
96287ddf5b1SJia Jie Ho
963b127dbf9SWilliam Qiu		mmc0: mmc@16010000 {
964b127dbf9SWilliam Qiu			compatible = "starfive,jh7110-mmc";
965b127dbf9SWilliam Qiu			reg = <0x0 0x16010000 0x0 0x10000>;
966b127dbf9SWilliam Qiu			clocks = <&syscrg JH7110_SYSCLK_SDIO0_AHB>,
967b127dbf9SWilliam Qiu				 <&syscrg JH7110_SYSCLK_SDIO0_SDCARD>;
968b127dbf9SWilliam Qiu			clock-names = "biu","ciu";
969b127dbf9SWilliam Qiu			resets = <&syscrg JH7110_SYSRST_SDIO0_AHB>;
970b127dbf9SWilliam Qiu			reset-names = "reset";
971b127dbf9SWilliam Qiu			interrupts = <74>;
972b127dbf9SWilliam Qiu			fifo-depth = <32>;
973b127dbf9SWilliam Qiu			fifo-watermark-aligned;
974b127dbf9SWilliam Qiu			data-addr = <0>;
975b127dbf9SWilliam Qiu			starfive,sysreg = <&sys_syscon 0x14 0x1a 0x7c000000>;
976b127dbf9SWilliam Qiu			status = "disabled";
977b127dbf9SWilliam Qiu		};
978b127dbf9SWilliam Qiu
979b127dbf9SWilliam Qiu		mmc1: mmc@16020000 {
980b127dbf9SWilliam Qiu			compatible = "starfive,jh7110-mmc";
981b127dbf9SWilliam Qiu			reg = <0x0 0x16020000 0x0 0x10000>;
982b127dbf9SWilliam Qiu			clocks = <&syscrg JH7110_SYSCLK_SDIO1_AHB>,
983b127dbf9SWilliam Qiu				 <&syscrg JH7110_SYSCLK_SDIO1_SDCARD>;
984b127dbf9SWilliam Qiu			clock-names = "biu","ciu";
985b127dbf9SWilliam Qiu			resets = <&syscrg JH7110_SYSRST_SDIO1_AHB>;
986b127dbf9SWilliam Qiu			reset-names = "reset";
987b127dbf9SWilliam Qiu			interrupts = <75>;
988b127dbf9SWilliam Qiu			fifo-depth = <32>;
989b127dbf9SWilliam Qiu			fifo-watermark-aligned;
990b127dbf9SWilliam Qiu			data-addr = <0>;
991b127dbf9SWilliam Qiu			starfive,sysreg = <&sys_syscon 0x9c 0x1 0x3e>;
992b127dbf9SWilliam Qiu			status = "disabled";
993b127dbf9SWilliam Qiu		};
994b127dbf9SWilliam Qiu
9951ff166c9SSamin Guo		gmac0: ethernet@16030000 {
9961ff166c9SSamin Guo			compatible = "starfive,jh7110-dwmac", "snps,dwmac-5.20";
9971ff166c9SSamin Guo			reg = <0x0 0x16030000 0x0 0x10000>;
9981ff166c9SSamin Guo			clocks = <&aoncrg JH7110_AONCLK_GMAC0_AXI>,
9991ff166c9SSamin Guo				 <&aoncrg JH7110_AONCLK_GMAC0_AHB>,
10001ff166c9SSamin Guo				 <&syscrg JH7110_SYSCLK_GMAC0_PTP>,
10011ff166c9SSamin Guo				 <&aoncrg JH7110_AONCLK_GMAC0_TX_INV>,
10021ff166c9SSamin Guo				 <&syscrg JH7110_SYSCLK_GMAC0_GTXC>;
10031ff166c9SSamin Guo			clock-names = "stmmaceth", "pclk", "ptp_ref",
10041ff166c9SSamin Guo				      "tx", "gtx";
10051ff166c9SSamin Guo			resets = <&aoncrg JH7110_AONRST_GMAC0_AXI>,
10061ff166c9SSamin Guo				 <&aoncrg JH7110_AONRST_GMAC0_AHB>;
10071ff166c9SSamin Guo			reset-names = "stmmaceth", "ahb";
10081ff166c9SSamin Guo			interrupts = <7>, <6>, <5>;
10091ff166c9SSamin Guo			interrupt-names = "macirq", "eth_wake_irq", "eth_lpi";
10101ff166c9SSamin Guo			rx-fifo-depth = <2048>;
10111ff166c9SSamin Guo			tx-fifo-depth = <2048>;
10121ff166c9SSamin Guo			snps,multicast-filter-bins = <64>;
1013f331eb1fSSamin Guo			snps,perfect-filter-entries = <256>;
10141ff166c9SSamin Guo			snps,fixed-burst;
10151ff166c9SSamin Guo			snps,no-pbl-x8;
10161ff166c9SSamin Guo			snps,force_thresh_dma_mode;
10171ff166c9SSamin Guo			snps,axi-config = <&stmmac_axi_setup>;
10181ff166c9SSamin Guo			snps,tso;
10191ff166c9SSamin Guo			snps,en-tx-lpi-clockgating;
10201ff166c9SSamin Guo			snps,txpbl = <16>;
10211ff166c9SSamin Guo			snps,rxpbl = <16>;
10221ff166c9SSamin Guo			starfive,syscon = <&aon_syscon 0xc 0x12>;
10231ff166c9SSamin Guo			status = "disabled";
10241ff166c9SSamin Guo		};
10251ff166c9SSamin Guo
10261ff166c9SSamin Guo		gmac1: ethernet@16040000 {
10271ff166c9SSamin Guo			compatible = "starfive,jh7110-dwmac", "snps,dwmac-5.20";
10281ff166c9SSamin Guo			reg = <0x0 0x16040000 0x0 0x10000>;
10291ff166c9SSamin Guo			clocks = <&syscrg JH7110_SYSCLK_GMAC1_AXI>,
10301ff166c9SSamin Guo				 <&syscrg JH7110_SYSCLK_GMAC1_AHB>,
10311ff166c9SSamin Guo				 <&syscrg JH7110_SYSCLK_GMAC1_PTP>,
10321ff166c9SSamin Guo				 <&syscrg JH7110_SYSCLK_GMAC1_TX_INV>,
10331ff166c9SSamin Guo				 <&syscrg JH7110_SYSCLK_GMAC1_GTXC>;
10341ff166c9SSamin Guo			clock-names = "stmmaceth", "pclk", "ptp_ref",
10351ff166c9SSamin Guo				      "tx", "gtx";
10361ff166c9SSamin Guo			resets = <&syscrg JH7110_SYSRST_GMAC1_AXI>,
10371ff166c9SSamin Guo				 <&syscrg JH7110_SYSRST_GMAC1_AHB>;
10381ff166c9SSamin Guo			reset-names = "stmmaceth", "ahb";
10391ff166c9SSamin Guo			interrupts = <78>, <77>, <76>;
10401ff166c9SSamin Guo			interrupt-names = "macirq", "eth_wake_irq", "eth_lpi";
10411ff166c9SSamin Guo			rx-fifo-depth = <2048>;
10421ff166c9SSamin Guo			tx-fifo-depth = <2048>;
10431ff166c9SSamin Guo			snps,multicast-filter-bins = <64>;
1044f331eb1fSSamin Guo			snps,perfect-filter-entries = <256>;
10451ff166c9SSamin Guo			snps,fixed-burst;
10461ff166c9SSamin Guo			snps,no-pbl-x8;
10471ff166c9SSamin Guo			snps,force_thresh_dma_mode;
10481ff166c9SSamin Guo			snps,axi-config = <&stmmac_axi_setup>;
10491ff166c9SSamin Guo			snps,tso;
10501ff166c9SSamin Guo			snps,en-tx-lpi-clockgating;
10511ff166c9SSamin Guo			snps,txpbl = <16>;
10521ff166c9SSamin Guo			snps,rxpbl = <16>;
10531ff166c9SSamin Guo			starfive,syscon = <&sys_syscon 0x90 0x2>;
10541ff166c9SSamin Guo			status = "disabled";
10551ff166c9SSamin Guo		};
10561ff166c9SSamin Guo
1057ac73c097SWalker Chen		dma: dma-controller@16050000 {
1058ac73c097SWalker Chen			compatible = "starfive,jh7110-axi-dma";
1059ac73c097SWalker Chen			reg = <0x0 0x16050000 0x0 0x10000>;
1060ac73c097SWalker Chen			clocks = <&stgcrg JH7110_STGCLK_DMA1P_AXI>,
1061ac73c097SWalker Chen				 <&stgcrg JH7110_STGCLK_DMA1P_AHB>;
1062ac73c097SWalker Chen			clock-names = "core-clk", "cfgr-clk";
1063ac73c097SWalker Chen			resets = <&stgcrg JH7110_STGRST_DMA1P_AXI>,
1064ac73c097SWalker Chen				 <&stgcrg JH7110_STGRST_DMA1P_AHB>;
1065ac73c097SWalker Chen			interrupts = <73>;
1066ac73c097SWalker Chen			#dma-cells = <1>;
1067ac73c097SWalker Chen			dma-channels = <4>;
1068ac73c097SWalker Chen			snps,dma-masters = <1>;
1069ac73c097SWalker Chen			snps,data-width = <3>;
1070ac73c097SWalker Chen			snps,block-size = <65536 65536 65536 65536>;
1071ac73c097SWalker Chen			snps,priority = <0 1 2 3>;
1072ac73c097SWalker Chen			snps,axi-max-burst-len = <16>;
1073ac73c097SWalker Chen		};
1074ac73c097SWalker Chen
107560bf0a39SEmil Renner Berthing		aoncrg: clock-controller@17000000 {
107660bf0a39SEmil Renner Berthing			compatible = "starfive,jh7110-aoncrg";
107760bf0a39SEmil Renner Berthing			reg = <0x0 0x17000000 0x0 0x10000>;
107860bf0a39SEmil Renner Berthing			clocks = <&osc>, <&gmac0_rmii_refin>,
107960bf0a39SEmil Renner Berthing				 <&gmac0_rgmii_rxin>,
108060bf0a39SEmil Renner Berthing				 <&syscrg JH7110_SYSCLK_STG_AXIAHB>,
108160bf0a39SEmil Renner Berthing				 <&syscrg JH7110_SYSCLK_APB_BUS>,
108260bf0a39SEmil Renner Berthing				 <&syscrg JH7110_SYSCLK_GMAC0_GTXCLK>,
108360bf0a39SEmil Renner Berthing				 <&rtc_osc>;
108460bf0a39SEmil Renner Berthing			clock-names = "osc", "gmac0_rmii_refin",
108560bf0a39SEmil Renner Berthing				      "gmac0_rgmii_rxin", "stg_axiahb",
108660bf0a39SEmil Renner Berthing				      "apb_bus", "gmac0_gtxclk",
108760bf0a39SEmil Renner Berthing				      "rtc_osc";
108860bf0a39SEmil Renner Berthing			#clock-cells = <1>;
108960bf0a39SEmil Renner Berthing			#reset-cells = <1>;
109060bf0a39SEmil Renner Berthing		};
109160bf0a39SEmil Renner Berthing
10923fcbcfc4SWilliam Qiu		aon_syscon: syscon@17010000 {
10933fcbcfc4SWilliam Qiu			compatible = "starfive,jh7110-aon-syscon", "syscon";
10943fcbcfc4SWilliam Qiu			reg = <0x0 0x17010000 0x0 0x1000>;
10953fcbcfc4SWilliam Qiu			#power-domain-cells = <1>;
10963fcbcfc4SWilliam Qiu		};
10973fcbcfc4SWilliam Qiu
109860bf0a39SEmil Renner Berthing		aongpio: pinctrl@17020000 {
109960bf0a39SEmil Renner Berthing			compatible = "starfive,jh7110-aon-pinctrl";
110060bf0a39SEmil Renner Berthing			reg = <0x0 0x17020000 0x0 0x10000>;
110160bf0a39SEmil Renner Berthing			resets = <&aoncrg JH7110_AONRST_IOMUX>;
110260bf0a39SEmil Renner Berthing			interrupts = <85>;
110360bf0a39SEmil Renner Berthing			interrupt-controller;
110460bf0a39SEmil Renner Berthing			#interrupt-cells = <2>;
110560bf0a39SEmil Renner Berthing			gpio-controller;
110660bf0a39SEmil Renner Berthing			#gpio-cells = <2>;
110760bf0a39SEmil Renner Berthing		};
11086a887bccSWalker Chen
11096a887bccSWalker Chen		pwrc: power-controller@17030000 {
11106a887bccSWalker Chen			compatible = "starfive,jh7110-pmu";
11116a887bccSWalker Chen			reg = <0x0 0x17030000 0x0 0x10000>;
11126a887bccSWalker Chen			interrupts = <111>;
11136a887bccSWalker Chen			#power-domain-cells = <1>;
11146a887bccSWalker Chen		};
11153d90131fSXingyu Wu
111628ecaaa5SChanghuang Liang		csi2rx: csi@19800000 {
111728ecaaa5SChanghuang Liang			compatible = "starfive,jh7110-csi2rx", "cdns,csi2rx";
111828ecaaa5SChanghuang Liang			reg = <0x0 0x19800000 0x0 0x10000>;
111928ecaaa5SChanghuang Liang			clocks = <&ispcrg JH7110_ISPCLK_VIN_SYS>,
112028ecaaa5SChanghuang Liang				 <&ispcrg JH7110_ISPCLK_VIN_APB>,
112128ecaaa5SChanghuang Liang				 <&ispcrg JH7110_ISPCLK_VIN_PIXEL_IF0>,
112228ecaaa5SChanghuang Liang				 <&ispcrg JH7110_ISPCLK_VIN_PIXEL_IF1>,
112328ecaaa5SChanghuang Liang				 <&ispcrg JH7110_ISPCLK_VIN_PIXEL_IF2>,
112428ecaaa5SChanghuang Liang				 <&ispcrg JH7110_ISPCLK_VIN_PIXEL_IF3>;
112528ecaaa5SChanghuang Liang			clock-names = "sys_clk", "p_clk",
112628ecaaa5SChanghuang Liang				      "pixel_if0_clk", "pixel_if1_clk",
112728ecaaa5SChanghuang Liang				      "pixel_if2_clk", "pixel_if3_clk";
112828ecaaa5SChanghuang Liang			resets = <&ispcrg JH7110_ISPRST_VIN_SYS>,
112928ecaaa5SChanghuang Liang				 <&ispcrg JH7110_ISPRST_VIN_APB>,
113028ecaaa5SChanghuang Liang				 <&ispcrg JH7110_ISPRST_VIN_PIXEL_IF0>,
113128ecaaa5SChanghuang Liang				 <&ispcrg JH7110_ISPRST_VIN_PIXEL_IF1>,
113228ecaaa5SChanghuang Liang				 <&ispcrg JH7110_ISPRST_VIN_PIXEL_IF2>,
113328ecaaa5SChanghuang Liang				 <&ispcrg JH7110_ISPRST_VIN_PIXEL_IF3>;
113428ecaaa5SChanghuang Liang			reset-names = "sys", "reg_bank",
113528ecaaa5SChanghuang Liang				      "pixel_if0", "pixel_if1",
113628ecaaa5SChanghuang Liang				      "pixel_if2", "pixel_if3";
113728ecaaa5SChanghuang Liang			phys = <&csi_phy>;
113828ecaaa5SChanghuang Liang			phy-names = "dphy";
113928ecaaa5SChanghuang Liang			status = "disabled";
114028ecaaa5SChanghuang Liang		};
114128ecaaa5SChanghuang Liang
11423d90131fSXingyu Wu		ispcrg: clock-controller@19810000 {
11433d90131fSXingyu Wu			compatible = "starfive,jh7110-ispcrg";
11443d90131fSXingyu Wu			reg = <0x0 0x19810000 0x0 0x10000>;
11453d90131fSXingyu Wu			clocks = <&syscrg JH7110_SYSCLK_ISP_TOP_CORE>,
11463d90131fSXingyu Wu				 <&syscrg JH7110_SYSCLK_ISP_TOP_AXI>,
11473d90131fSXingyu Wu				 <&syscrg JH7110_SYSCLK_NOC_BUS_ISP_AXI>,
11483d90131fSXingyu Wu				 <&dvp_clk>;
11493d90131fSXingyu Wu			clock-names = "isp_top_core", "isp_top_axi",
11503d90131fSXingyu Wu				      "noc_bus_isp_axi", "dvp_clk";
11513d90131fSXingyu Wu			resets = <&syscrg JH7110_SYSRST_ISP_TOP>,
11523d90131fSXingyu Wu				 <&syscrg JH7110_SYSRST_ISP_TOP_AXI>,
11533d90131fSXingyu Wu				 <&syscrg JH7110_SYSRST_NOC_BUS_ISP_AXI>;
11543d90131fSXingyu Wu			#clock-cells = <1>;
11553d90131fSXingyu Wu			#reset-cells = <1>;
11563d90131fSXingyu Wu			power-domains = <&pwrc JH7110_PD_ISP>;
11573d90131fSXingyu Wu		};
11583d90131fSXingyu Wu
115928ecaaa5SChanghuang Liang		csi_phy: phy@19820000 {
116028ecaaa5SChanghuang Liang			compatible = "starfive,jh7110-dphy-rx";
116128ecaaa5SChanghuang Liang			reg = <0x0 0x19820000 0x0 0x10000>;
116228ecaaa5SChanghuang Liang			clocks = <&ispcrg JH7110_ISPCLK_M31DPHY_CFG_IN>,
116328ecaaa5SChanghuang Liang				 <&ispcrg JH7110_ISPCLK_M31DPHY_REF_IN>,
116428ecaaa5SChanghuang Liang				 <&ispcrg JH7110_ISPCLK_M31DPHY_TX_ESC_LAN0>;
116528ecaaa5SChanghuang Liang			clock-names = "cfg", "ref", "tx";
116628ecaaa5SChanghuang Liang			resets = <&ispcrg JH7110_ISPRST_M31DPHY_HW>,
116728ecaaa5SChanghuang Liang				 <&ispcrg JH7110_ISPRST_M31DPHY_B09_AON>;
116828ecaaa5SChanghuang Liang			power-domains = <&aon_syscon JH7110_AON_PD_DPHY_RX>;
116928ecaaa5SChanghuang Liang			#phy-cells = <0>;
117028ecaaa5SChanghuang Liang		};
117128ecaaa5SChanghuang Liang
117228ecaaa5SChanghuang Liang		camss: isp@19840000 {
117328ecaaa5SChanghuang Liang			compatible = "starfive,jh7110-camss";
117428ecaaa5SChanghuang Liang			reg = <0x0 0x19840000 0x0 0x10000>,
117528ecaaa5SChanghuang Liang			      <0x0 0x19870000 0x0 0x30000>;
117628ecaaa5SChanghuang Liang			reg-names = "syscon", "isp";
117728ecaaa5SChanghuang Liang			clocks = <&ispcrg JH7110_ISPCLK_DOM4_APB_FUNC>,
117828ecaaa5SChanghuang Liang				 <&ispcrg JH7110_ISPCLK_ISPV2_TOP_WRAPPER_C>,
117928ecaaa5SChanghuang Liang				 <&ispcrg JH7110_ISPCLK_DVP_INV>,
118028ecaaa5SChanghuang Liang				 <&ispcrg JH7110_ISPCLK_VIN_P_AXI_WR>,
118128ecaaa5SChanghuang Liang				 <&ispcrg JH7110_ISPCLK_MIPI_RX0_PXL>,
118228ecaaa5SChanghuang Liang				 <&syscrg JH7110_SYSCLK_ISP_TOP_CORE>,
118328ecaaa5SChanghuang Liang				 <&syscrg JH7110_SYSCLK_ISP_TOP_AXI>;
118428ecaaa5SChanghuang Liang			clock-names = "apb_func", "wrapper_clk_c", "dvp_inv",
118528ecaaa5SChanghuang Liang				      "axiwr", "mipi_rx0_pxl", "ispcore_2x",
118628ecaaa5SChanghuang Liang				      "isp_axi";
118728ecaaa5SChanghuang Liang			resets = <&ispcrg JH7110_ISPRST_ISPV2_TOP_WRAPPER_P>,
118828ecaaa5SChanghuang Liang				 <&ispcrg JH7110_ISPRST_ISPV2_TOP_WRAPPER_C>,
118928ecaaa5SChanghuang Liang				 <&ispcrg JH7110_ISPRST_VIN_P_AXI_RD>,
119028ecaaa5SChanghuang Liang				 <&ispcrg JH7110_ISPRST_VIN_P_AXI_WR>,
119128ecaaa5SChanghuang Liang				 <&syscrg JH7110_SYSRST_ISP_TOP>,
119228ecaaa5SChanghuang Liang				 <&syscrg JH7110_SYSRST_ISP_TOP_AXI>;
119328ecaaa5SChanghuang Liang			reset-names = "wrapper_p", "wrapper_c", "axird",
119428ecaaa5SChanghuang Liang				      "axiwr", "isp_top_n", "isp_top_axi";
119528ecaaa5SChanghuang Liang			power-domains = <&pwrc JH7110_PD_ISP>;
119628ecaaa5SChanghuang Liang			interrupts = <92>, <87>, <90>, <88>;
119728ecaaa5SChanghuang Liang			status = "disabled";
119828ecaaa5SChanghuang Liang		};
119928ecaaa5SChanghuang Liang
12003d90131fSXingyu Wu		voutcrg: clock-controller@295c0000 {
12013d90131fSXingyu Wu			compatible = "starfive,jh7110-voutcrg";
12023d90131fSXingyu Wu			reg = <0x0 0x295c0000 0x0 0x10000>;
12033d90131fSXingyu Wu			clocks = <&syscrg JH7110_SYSCLK_VOUT_SRC>,
12043d90131fSXingyu Wu				 <&syscrg JH7110_SYSCLK_VOUT_TOP_AHB>,
12053d90131fSXingyu Wu				 <&syscrg JH7110_SYSCLK_VOUT_TOP_AXI>,
12063d90131fSXingyu Wu				 <&syscrg JH7110_SYSCLK_VOUT_TOP_HDMITX0_MCLK>,
12073d90131fSXingyu Wu				 <&syscrg JH7110_SYSCLK_I2STX0_BCLK>,
12083d90131fSXingyu Wu				 <&hdmitx0_pixelclk>;
12093d90131fSXingyu Wu			clock-names = "vout_src", "vout_top_ahb",
12103d90131fSXingyu Wu				      "vout_top_axi", "vout_top_hdmitx0_mclk",
12113d90131fSXingyu Wu				      "i2stx0_bclk", "hdmitx0_pixelclk";
12123d90131fSXingyu Wu			resets = <&syscrg JH7110_SYSRST_VOUT_TOP_SRC>;
12133d90131fSXingyu Wu			#clock-cells = <1>;
12143d90131fSXingyu Wu			#reset-cells = <1>;
12153d90131fSXingyu Wu			power-domains = <&pwrc JH7110_PD_VOUT>;
12163d90131fSXingyu Wu		};
121760bf0a39SEmil Renner Berthing	};
121860bf0a39SEmil Renner Berthing};
1219