blob: 6d2675d6ceacdf2f33fa168a2686e0818f602563 [file] [log] [blame]
Yanhong Wang96c3eb722023-03-29 11:42:21 +08001// SPDX-License-Identifier: GPL-2.0 OR MIT
2/*
3 * Copyright (C) 2022 StarFive Technology Co., Ltd.
4 */
5
6/dts-v1/;
7#include <dt-bindings/clock/starfive,jh7110-crg.h>
8#include <dt-bindings/reset/starfive,jh7110-crg.h>
9
10/ {
11 compatible = "starfive,jh7110";
12 #address-cells = <2>;
13 #size-cells = <2>;
14
15 cpus {
16 #address-cells = <1>;
17 #size-cells = <0>;
18
19 S7_0: cpu@0 {
20 compatible = "sifive,s7", "riscv";
21 reg = <0>;
22 device_type = "cpu";
23 i-cache-block-size = <64>;
24 i-cache-sets = <64>;
25 i-cache-size = <16384>;
26 next-level-cache = <&ccache>;
27 riscv,isa = "rv64imac_zba_zbb";
28 status = "disabled";
29
30 cpu0_intc: interrupt-controller {
31 compatible = "riscv,cpu-intc";
32 interrupt-controller;
33 #interrupt-cells = <1>;
34 };
35 };
36
37 U74_1: cpu@1 {
38 compatible = "sifive,u74-mc", "riscv";
39 reg = <1>;
40 d-cache-block-size = <64>;
41 d-cache-sets = <64>;
42 d-cache-size = <32768>;
43 d-tlb-sets = <1>;
44 d-tlb-size = <40>;
45 device_type = "cpu";
46 i-cache-block-size = <64>;
47 i-cache-sets = <64>;
48 i-cache-size = <32768>;
49 i-tlb-sets = <1>;
50 i-tlb-size = <40>;
51 mmu-type = "riscv,sv39";
52 next-level-cache = <&ccache>;
53 riscv,isa = "rv64imafdc_zba_zbb";
54 tlb-split;
55
56 cpu1_intc: interrupt-controller {
57 compatible = "riscv,cpu-intc";
58 interrupt-controller;
59 #interrupt-cells = <1>;
60 };
61 };
62
63 U74_2: cpu@2 {
64 compatible = "sifive,u74-mc", "riscv";
65 reg = <2>;
66 d-cache-block-size = <64>;
67 d-cache-sets = <64>;
68 d-cache-size = <32768>;
69 d-tlb-sets = <1>;
70 d-tlb-size = <40>;
71 device_type = "cpu";
72 i-cache-block-size = <64>;
73 i-cache-sets = <64>;
74 i-cache-size = <32768>;
75 i-tlb-sets = <1>;
76 i-tlb-size = <40>;
77 mmu-type = "riscv,sv39";
78 next-level-cache = <&ccache>;
79 riscv,isa = "rv64imafdc_zba_zbb";
80 tlb-split;
81
82 cpu2_intc: interrupt-controller {
83 compatible = "riscv,cpu-intc";
84 interrupt-controller;
85 #interrupt-cells = <1>;
86 };
87 };
88
89 U74_3: cpu@3 {
90 compatible = "sifive,u74-mc", "riscv";
91 reg = <3>;
92 d-cache-block-size = <64>;
93 d-cache-sets = <64>;
94 d-cache-size = <32768>;
95 d-tlb-sets = <1>;
96 d-tlb-size = <40>;
97 device_type = "cpu";
98 i-cache-block-size = <64>;
99 i-cache-sets = <64>;
100 i-cache-size = <32768>;
101 i-tlb-sets = <1>;
102 i-tlb-size = <40>;
103 mmu-type = "riscv,sv39";
104 next-level-cache = <&ccache>;
105 riscv,isa = "rv64imafdc_zba_zbb";
106 tlb-split;
107
108 cpu3_intc: interrupt-controller {
109 compatible = "riscv,cpu-intc";
110 interrupt-controller;
111 #interrupt-cells = <1>;
112 };
113 };
114
115 U74_4: cpu@4 {
116 compatible = "sifive,u74-mc", "riscv";
117 reg = <4>;
118 d-cache-block-size = <64>;
119 d-cache-sets = <64>;
120 d-cache-size = <32768>;
121 d-tlb-sets = <1>;
122 d-tlb-size = <40>;
123 device_type = "cpu";
124 i-cache-block-size = <64>;
125 i-cache-sets = <64>;
126 i-cache-size = <32768>;
127 i-tlb-sets = <1>;
128 i-tlb-size = <40>;
129 mmu-type = "riscv,sv39";
130 next-level-cache = <&ccache>;
131 riscv,isa = "rv64imafdc_zba_zbb";
132 tlb-split;
133
134 cpu4_intc: interrupt-controller {
135 compatible = "riscv,cpu-intc";
136 interrupt-controller;
137 #interrupt-cells = <1>;
138 };
139 };
140
141 cpu-map {
142 cluster0 {
143 core0 {
144 cpu = <&S7_0>;
145 };
146
147 core1 {
148 cpu = <&U74_1>;
149 };
150
151 core2 {
152 cpu = <&U74_2>;
153 };
154
155 core3 {
156 cpu = <&U74_3>;
157 };
158
159 core4 {
160 cpu = <&U74_4>;
161 };
162 };
163 };
164 };
165
Torsten Duwe42fa87e2023-08-14 18:05:33 +0200166 timer {
167 compatible = "riscv,timer";
168 interrupts-extended = <&cpu0_intc 5>,
169 <&cpu1_intc 5>,
170 <&cpu2_intc 5>,
171 <&cpu3_intc 5>,
172 <&cpu4_intc 5>;
173 };
174
Yanhong Wang96c3eb722023-03-29 11:42:21 +0800175 osc: oscillator {
176 compatible = "fixed-clock";
177 clock-output-names = "osc";
178 #clock-cells = <0>;
179 };
180
181 rtc_osc: rtc-oscillator {
182 compatible = "fixed-clock";
183 clock-output-names = "rtc_osc";
184 #clock-cells = <0>;
185 };
186
187 gmac0_rmii_refin: gmac0-rmii-refin-clock {
188 compatible = "fixed-clock";
189 clock-output-names = "gmac0_rmii_refin";
190 #clock-cells = <0>;
191 };
192
193 gmac0_rgmii_rxin: gmac0-rgmii-rxin-clock {
194 compatible = "fixed-clock";
195 clock-output-names = "gmac0_rgmii_rxin";
196 #clock-cells = <0>;
197 };
198
199 gmac1_rmii_refin: gmac1-rmii-refin-clock {
200 compatible = "fixed-clock";
201 clock-output-names = "gmac1_rmii_refin";
202 #clock-cells = <0>;
203 };
204
205 gmac1_rgmii_rxin: gmac1-rgmii-rxin-clock {
206 compatible = "fixed-clock";
207 clock-output-names = "gmac1_rgmii_rxin";
208 #clock-cells = <0>;
209 };
210
211 i2stx_bclk_ext: i2stx-bclk-ext-clock {
212 compatible = "fixed-clock";
213 clock-output-names = "i2stx_bclk_ext";
214 #clock-cells = <0>;
215 };
216
217 i2stx_lrck_ext: i2stx-lrck-ext-clock {
218 compatible = "fixed-clock";
219 clock-output-names = "i2stx_lrck_ext";
220 #clock-cells = <0>;
221 };
222
223 i2srx_bclk_ext: i2srx-bclk-ext-clock {
224 compatible = "fixed-clock";
225 clock-output-names = "i2srx_bclk_ext";
226 #clock-cells = <0>;
227 };
228
229 i2srx_lrck_ext: i2srx-lrck-ext-clock {
230 compatible = "fixed-clock";
231 clock-output-names = "i2srx_lrck_ext";
232 #clock-cells = <0>;
233 };
234
235 tdm_ext: tdm-ext-clock {
236 compatible = "fixed-clock";
237 clock-output-names = "tdm_ext";
238 #clock-cells = <0>;
239 };
240
241 mclk_ext: mclk-ext-clock {
242 compatible = "fixed-clock";
243 clock-output-names = "mclk_ext";
244 #clock-cells = <0>;
245 };
246
Yanhong Wang7f63bd92023-06-15 17:36:44 +0800247 stmmac_axi_setup: stmmac-axi-config {
248 snps,lpi_en;
249 snps,wr_osr_lmt = <4>;
250 snps,rd_osr_lmt = <4>;
251 snps,blen = <256 128 64 32 0 0 0>;
252 };
253
Yanhong Wang96c3eb722023-03-29 11:42:21 +0800254 soc {
255 compatible = "simple-bus";
256 interrupt-parent = <&plic>;
257 #address-cells = <2>;
258 #size-cells = <2>;
259 ranges;
260
261 clint: timer@2000000 {
262 compatible = "starfive,jh7110-clint", "sifive,clint0";
263 reg = <0x0 0x2000000 0x0 0x10000>;
264 interrupts-extended = <&cpu0_intc 3>, <&cpu0_intc 7>,
265 <&cpu1_intc 3>, <&cpu1_intc 7>,
266 <&cpu2_intc 3>, <&cpu2_intc 7>,
267 <&cpu3_intc 3>, <&cpu3_intc 7>,
268 <&cpu4_intc 3>, <&cpu4_intc 7>;
269 };
270
271 plic: interrupt-controller@c000000 {
272 compatible = "starfive,jh7110-plic", "sifive,plic-1.0.0";
273 reg = <0x0 0xc000000 0x0 0x4000000>;
274 interrupts-extended = <&cpu0_intc 11>,
275 <&cpu1_intc 11>, <&cpu1_intc 9>,
276 <&cpu2_intc 11>, <&cpu2_intc 9>,
277 <&cpu3_intc 11>, <&cpu3_intc 9>,
278 <&cpu4_intc 11>, <&cpu4_intc 9>;
279 interrupt-controller;
280 #interrupt-cells = <1>;
281 #address-cells = <0>;
282 riscv,ndev = <136>;
283 };
284
285 ccache: cache-controller@2010000 {
286 compatible = "starfive,jh7110-ccache", "sifive,ccache0", "cache";
287 reg = <0x0 0x2010000 0x0 0x4000>;
288 interrupts = <1>, <3>, <4>, <2>;
289 cache-block-size = <64>;
290 cache-level = <2>;
291 cache-sets = <2048>;
292 cache-size = <2097152>;
293 cache-unified;
294 };
295
296 uart0: serial@10000000 {
297 compatible = "snps,dw-apb-uart";
298 reg = <0x0 0x10000000 0x0 0x10000>;
299 clocks = <&syscrg JH7110_SYSCLK_UART0_CORE>,
300 <&syscrg JH7110_SYSCLK_UART0_APB>;
301 clock-names = "baudclk", "apb_pclk";
302 resets = <&syscrg JH7110_SYSRST_UART0_APB>,
303 <&syscrg JH7110_SYSRST_UART0_CORE>;
304 interrupts = <32>;
305 reg-io-width = <4>;
306 reg-shift = <2>;
307 status = "disabled";
308 };
309
310 uart1: serial@10010000 {
311 compatible = "snps,dw-apb-uart";
312 reg = <0x0 0x10010000 0x0 0x10000>;
313 clocks = <&syscrg JH7110_SYSCLK_UART1_CORE>,
314 <&syscrg JH7110_SYSCLK_UART1_APB>;
315 clock-names = "baudclk", "apb_pclk";
316 resets = <&syscrg JH7110_SYSRST_UART1_APB>,
317 <&syscrg JH7110_SYSRST_UART1_CORE>;
318 interrupts = <33>;
319 reg-io-width = <4>;
320 reg-shift = <2>;
321 status = "disabled";
322 };
323
324 uart2: serial@10020000 {
325 compatible = "snps,dw-apb-uart";
326 reg = <0x0 0x10020000 0x0 0x10000>;
327 clocks = <&syscrg JH7110_SYSCLK_UART2_CORE>,
328 <&syscrg JH7110_SYSCLK_UART2_APB>;
329 clock-names = "baudclk", "apb_pclk";
330 resets = <&syscrg JH7110_SYSRST_UART2_APB>,
331 <&syscrg JH7110_SYSRST_UART2_CORE>;
332 interrupts = <34>;
333 reg-io-width = <4>;
334 reg-shift = <2>;
335 status = "disabled";
336 };
337
338 i2c0: i2c@10030000 {
339 compatible = "snps,designware-i2c";
340 reg = <0x0 0x10030000 0x0 0x10000>;
341 clocks = <&syscrg JH7110_SYSCLK_I2C0_APB>;
342 clock-names = "ref";
343 resets = <&syscrg JH7110_SYSRST_I2C0_APB>;
344 interrupts = <35>;
345 #address-cells = <1>;
346 #size-cells = <0>;
347 status = "disabled";
348 };
349
350 i2c1: i2c@10040000 {
351 compatible = "snps,designware-i2c";
352 reg = <0x0 0x10040000 0x0 0x10000>;
353 clocks = <&syscrg JH7110_SYSCLK_I2C1_APB>;
354 clock-names = "ref";
355 resets = <&syscrg JH7110_SYSRST_I2C1_APB>;
356 interrupts = <36>;
357 #address-cells = <1>;
358 #size-cells = <0>;
359 status = "disabled";
360 };
361
362 i2c2: i2c@10050000 {
363 compatible = "snps,designware-i2c";
364 reg = <0x0 0x10050000 0x0 0x10000>;
365 clocks = <&syscrg JH7110_SYSCLK_I2C2_APB>;
366 clock-names = "ref";
367 resets = <&syscrg JH7110_SYSRST_I2C2_APB>;
368 interrupts = <37>;
369 #address-cells = <1>;
370 #size-cells = <0>;
371 status = "disabled";
372 };
373
374 stgcrg: clock-controller@10230000 {
375 compatible = "starfive,jh7110-stgcrg";
376 reg = <0x0 0x10230000 0x0 0x10000>;
377 #clock-cells = <1>;
378 #reset-cells = <1>;
379 };
380
381 stg_syscon: stg_syscon@10240000 {
382 compatible = "starfive,jh7110-stg-syscon","syscon";
383 reg = <0x0 0x10240000 0x0 0x1000>;
384 };
385
386 uart3: serial@12000000 {
387 compatible = "snps,dw-apb-uart";
388 reg = <0x0 0x12000000 0x0 0x10000>;
389 clocks = <&syscrg JH7110_SYSCLK_UART3_CORE>,
390 <&syscrg JH7110_SYSCLK_UART3_APB>;
391 clock-names = "baudclk", "apb_pclk";
392 resets = <&syscrg JH7110_SYSRST_UART3_APB>,
393 <&syscrg JH7110_SYSRST_UART3_CORE>;
394 interrupts = <45>;
395 reg-io-width = <4>;
396 reg-shift = <2>;
397 status = "disabled";
398 };
399
400 uart4: serial@12010000 {
401 compatible = "snps,dw-apb-uart";
402 reg = <0x0 0x12010000 0x0 0x10000>;
403 clocks = <&syscrg JH7110_SYSCLK_UART4_CORE>,
404 <&syscrg JH7110_SYSCLK_UART4_APB>;
405 clock-names = "baudclk", "apb_pclk";
406 resets = <&syscrg JH7110_SYSRST_UART4_APB>,
407 <&syscrg JH7110_SYSRST_UART4_CORE>;
408 interrupts = <46>;
409 reg-io-width = <4>;
410 reg-shift = <2>;
411 status = "disabled";
412 };
413
414 uart5: serial@12020000 {
415 compatible = "snps,dw-apb-uart";
416 reg = <0x0 0x12020000 0x0 0x10000>;
417 clocks = <&syscrg JH7110_SYSCLK_UART5_CORE>,
418 <&syscrg JH7110_SYSCLK_UART5_APB>;
419 clock-names = "baudclk", "apb_pclk";
420 resets = <&syscrg JH7110_SYSRST_UART5_APB>,
421 <&syscrg JH7110_SYSRST_UART5_CORE>;
422 interrupts = <47>;
423 reg-io-width = <4>;
424 reg-shift = <2>;
425 status = "disabled";
426 };
427
428 i2c3: i2c@12030000 {
429 compatible = "snps,designware-i2c";
430 reg = <0x0 0x12030000 0x0 0x10000>;
431 clocks = <&syscrg JH7110_SYSCLK_I2C3_APB>;
432 clock-names = "ref";
433 resets = <&syscrg JH7110_SYSRST_I2C3_APB>;
434 interrupts = <48>;
435 #address-cells = <1>;
436 #size-cells = <0>;
437 status = "disabled";
438 };
439
440 i2c4: i2c@12040000 {
441 compatible = "snps,designware-i2c";
442 reg = <0x0 0x12040000 0x0 0x10000>;
443 clocks = <&syscrg JH7110_SYSCLK_I2C4_APB>;
444 clock-names = "ref";
445 resets = <&syscrg JH7110_SYSRST_I2C4_APB>;
446 interrupts = <49>;
447 #address-cells = <1>;
448 #size-cells = <0>;
449 status = "disabled";
450 };
451
452 i2c5: i2c@12050000 {
453 compatible = "snps,designware-i2c";
454 reg = <0x0 0x12050000 0x0 0x10000>;
455 clocks = <&syscrg JH7110_SYSCLK_I2C5_APB>;
456 clock-names = "ref";
457 resets = <&syscrg JH7110_SYSRST_I2C5_APB>;
458 interrupts = <50>;
459 #address-cells = <1>;
460 #size-cells = <0>;
461 status = "disabled";
462 };
463
464 i2c6: i2c@12060000 {
465 compatible = "snps,designware-i2c";
466 reg = <0x0 0x12060000 0x0 0x10000>;
467 clocks = <&syscrg JH7110_SYSCLK_I2C6_APB>;
468 clock-names = "ref";
469 resets = <&syscrg JH7110_SYSRST_I2C6_APB>;
470 interrupts = <51>;
471 #address-cells = <1>;
472 #size-cells = <0>;
473 status = "disabled";
474 };
475
476 qspi: spi@13010000 {
477 compatible = "cdns,qspi-nor";
478 reg = <0x0 0x13010000 0x0 0x10000
479 0x0 0x21000000 0x0 0x400000>;
480 clocks = <&syscrg JH7110_SYSCLK_QSPI_REF>;
481 clock-names = "clk_ref";
482 resets = <&syscrg JH7110_SYSRST_QSPI_APB>,
483 <&syscrg JH7110_SYSRST_QSPI_AHB>,
484 <&syscrg JH7110_SYSRST_QSPI_REF>;
485 reset-names = "rst_apb", "rst_ahb", "rst_ref";
486 cdns,fifo-depth = <256>;
487 cdns,fifo-width = <4>;
488 #address-cells = <1>;
489 #size-cells = <0>;
490 };
491
492 syscrg: clock-controller@13020000 {
493 compatible = "starfive,jh7110-syscrg";
494 reg = <0x0 0x13020000 0x0 0x10000>;
495 clocks = <&osc>, <&gmac1_rmii_refin>,
496 <&gmac1_rgmii_rxin>,
497 <&i2stx_bclk_ext>, <&i2stx_lrck_ext>,
498 <&i2srx_bclk_ext>, <&i2srx_lrck_ext>,
Xingyu Wu1345c9e2023-07-07 18:50:09 +0800499 <&tdm_ext>, <&mclk_ext>,
500 <&pllclk JH7110_SYSCLK_PLL0_OUT>,
501 <&pllclk JH7110_SYSCLK_PLL1_OUT>,
502 <&pllclk JH7110_SYSCLK_PLL2_OUT>;
Yanhong Wang96c3eb722023-03-29 11:42:21 +0800503 clock-names = "osc", "gmac1_rmii_refin",
504 "gmac1_rgmii_rxin",
505 "i2stx_bclk_ext", "i2stx_lrck_ext",
506 "i2srx_bclk_ext", "i2srx_lrck_ext",
Xingyu Wu1345c9e2023-07-07 18:50:09 +0800507 "tdm_ext", "mclk_ext",
508 "pll0_out", "pll1_out", "pll2_out";
Yanhong Wang96c3eb722023-03-29 11:42:21 +0800509 #clock-cells = <1>;
510 #reset-cells = <1>;
511 };
512
513 sys_syscon: sys_syscon@13030000 {
Xingyu Wu7ae81bb2023-07-07 18:50:08 +0800514 compatible = "starfive,jh7110-sys-syscon","syscon", "simple-mfd";
Yanhong Wang96c3eb722023-03-29 11:42:21 +0800515 reg = <0x0 0x13030000 0x0 0x1000>;
Xingyu Wu7ae81bb2023-07-07 18:50:08 +0800516
517 pllclk: clock-controller {
518 compatible = "starfive,jh7110-pll";
519 clocks = <&osc>;
520 #clock-cells = <1>;
521 };
Yanhong Wang96c3eb722023-03-29 11:42:21 +0800522 };
523
524 sysgpio: pinctrl@13040000 {
525 compatible = "starfive,jh7110-sys-pinctrl";
526 reg = <0x0 0x13040000 0x0 0x10000>;
527 clocks = <&syscrg JH7110_SYSCLK_IOMUX_APB>;
528 resets = <&syscrg JH7110_SYSRST_IOMUX_APB>;
529 interrupts = <86>;
530 interrupt-controller;
531 #interrupt-cells = <2>;
532 gpio-controller;
533 #gpio-cells = <2>;
534 };
535
Chanho Park0fe44f62023-11-06 08:13:17 +0900536 watchdog@13070000 {
537 compatible = "starfive,jh7110-wdt";
538 reg = <0x0 0x13070000 0x0 0x10000>;
539 clocks = <&syscrg JH7110_SYSCLK_WDT_APB>,
540 <&syscrg JH7110_SYSCLK_WDT_CORE>;
541 clock-names = "apb", "core";
542 resets = <&syscrg JH7110_SYSRST_WDT_APB>,
543 <&syscrg JH7110_SYSRST_WDT_CORE>;
544 };
545
Yanhong Wang96c3eb722023-03-29 11:42:21 +0800546 mmc0: mmc@16010000 {
547 compatible = "starfive,jh7110-mmc";
548 reg = <0x0 0x16010000 0x0 0x10000>;
549 clocks = <&syscrg JH7110_SYSCLK_SDIO0_AHB>,
550 <&syscrg JH7110_SYSCLK_SDIO0_SDCARD>;
551 clock-names = "biu", "ciu";
552 resets = <&syscrg JH7110_SYSRST_SDIO0_AHB>;
553 reset-names = "reset";
554 interrupts = <74>;
555 fifo-depth = <32>;
556 fifo-watermark-aligned;
557 data-addr = <0>;
558 starfive,sysreg = <&sys_syscon 0x14 0x1a 0x7c000000>;
559 status = "disabled";
560 };
561
562 mmc1: mmc@16020000 {
563 compatible = "starfive,jh7110-mmc";
564 reg = <0x0 0x16020000 0x0 0x10000>;
565 clocks = <&syscrg JH7110_SYSCLK_SDIO1_AHB>,
566 <&syscrg JH7110_SYSCLK_SDIO1_SDCARD>;
567 clock-names = "biu", "ciu";
568 resets = <&syscrg JH7110_SYSRST_SDIO1_AHB>;
569 reset-names = "reset";
570 interrupts = <75>;
571 fifo-depth = <32>;
572 fifo-watermark-aligned;
573 data-addr = <0>;
574 starfive,sysreg = <&sys_syscon 0x9c 0x1 0x3e>;
575 status = "disabled";
576 };
577
Yanhong Wang7f63bd92023-06-15 17:36:44 +0800578 gmac0: ethernet@16030000 {
579 compatible = "starfive,jh7110-dwmac", "snps,dwmac-5.20";
580 reg = <0x0 0x16030000 0x0 0x10000>;
581 clocks = <&aoncrg JH7110_AONCLK_GMAC0_AXI>,
582 <&aoncrg JH7110_AONCLK_GMAC0_AHB>,
583 <&syscrg JH7110_SYSCLK_GMAC0_PTP>,
584 <&aoncrg JH7110_AONCLK_GMAC0_TX_INV>,
585 <&syscrg JH7110_SYSCLK_GMAC0_GTXC>;
586 clock-names = "stmmaceth", "pclk", "ptp_ref",
587 "tx", "gtx";
588 resets = <&aoncrg JH7110_AONRST_GMAC0_AXI>,
589 <&aoncrg JH7110_AONRST_GMAC0_AHB>;
590 reset-names = "stmmaceth", "ahb";
591 interrupts = <7>, <6>, <5>;
592 interrupt-names = "macirq", "eth_wake_irq", "eth_lpi";
593 snps,multicast-filter-bins = <64>;
594 snps,perfect-filter-entries = <8>;
595 rx-fifo-depth = <2048>;
596 tx-fifo-depth = <2048>;
597 snps,fixed-burst;
598 snps,no-pbl-x8;
599 snps,force_thresh_dma_mode;
600 snps,axi-config = <&stmmac_axi_setup>;
601 snps,tso;
602 snps,en-tx-lpi-clockgating;
603 snps,txpbl = <16>;
604 snps,rxpbl = <16>;
605 starfive,syscon = <&aon_syscon 0xc 0x12>;
606 status = "disabled";
607 };
608
609 gmac1: ethernet@16040000 {
610 compatible = "starfive,jh7110-dwmac", "snps,dwmac-5.20";
611 reg = <0x0 0x16040000 0x0 0x10000>;
612 clocks = <&syscrg JH7110_SYSCLK_GMAC1_AXI>,
613 <&syscrg JH7110_SYSCLK_GMAC1_AHB>,
614 <&syscrg JH7110_SYSCLK_GMAC1_PTP>,
615 <&syscrg JH7110_SYSCLK_GMAC1_TX_INV>,
616 <&syscrg JH7110_SYSCLK_GMAC1_GTXC>;
617 clock-names = "stmmaceth", "pclk", "ptp_ref",
618 "tx", "gtx";
619 resets = <&syscrg JH7110_SYSRST_GMAC1_AXI>,
620 <&syscrg JH7110_SYSRST_GMAC1_AHB>;
621 reset-names = "stmmaceth", "ahb";
622 interrupts = <78>, <77>, <76>;
623 interrupt-names = "macirq", "eth_wake_irq", "eth_lpi";
624 snps,multicast-filter-bins = <64>;
625 snps,perfect-filter-entries = <8>;
626 rx-fifo-depth = <2048>;
627 tx-fifo-depth = <2048>;
628 snps,fixed-burst;
629 snps,no-pbl-x8;
630 snps,force_thresh_dma_mode;
631 snps,axi-config = <&stmmac_axi_setup>;
632 snps,tso;
633 snps,en-tx-lpi-clockgating;
634 snps,txpbl = <16>;
635 snps,rxpbl = <16>;
636 starfive,syscon = <&sys_syscon 0x90 0x2>;
637 status = "disabled";
638 };
639
Chanho Park601941c2023-11-01 21:16:51 +0900640 rng: rng@1600c000 {
641 compatible = "starfive,jh7110-trng";
642 reg = <0x0 0x1600C000 0x0 0x4000>;
643 clocks = <&stgcrg JH7110_STGCLK_SEC_HCLK>,
644 <&stgcrg JH7110_STGCLK_SEC_MISCAHB>;
645 clock-names = "hclk", "ahb";
646 resets = <&stgcrg JH7110_STGRST_SEC_TOP_HRESETN>;
647 interrupts = <30>;
648 };
649
Yanhong Wang96c3eb722023-03-29 11:42:21 +0800650 aoncrg: clock-controller@17000000 {
651 compatible = "starfive,jh7110-aoncrg";
652 reg = <0x0 0x17000000 0x0 0x10000>;
653 clocks = <&osc>, <&rtc_osc>,
654 <&gmac0_rmii_refin>, <&gmac0_rgmii_rxin>,
655 <&syscrg JH7110_SYSCLK_STG_AXIAHB>,
656 <&syscrg JH7110_SYSCLK_APB_BUS>,
657 <&syscrg JH7110_SYSCLK_GMAC0_GTXCLK>;
658 clock-names = "osc", "rtc_osc", "gmac0_rmii_refin",
659 "gmac0_rgmii_rxin", "stg_axiahb",
660 "apb_bus", "gmac0_gtxclk";
661 #clock-cells = <1>;
662 #reset-cells = <1>;
663 };
664
665 aon_syscon: aon_syscon@17010000 {
666 compatible = "starfive,jh7110-aon-syscon","syscon";
667 reg = <0x0 0x17010000 0x0 0x1000>;
668 };
669
670 aongpio: pinctrl@17020000 {
671 compatible = "starfive,jh7110-aon-pinctrl";
672 reg = <0x0 0x17020000 0x0 0x10000>;
673 resets = <&aoncrg JH7110_AONRST_IOMUX>;
674 interrupts = <85>;
675 interrupt-controller;
676 #interrupt-cells = <2>;
677 gpio-controller;
678 #gpio-cells = <2>;
679 };
Mason Huo23dfd812023-07-25 17:46:50 +0800680
681 pcie0: pcie@2b000000 {
682 compatible = "starfive,jh7110-pcie";
683 reg = <0x0 0x2b000000 0x0 0x1000000
684 0x9 0x40000000 0x0 0x10000000>;
685 reg-names = "reg", "config";
686 #address-cells = <3>;
687 #size-cells = <2>;
688 #interrupt-cells = <1>;
689 ranges = <0x82000000 0x0 0x30000000 0x0 0x30000000 0x0 0x08000000>,
690 <0xc3000000 0x9 0x00000000 0x9 0x00000000 0x0 0x40000000>;
691 interrupts = <56>;
692 interrupt-parent = <&plic>;
693 interrupt-map-mask = <0x0 0x0 0x0 0x7>;
694 interrupt-map = <0x0 0x0 0x0 0x1 &plic 0x1>,
695 <0x0 0x0 0x0 0x2 &plic 0x2>,
696 <0x0 0x0 0x0 0x3 &plic 0x3>,
697 <0x0 0x0 0x0 0x4 &plic 0x4>;
698 msi-parent = <&plic>;
699 device_type = "pci";
700 starfive,stg-syscon = <&stg_syscon 0xc0 0xc4 0x130 0x1b8>;
701 bus-range = <0x0 0xff>;
702 clocks = <&syscrg JH7110_SYSCLK_NOC_BUS_STG_AXI>,
703 <&stgcrg JH7110_STGCLK_PCIE0_TL>,
704 <&stgcrg JH7110_STGCLK_PCIE0_AXI>,
705 <&stgcrg JH7110_STGCLK_PCIE0_APB>;
706 clock-names = "noc", "tl", "axi", "apb";
707 resets = <&stgcrg JH7110_STGRST_PCIE0_MST0>,
708 <&stgcrg JH7110_STGRST_PCIE0_SLV0>,
709 <&stgcrg JH7110_STGRST_PCIE0_SLV>,
710 <&stgcrg JH7110_STGRST_PCIE0_BRG>,
711 <&stgcrg JH7110_STGRST_PCIE0_CORE>,
712 <&stgcrg JH7110_STGRST_PCIE0_APB>;
713 reset-names = "mst0", "slv0", "slv", "brg",
714 "core", "apb";
715 status = "disabled";
716 };
717
718 pcie1: pcie@2c000000 {
719 compatible = "starfive,jh7110-pcie";
720 reg = <0x0 0x2c000000 0x0 0x1000000
721 0x9 0xc0000000 0x0 0x10000000>;
722 reg-names = "reg", "config";
723 #address-cells = <3>;
724 #size-cells = <2>;
725 #interrupt-cells = <1>;
726 ranges = <0x82000000 0x0 0x38000000 0x0 0x38000000 0x0 0x08000000>,
727 <0xc3000000 0x9 0x80000000 0x9 0x80000000 0x0 0x40000000>;
728 interrupts = <57>;
729 interrupt-parent = <&plic>;
730 interrupt-map-mask = <0x0 0x0 0x0 0x7>;
731 interrupt-map = <0x0 0x0 0x0 0x1 &plic 0x1>,
732 <0x0 0x0 0x0 0x2 &plic 0x2>,
733 <0x0 0x0 0x0 0x3 &plic 0x3>,
734 <0x0 0x0 0x0 0x4 &plic 0x4>;
735 msi-parent = <&plic>;
736 device_type = "pci";
737 starfive,stg-syscon = <&stg_syscon 0x270 0x274 0x2e0 0x368>;
738 bus-range = <0x0 0xff>;
739 clocks = <&syscrg JH7110_SYSCLK_NOC_BUS_STG_AXI>,
740 <&stgcrg JH7110_STGCLK_PCIE1_TL>,
741 <&stgcrg JH7110_STGCLK_PCIE1_AXI>,
742 <&stgcrg JH7110_STGCLK_PCIE1_APB>;
743 clock-names = "noc", "tl", "axi", "apb";
744 resets = <&stgcrg JH7110_STGRST_PCIE1_MST0>,
745 <&stgcrg JH7110_STGRST_PCIE1_SLV0>,
746 <&stgcrg JH7110_STGRST_PCIE1_SLV>,
747 <&stgcrg JH7110_STGRST_PCIE1_BRG>,
748 <&stgcrg JH7110_STGRST_PCIE1_CORE>,
749 <&stgcrg JH7110_STGRST_PCIE1_APB>;
750 reset-names = "mst0", "slv0", "slv", "brg",
751 "core", "apb";
752 status = "disabled";
753 };
Yanhong Wang96c3eb722023-03-29 11:42:21 +0800754 };
755};