1// SPDX-License-Identifier: GPL-2.0 OR MIT 2/* 3 * Copyright (C) 2022 StarFive Technology Co., Ltd. 4 * Copyright (C) 2022 Emil Renner Berthing <kernel@esmil.dk> 5 */ 6 7/dts-v1/; 8#include <dt-bindings/clock/starfive,jh7110-crg.h> 9#include <dt-bindings/power/starfive,jh7110-pmu.h> 10#include <dt-bindings/reset/starfive,jh7110-crg.h> 11#include <dt-bindings/thermal/thermal.h> 12 13/ { 14 compatible = "starfive,jh7110"; 15 #address-cells = <2>; 16 #size-cells = <2>; 17 18 cpus { 19 #address-cells = <1>; 20 #size-cells = <0>; 21 22 S7_0: cpu@0 { 23 compatible = "sifive,s7", "riscv"; 24 reg = <0>; 25 device_type = "cpu"; 26 i-cache-block-size = <64>; 27 i-cache-sets = <64>; 28 i-cache-size = <16384>; 29 next-level-cache = <&ccache>; 30 riscv,isa = "rv64imac_zba_zbb"; 31 status = "disabled"; 32 33 cpu0_intc: interrupt-controller { 34 compatible = "riscv,cpu-intc"; 35 interrupt-controller; 36 #interrupt-cells = <1>; 37 }; 38 }; 39 40 U74_1: cpu@1 { 41 compatible = "sifive,u74-mc", "riscv"; 42 reg = <1>; 43 d-cache-block-size = <64>; 44 d-cache-sets = <64>; 45 d-cache-size = <32768>; 46 d-tlb-sets = <1>; 47 d-tlb-size = <40>; 48 device_type = "cpu"; 49 i-cache-block-size = <64>; 50 i-cache-sets = <64>; 51 i-cache-size = <32768>; 52 i-tlb-sets = <1>; 53 i-tlb-size = <40>; 54 mmu-type = "riscv,sv39"; 55 next-level-cache = <&ccache>; 56 riscv,isa = "rv64imafdc_zba_zbb"; 57 tlb-split; 58 operating-points-v2 = <&cpu_opp>; 59 clocks = <&syscrg JH7110_SYSCLK_CPU_CORE>; 60 clock-names = "cpu"; 61 #cooling-cells = <2>; 62 63 cpu1_intc: interrupt-controller { 64 compatible = "riscv,cpu-intc"; 65 interrupt-controller; 66 #interrupt-cells = <1>; 67 }; 68 }; 69 70 U74_2: cpu@2 { 71 compatible = "sifive,u74-mc", "riscv"; 72 reg = <2>; 73 d-cache-block-size = <64>; 74 d-cache-sets = <64>; 75 d-cache-size = <32768>; 76 d-tlb-sets = <1>; 77 d-tlb-size = <40>; 78 device_type = "cpu"; 79 i-cache-block-size = <64>; 80 i-cache-sets = <64>; 81 i-cache-size = <32768>; 82 i-tlb-sets = <1>; 83 i-tlb-size = <40>; 84 mmu-type = "riscv,sv39"; 85 next-level-cache = <&ccache>; 86 riscv,isa = "rv64imafdc_zba_zbb"; 87 tlb-split; 88 operating-points-v2 = <&cpu_opp>; 89 clocks = <&syscrg JH7110_SYSCLK_CPU_CORE>; 90 clock-names = "cpu"; 91 #cooling-cells = <2>; 92 93 cpu2_intc: interrupt-controller { 94 compatible = "riscv,cpu-intc"; 95 interrupt-controller; 96 #interrupt-cells = <1>; 97 }; 98 }; 99 100 U74_3: cpu@3 { 101 compatible = "sifive,u74-mc", "riscv"; 102 reg = <3>; 103 d-cache-block-size = <64>; 104 d-cache-sets = <64>; 105 d-cache-size = <32768>; 106 d-tlb-sets = <1>; 107 d-tlb-size = <40>; 108 device_type = "cpu"; 109 i-cache-block-size = <64>; 110 i-cache-sets = <64>; 111 i-cache-size = <32768>; 112 i-tlb-sets = <1>; 113 i-tlb-size = <40>; 114 mmu-type = "riscv,sv39"; 115 next-level-cache = <&ccache>; 116 riscv,isa = "rv64imafdc_zba_zbb"; 117 tlb-split; 118 operating-points-v2 = <&cpu_opp>; 119 clocks = <&syscrg JH7110_SYSCLK_CPU_CORE>; 120 clock-names = "cpu"; 121 #cooling-cells = <2>; 122 123 cpu3_intc: interrupt-controller { 124 compatible = "riscv,cpu-intc"; 125 interrupt-controller; 126 #interrupt-cells = <1>; 127 }; 128 }; 129 130 U74_4: cpu@4 { 131 compatible = "sifive,u74-mc", "riscv"; 132 reg = <4>; 133 d-cache-block-size = <64>; 134 d-cache-sets = <64>; 135 d-cache-size = <32768>; 136 d-tlb-sets = <1>; 137 d-tlb-size = <40>; 138 device_type = "cpu"; 139 i-cache-block-size = <64>; 140 i-cache-sets = <64>; 141 i-cache-size = <32768>; 142 i-tlb-sets = <1>; 143 i-tlb-size = <40>; 144 mmu-type = "riscv,sv39"; 145 next-level-cache = <&ccache>; 146 riscv,isa = "rv64imafdc_zba_zbb"; 147 tlb-split; 148 operating-points-v2 = <&cpu_opp>; 149 clocks = <&syscrg JH7110_SYSCLK_CPU_CORE>; 150 clock-names = "cpu"; 151 #cooling-cells = <2>; 152 153 cpu4_intc: interrupt-controller { 154 compatible = "riscv,cpu-intc"; 155 interrupt-controller; 156 #interrupt-cells = <1>; 157 }; 158 }; 159 160 cpu-map { 161 cluster0 { 162 core0 { 163 cpu = <&S7_0>; 164 }; 165 166 core1 { 167 cpu = <&U74_1>; 168 }; 169 170 core2 { 171 cpu = <&U74_2>; 172 }; 173 174 core3 { 175 cpu = <&U74_3>; 176 }; 177 178 core4 { 179 cpu = <&U74_4>; 180 }; 181 }; 182 }; 183 }; 184 185 cpu_opp: opp-table-0 { 186 compatible = "operating-points-v2"; 187 opp-shared; 188 opp-375000000 { 189 opp-hz = /bits/ 64 <375000000>; 190 opp-microvolt = <800000>; 191 }; 192 opp-500000000 { 193 opp-hz = /bits/ 64 <500000000>; 194 opp-microvolt = <800000>; 195 }; 196 opp-750000000 { 197 opp-hz = /bits/ 64 <750000000>; 198 opp-microvolt = <800000>; 199 }; 200 opp-1500000000 { 201 opp-hz = /bits/ 64 <1500000000>; 202 opp-microvolt = <1040000>; 203 }; 204 }; 205 206 thermal-zones { 207 cpu-thermal { 208 polling-delay-passive = <250>; 209 polling-delay = <15000>; 210 211 thermal-sensors = <&sfctemp>; 212 213 cooling-maps { 214 map0 { 215 trip = <&cpu_alert0>; 216 cooling-device = 217 <&U74_1 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>, 218 <&U74_2 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>, 219 <&U74_3 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>, 220 <&U74_4 THERMAL_NO_LIMIT THERMAL_NO_LIMIT>; 221 }; 222 }; 223 224 trips { 225 cpu_alert0: cpu_alert0 { 226 /* milliCelsius */ 227 temperature = <85000>; 228 hysteresis = <2000>; 229 type = "passive"; 230 }; 231 232 cpu_crit { 233 /* milliCelsius */ 234 temperature = <100000>; 235 hysteresis = <2000>; 236 type = "critical"; 237 }; 238 }; 239 }; 240 }; 241 242 dvp_clk: dvp-clock { 243 compatible = "fixed-clock"; 244 clock-output-names = "dvp_clk"; 245 #clock-cells = <0>; 246 }; 247 gmac0_rgmii_rxin: gmac0-rgmii-rxin-clock { 248 compatible = "fixed-clock"; 249 clock-output-names = "gmac0_rgmii_rxin"; 250 #clock-cells = <0>; 251 }; 252 253 gmac0_rmii_refin: gmac0-rmii-refin-clock { 254 compatible = "fixed-clock"; 255 clock-output-names = "gmac0_rmii_refin"; 256 #clock-cells = <0>; 257 }; 258 259 gmac1_rgmii_rxin: gmac1-rgmii-rxin-clock { 260 compatible = "fixed-clock"; 261 clock-output-names = "gmac1_rgmii_rxin"; 262 #clock-cells = <0>; 263 }; 264 265 gmac1_rmii_refin: gmac1-rmii-refin-clock { 266 compatible = "fixed-clock"; 267 clock-output-names = "gmac1_rmii_refin"; 268 #clock-cells = <0>; 269 }; 270 271 hdmitx0_pixelclk: hdmitx0-pixel-clock { 272 compatible = "fixed-clock"; 273 clock-output-names = "hdmitx0_pixelclk"; 274 #clock-cells = <0>; 275 }; 276 277 i2srx_bclk_ext: i2srx-bclk-ext-clock { 278 compatible = "fixed-clock"; 279 clock-output-names = "i2srx_bclk_ext"; 280 #clock-cells = <0>; 281 }; 282 283 i2srx_lrck_ext: i2srx-lrck-ext-clock { 284 compatible = "fixed-clock"; 285 clock-output-names = "i2srx_lrck_ext"; 286 #clock-cells = <0>; 287 }; 288 289 i2stx_bclk_ext: i2stx-bclk-ext-clock { 290 compatible = "fixed-clock"; 291 clock-output-names = "i2stx_bclk_ext"; 292 #clock-cells = <0>; 293 }; 294 295 i2stx_lrck_ext: i2stx-lrck-ext-clock { 296 compatible = "fixed-clock"; 297 clock-output-names = "i2stx_lrck_ext"; 298 #clock-cells = <0>; 299 }; 300 301 mclk_ext: mclk-ext-clock { 302 compatible = "fixed-clock"; 303 clock-output-names = "mclk_ext"; 304 #clock-cells = <0>; 305 }; 306 307 osc: oscillator { 308 compatible = "fixed-clock"; 309 clock-output-names = "osc"; 310 #clock-cells = <0>; 311 }; 312 313 rtc_osc: rtc-oscillator { 314 compatible = "fixed-clock"; 315 clock-output-names = "rtc_osc"; 316 #clock-cells = <0>; 317 }; 318 319 stmmac_axi_setup: stmmac-axi-config { 320 snps,lpi_en; 321 snps,wr_osr_lmt = <4>; 322 snps,rd_osr_lmt = <4>; 323 snps,blen = <256 128 64 32 0 0 0>; 324 }; 325 326 tdm_ext: tdm-ext-clock { 327 compatible = "fixed-clock"; 328 clock-output-names = "tdm_ext"; 329 #clock-cells = <0>; 330 }; 331 332 soc { 333 compatible = "simple-bus"; 334 interrupt-parent = <&plic>; 335 #address-cells = <2>; 336 #size-cells = <2>; 337 ranges; 338 339 clint: timer@2000000 { 340 compatible = "starfive,jh7110-clint", "sifive,clint0"; 341 reg = <0x0 0x2000000 0x0 0x10000>; 342 interrupts-extended = <&cpu0_intc 3>, <&cpu0_intc 7>, 343 <&cpu1_intc 3>, <&cpu1_intc 7>, 344 <&cpu2_intc 3>, <&cpu2_intc 7>, 345 <&cpu3_intc 3>, <&cpu3_intc 7>, 346 <&cpu4_intc 3>, <&cpu4_intc 7>; 347 }; 348 349 ccache: cache-controller@2010000 { 350 compatible = "starfive,jh7110-ccache", "sifive,ccache0", "cache"; 351 reg = <0x0 0x2010000 0x0 0x4000>; 352 interrupts = <1>, <3>, <4>, <2>; 353 cache-block-size = <64>; 354 cache-level = <2>; 355 cache-sets = <2048>; 356 cache-size = <2097152>; 357 cache-unified; 358 }; 359 360 plic: interrupt-controller@c000000 { 361 compatible = "starfive,jh7110-plic", "sifive,plic-1.0.0"; 362 reg = <0x0 0xc000000 0x0 0x4000000>; 363 interrupts-extended = <&cpu0_intc 11>, 364 <&cpu1_intc 11>, <&cpu1_intc 9>, 365 <&cpu2_intc 11>, <&cpu2_intc 9>, 366 <&cpu3_intc 11>, <&cpu3_intc 9>, 367 <&cpu4_intc 11>, <&cpu4_intc 9>; 368 interrupt-controller; 369 #interrupt-cells = <1>; 370 #address-cells = <0>; 371 riscv,ndev = <136>; 372 }; 373 374 uart0: serial@10000000 { 375 compatible = "snps,dw-apb-uart"; 376 reg = <0x0 0x10000000 0x0 0x10000>; 377 clocks = <&syscrg JH7110_SYSCLK_UART0_CORE>, 378 <&syscrg JH7110_SYSCLK_UART0_APB>; 379 clock-names = "baudclk", "apb_pclk"; 380 resets = <&syscrg JH7110_SYSRST_UART0_APB>; 381 interrupts = <32>; 382 reg-io-width = <4>; 383 reg-shift = <2>; 384 status = "disabled"; 385 }; 386 387 uart1: serial@10010000 { 388 compatible = "snps,dw-apb-uart"; 389 reg = <0x0 0x10010000 0x0 0x10000>; 390 clocks = <&syscrg JH7110_SYSCLK_UART1_CORE>, 391 <&syscrg JH7110_SYSCLK_UART1_APB>; 392 clock-names = "baudclk", "apb_pclk"; 393 resets = <&syscrg JH7110_SYSRST_UART1_APB>; 394 interrupts = <33>; 395 reg-io-width = <4>; 396 reg-shift = <2>; 397 status = "disabled"; 398 }; 399 400 uart2: serial@10020000 { 401 compatible = "snps,dw-apb-uart"; 402 reg = <0x0 0x10020000 0x0 0x10000>; 403 clocks = <&syscrg JH7110_SYSCLK_UART2_CORE>, 404 <&syscrg JH7110_SYSCLK_UART2_APB>; 405 clock-names = "baudclk", "apb_pclk"; 406 resets = <&syscrg JH7110_SYSRST_UART2_APB>; 407 interrupts = <34>; 408 reg-io-width = <4>; 409 reg-shift = <2>; 410 status = "disabled"; 411 }; 412 413 i2c0: i2c@10030000 { 414 compatible = "snps,designware-i2c"; 415 reg = <0x0 0x10030000 0x0 0x10000>; 416 clocks = <&syscrg JH7110_SYSCLK_I2C0_APB>; 417 clock-names = "ref"; 418 resets = <&syscrg JH7110_SYSRST_I2C0_APB>; 419 interrupts = <35>; 420 #address-cells = <1>; 421 #size-cells = <0>; 422 status = "disabled"; 423 }; 424 425 i2c1: i2c@10040000 { 426 compatible = "snps,designware-i2c"; 427 reg = <0x0 0x10040000 0x0 0x10000>; 428 clocks = <&syscrg JH7110_SYSCLK_I2C1_APB>; 429 clock-names = "ref"; 430 resets = <&syscrg JH7110_SYSRST_I2C1_APB>; 431 interrupts = <36>; 432 #address-cells = <1>; 433 #size-cells = <0>; 434 status = "disabled"; 435 }; 436 437 i2c2: i2c@10050000 { 438 compatible = "snps,designware-i2c"; 439 reg = <0x0 0x10050000 0x0 0x10000>; 440 clocks = <&syscrg JH7110_SYSCLK_I2C2_APB>; 441 clock-names = "ref"; 442 resets = <&syscrg JH7110_SYSRST_I2C2_APB>; 443 interrupts = <37>; 444 #address-cells = <1>; 445 #size-cells = <0>; 446 status = "disabled"; 447 }; 448 449 spi0: spi@10060000 { 450 compatible = "arm,pl022", "arm,primecell"; 451 reg = <0x0 0x10060000 0x0 0x10000>; 452 clocks = <&syscrg JH7110_SYSCLK_SPI0_APB>, 453 <&syscrg JH7110_SYSCLK_SPI0_APB>; 454 clock-names = "sspclk", "apb_pclk"; 455 resets = <&syscrg JH7110_SYSRST_SPI0_APB>; 456 interrupts = <38>; 457 arm,primecell-periphid = <0x00041022>; 458 num-cs = <1>; 459 #address-cells = <1>; 460 #size-cells = <0>; 461 status = "disabled"; 462 }; 463 464 spi1: spi@10070000 { 465 compatible = "arm,pl022", "arm,primecell"; 466 reg = <0x0 0x10070000 0x0 0x10000>; 467 clocks = <&syscrg JH7110_SYSCLK_SPI1_APB>, 468 <&syscrg JH7110_SYSCLK_SPI1_APB>; 469 clock-names = "sspclk", "apb_pclk"; 470 resets = <&syscrg JH7110_SYSRST_SPI1_APB>; 471 interrupts = <39>; 472 arm,primecell-periphid = <0x00041022>; 473 num-cs = <1>; 474 #address-cells = <1>; 475 #size-cells = <0>; 476 status = "disabled"; 477 }; 478 479 spi2: spi@10080000 { 480 compatible = "arm,pl022", "arm,primecell"; 481 reg = <0x0 0x10080000 0x0 0x10000>; 482 clocks = <&syscrg JH7110_SYSCLK_SPI2_APB>, 483 <&syscrg JH7110_SYSCLK_SPI2_APB>; 484 clock-names = "sspclk", "apb_pclk"; 485 resets = <&syscrg JH7110_SYSRST_SPI2_APB>; 486 interrupts = <40>; 487 arm,primecell-periphid = <0x00041022>; 488 num-cs = <1>; 489 #address-cells = <1>; 490 #size-cells = <0>; 491 status = "disabled"; 492 }; 493 494 usb0: usb@10100000 { 495 compatible = "starfive,jh7110-usb"; 496 ranges = <0x0 0x0 0x10100000 0x100000>; 497 #address-cells = <1>; 498 #size-cells = <1>; 499 starfive,stg-syscon = <&stg_syscon 0x4>; 500 clocks = <&stgcrg JH7110_STGCLK_USB0_LPM>, 501 <&stgcrg JH7110_STGCLK_USB0_STB>, 502 <&stgcrg JH7110_STGCLK_USB0_APB>, 503 <&stgcrg JH7110_STGCLK_USB0_AXI>, 504 <&stgcrg JH7110_STGCLK_USB0_UTMI_APB>; 505 clock-names = "lpm", "stb", "apb", "axi", "utmi_apb"; 506 resets = <&stgcrg JH7110_STGRST_USB0_PWRUP>, 507 <&stgcrg JH7110_STGRST_USB0_APB>, 508 <&stgcrg JH7110_STGRST_USB0_AXI>, 509 <&stgcrg JH7110_STGRST_USB0_UTMI_APB>; 510 reset-names = "pwrup", "apb", "axi", "utmi_apb"; 511 status = "disabled"; 512 513 usb_cdns3: usb@0 { 514 compatible = "cdns,usb3"; 515 reg = <0x0 0x10000>, 516 <0x10000 0x10000>, 517 <0x20000 0x10000>; 518 reg-names = "otg", "xhci", "dev"; 519 interrupts = <100>, <108>, <110>; 520 interrupt-names = "host", "peripheral", "otg"; 521 phys = <&usbphy0>; 522 phy-names = "cdns3,usb2-phy"; 523 }; 524 }; 525 526 usbphy0: phy@10200000 { 527 compatible = "starfive,jh7110-usb-phy"; 528 reg = <0x0 0x10200000 0x0 0x10000>; 529 clocks = <&syscrg JH7110_SYSCLK_USB_125M>, 530 <&stgcrg JH7110_STGCLK_USB0_APP_125>; 531 clock-names = "125m", "app_125m"; 532 #phy-cells = <0>; 533 }; 534 535 pciephy0: phy@10210000 { 536 compatible = "starfive,jh7110-pcie-phy"; 537 reg = <0x0 0x10210000 0x0 0x10000>; 538 #phy-cells = <0>; 539 }; 540 541 pciephy1: phy@10220000 { 542 compatible = "starfive,jh7110-pcie-phy"; 543 reg = <0x0 0x10220000 0x0 0x10000>; 544 #phy-cells = <0>; 545 }; 546 547 stgcrg: clock-controller@10230000 { 548 compatible = "starfive,jh7110-stgcrg"; 549 reg = <0x0 0x10230000 0x0 0x10000>; 550 clocks = <&osc>, 551 <&syscrg JH7110_SYSCLK_HIFI4_CORE>, 552 <&syscrg JH7110_SYSCLK_STG_AXIAHB>, 553 <&syscrg JH7110_SYSCLK_USB_125M>, 554 <&syscrg JH7110_SYSCLK_CPU_BUS>, 555 <&syscrg JH7110_SYSCLK_HIFI4_AXI>, 556 <&syscrg JH7110_SYSCLK_NOCSTG_BUS>, 557 <&syscrg JH7110_SYSCLK_APB_BUS>; 558 clock-names = "osc", "hifi4_core", 559 "stg_axiahb", "usb_125m", 560 "cpu_bus", "hifi4_axi", 561 "nocstg_bus", "apb_bus"; 562 #clock-cells = <1>; 563 #reset-cells = <1>; 564 }; 565 566 stg_syscon: syscon@10240000 { 567 compatible = "starfive,jh7110-stg-syscon", "syscon"; 568 reg = <0x0 0x10240000 0x0 0x1000>; 569 }; 570 571 uart3: serial@12000000 { 572 compatible = "snps,dw-apb-uart"; 573 reg = <0x0 0x12000000 0x0 0x10000>; 574 clocks = <&syscrg JH7110_SYSCLK_UART3_CORE>, 575 <&syscrg JH7110_SYSCLK_UART3_APB>; 576 clock-names = "baudclk", "apb_pclk"; 577 resets = <&syscrg JH7110_SYSRST_UART3_APB>; 578 interrupts = <45>; 579 reg-io-width = <4>; 580 reg-shift = <2>; 581 status = "disabled"; 582 }; 583 584 uart4: serial@12010000 { 585 compatible = "snps,dw-apb-uart"; 586 reg = <0x0 0x12010000 0x0 0x10000>; 587 clocks = <&syscrg JH7110_SYSCLK_UART4_CORE>, 588 <&syscrg JH7110_SYSCLK_UART4_APB>; 589 clock-names = "baudclk", "apb_pclk"; 590 resets = <&syscrg JH7110_SYSRST_UART4_APB>; 591 interrupts = <46>; 592 reg-io-width = <4>; 593 reg-shift = <2>; 594 status = "disabled"; 595 }; 596 597 uart5: serial@12020000 { 598 compatible = "snps,dw-apb-uart"; 599 reg = <0x0 0x12020000 0x0 0x10000>; 600 clocks = <&syscrg JH7110_SYSCLK_UART5_CORE>, 601 <&syscrg JH7110_SYSCLK_UART5_APB>; 602 clock-names = "baudclk", "apb_pclk"; 603 resets = <&syscrg JH7110_SYSRST_UART5_APB>; 604 interrupts = <47>; 605 reg-io-width = <4>; 606 reg-shift = <2>; 607 status = "disabled"; 608 }; 609 610 i2c3: i2c@12030000 { 611 compatible = "snps,designware-i2c"; 612 reg = <0x0 0x12030000 0x0 0x10000>; 613 clocks = <&syscrg JH7110_SYSCLK_I2C3_APB>; 614 clock-names = "ref"; 615 resets = <&syscrg JH7110_SYSRST_I2C3_APB>; 616 interrupts = <48>; 617 #address-cells = <1>; 618 #size-cells = <0>; 619 status = "disabled"; 620 }; 621 622 i2c4: i2c@12040000 { 623 compatible = "snps,designware-i2c"; 624 reg = <0x0 0x12040000 0x0 0x10000>; 625 clocks = <&syscrg JH7110_SYSCLK_I2C4_APB>; 626 clock-names = "ref"; 627 resets = <&syscrg JH7110_SYSRST_I2C4_APB>; 628 interrupts = <49>; 629 #address-cells = <1>; 630 #size-cells = <0>; 631 status = "disabled"; 632 }; 633 634 i2c5: i2c@12050000 { 635 compatible = "snps,designware-i2c"; 636 reg = <0x0 0x12050000 0x0 0x10000>; 637 clocks = <&syscrg JH7110_SYSCLK_I2C5_APB>; 638 clock-names = "ref"; 639 resets = <&syscrg JH7110_SYSRST_I2C5_APB>; 640 interrupts = <50>; 641 #address-cells = <1>; 642 #size-cells = <0>; 643 status = "disabled"; 644 }; 645 646 i2c6: i2c@12060000 { 647 compatible = "snps,designware-i2c"; 648 reg = <0x0 0x12060000 0x0 0x10000>; 649 clocks = <&syscrg JH7110_SYSCLK_I2C6_APB>; 650 clock-names = "ref"; 651 resets = <&syscrg JH7110_SYSRST_I2C6_APB>; 652 interrupts = <51>; 653 #address-cells = <1>; 654 #size-cells = <0>; 655 status = "disabled"; 656 }; 657 658 spi3: spi@12070000 { 659 compatible = "arm,pl022", "arm,primecell"; 660 reg = <0x0 0x12070000 0x0 0x10000>; 661 clocks = <&syscrg JH7110_SYSCLK_SPI3_APB>, 662 <&syscrg JH7110_SYSCLK_SPI3_APB>; 663 clock-names = "sspclk", "apb_pclk"; 664 resets = <&syscrg JH7110_SYSRST_SPI3_APB>; 665 interrupts = <52>; 666 arm,primecell-periphid = <0x00041022>; 667 num-cs = <1>; 668 #address-cells = <1>; 669 #size-cells = <0>; 670 status = "disabled"; 671 }; 672 673 spi4: spi@12080000 { 674 compatible = "arm,pl022", "arm,primecell"; 675 reg = <0x0 0x12080000 0x0 0x10000>; 676 clocks = <&syscrg JH7110_SYSCLK_SPI4_APB>, 677 <&syscrg JH7110_SYSCLK_SPI4_APB>; 678 clock-names = "sspclk", "apb_pclk"; 679 resets = <&syscrg JH7110_SYSRST_SPI4_APB>; 680 interrupts = <53>; 681 arm,primecell-periphid = <0x00041022>; 682 num-cs = <1>; 683 #address-cells = <1>; 684 #size-cells = <0>; 685 status = "disabled"; 686 }; 687 688 spi5: spi@12090000 { 689 compatible = "arm,pl022", "arm,primecell"; 690 reg = <0x0 0x12090000 0x0 0x10000>; 691 clocks = <&syscrg JH7110_SYSCLK_SPI5_APB>, 692 <&syscrg JH7110_SYSCLK_SPI5_APB>; 693 clock-names = "sspclk", "apb_pclk"; 694 resets = <&syscrg JH7110_SYSRST_SPI5_APB>; 695 interrupts = <54>; 696 arm,primecell-periphid = <0x00041022>; 697 num-cs = <1>; 698 #address-cells = <1>; 699 #size-cells = <0>; 700 status = "disabled"; 701 }; 702 703 spi6: spi@120a0000 { 704 compatible = "arm,pl022", "arm,primecell"; 705 reg = <0x0 0x120A0000 0x0 0x10000>; 706 clocks = <&syscrg JH7110_SYSCLK_SPI6_APB>, 707 <&syscrg JH7110_SYSCLK_SPI6_APB>; 708 clock-names = "sspclk", "apb_pclk"; 709 resets = <&syscrg JH7110_SYSRST_SPI6_APB>; 710 interrupts = <55>; 711 arm,primecell-periphid = <0x00041022>; 712 num-cs = <1>; 713 #address-cells = <1>; 714 #size-cells = <0>; 715 status = "disabled"; 716 }; 717 718 sfctemp: temperature-sensor@120e0000 { 719 compatible = "starfive,jh7110-temp"; 720 reg = <0x0 0x120e0000 0x0 0x10000>; 721 clocks = <&syscrg JH7110_SYSCLK_TEMP_CORE>, 722 <&syscrg JH7110_SYSCLK_TEMP_APB>; 723 clock-names = "sense", "bus"; 724 resets = <&syscrg JH7110_SYSRST_TEMP_CORE>, 725 <&syscrg JH7110_SYSRST_TEMP_APB>; 726 reset-names = "sense", "bus"; 727 #thermal-sensor-cells = <0>; 728 }; 729 730 syscrg: clock-controller@13020000 { 731 compatible = "starfive,jh7110-syscrg"; 732 reg = <0x0 0x13020000 0x0 0x10000>; 733 clocks = <&osc>, <&gmac1_rmii_refin>, 734 <&gmac1_rgmii_rxin>, 735 <&i2stx_bclk_ext>, <&i2stx_lrck_ext>, 736 <&i2srx_bclk_ext>, <&i2srx_lrck_ext>, 737 <&tdm_ext>, <&mclk_ext>, 738 <&pllclk JH7110_PLLCLK_PLL0_OUT>, 739 <&pllclk JH7110_PLLCLK_PLL1_OUT>, 740 <&pllclk JH7110_PLLCLK_PLL2_OUT>; 741 clock-names = "osc", "gmac1_rmii_refin", 742 "gmac1_rgmii_rxin", 743 "i2stx_bclk_ext", "i2stx_lrck_ext", 744 "i2srx_bclk_ext", "i2srx_lrck_ext", 745 "tdm_ext", "mclk_ext", 746 "pll0_out", "pll1_out", "pll2_out"; 747 #clock-cells = <1>; 748 #reset-cells = <1>; 749 }; 750 751 sys_syscon: syscon@13030000 { 752 compatible = "starfive,jh7110-sys-syscon", "syscon", "simple-mfd"; 753 reg = <0x0 0x13030000 0x0 0x1000>; 754 755 pllclk: clock-controller { 756 compatible = "starfive,jh7110-pll"; 757 clocks = <&osc>; 758 #clock-cells = <1>; 759 }; 760 }; 761 762 sysgpio: pinctrl@13040000 { 763 compatible = "starfive,jh7110-sys-pinctrl"; 764 reg = <0x0 0x13040000 0x0 0x10000>; 765 clocks = <&syscrg JH7110_SYSCLK_IOMUX_APB>; 766 resets = <&syscrg JH7110_SYSRST_IOMUX_APB>; 767 interrupts = <86>; 768 interrupt-controller; 769 #interrupt-cells = <2>; 770 gpio-controller; 771 #gpio-cells = <2>; 772 }; 773 774 watchdog@13070000 { 775 compatible = "starfive,jh7110-wdt"; 776 reg = <0x0 0x13070000 0x0 0x10000>; 777 clocks = <&syscrg JH7110_SYSCLK_WDT_APB>, 778 <&syscrg JH7110_SYSCLK_WDT_CORE>; 779 clock-names = "apb", "core"; 780 resets = <&syscrg JH7110_SYSRST_WDT_APB>, 781 <&syscrg JH7110_SYSRST_WDT_CORE>; 782 }; 783 784 gmac0: ethernet@16030000 { 785 compatible = "starfive,jh7110-dwmac", "snps,dwmac-5.20"; 786 reg = <0x0 0x16030000 0x0 0x10000>; 787 clocks = <&aoncrg JH7110_AONCLK_GMAC0_AXI>, 788 <&aoncrg JH7110_AONCLK_GMAC0_AHB>, 789 <&syscrg JH7110_SYSCLK_GMAC0_PTP>, 790 <&aoncrg JH7110_AONCLK_GMAC0_TX_INV>, 791 <&syscrg JH7110_SYSCLK_GMAC0_GTXC>; 792 clock-names = "stmmaceth", "pclk", "ptp_ref", 793 "tx", "gtx"; 794 resets = <&aoncrg JH7110_AONRST_GMAC0_AXI>, 795 <&aoncrg JH7110_AONRST_GMAC0_AHB>; 796 reset-names = "stmmaceth", "ahb"; 797 interrupts = <7>, <6>, <5>; 798 interrupt-names = "macirq", "eth_wake_irq", "eth_lpi"; 799 rx-fifo-depth = <2048>; 800 tx-fifo-depth = <2048>; 801 snps,multicast-filter-bins = <64>; 802 snps,perfect-filter-entries = <8>; 803 snps,fixed-burst; 804 snps,no-pbl-x8; 805 snps,force_thresh_dma_mode; 806 snps,axi-config = <&stmmac_axi_setup>; 807 snps,tso; 808 snps,en-tx-lpi-clockgating; 809 snps,txpbl = <16>; 810 snps,rxpbl = <16>; 811 starfive,syscon = <&aon_syscon 0xc 0x12>; 812 status = "disabled"; 813 }; 814 815 gmac1: ethernet@16040000 { 816 compatible = "starfive,jh7110-dwmac", "snps,dwmac-5.20"; 817 reg = <0x0 0x16040000 0x0 0x10000>; 818 clocks = <&syscrg JH7110_SYSCLK_GMAC1_AXI>, 819 <&syscrg JH7110_SYSCLK_GMAC1_AHB>, 820 <&syscrg JH7110_SYSCLK_GMAC1_PTP>, 821 <&syscrg JH7110_SYSCLK_GMAC1_TX_INV>, 822 <&syscrg JH7110_SYSCLK_GMAC1_GTXC>; 823 clock-names = "stmmaceth", "pclk", "ptp_ref", 824 "tx", "gtx"; 825 resets = <&syscrg JH7110_SYSRST_GMAC1_AXI>, 826 <&syscrg JH7110_SYSRST_GMAC1_AHB>; 827 reset-names = "stmmaceth", "ahb"; 828 interrupts = <78>, <77>, <76>; 829 interrupt-names = "macirq", "eth_wake_irq", "eth_lpi"; 830 rx-fifo-depth = <2048>; 831 tx-fifo-depth = <2048>; 832 snps,multicast-filter-bins = <64>; 833 snps,perfect-filter-entries = <8>; 834 snps,fixed-burst; 835 snps,no-pbl-x8; 836 snps,force_thresh_dma_mode; 837 snps,axi-config = <&stmmac_axi_setup>; 838 snps,tso; 839 snps,en-tx-lpi-clockgating; 840 snps,txpbl = <16>; 841 snps,rxpbl = <16>; 842 starfive,syscon = <&sys_syscon 0x90 0x2>; 843 status = "disabled"; 844 }; 845 846 aoncrg: clock-controller@17000000 { 847 compatible = "starfive,jh7110-aoncrg"; 848 reg = <0x0 0x17000000 0x0 0x10000>; 849 clocks = <&osc>, <&gmac0_rmii_refin>, 850 <&gmac0_rgmii_rxin>, 851 <&syscrg JH7110_SYSCLK_STG_AXIAHB>, 852 <&syscrg JH7110_SYSCLK_APB_BUS>, 853 <&syscrg JH7110_SYSCLK_GMAC0_GTXCLK>, 854 <&rtc_osc>; 855 clock-names = "osc", "gmac0_rmii_refin", 856 "gmac0_rgmii_rxin", "stg_axiahb", 857 "apb_bus", "gmac0_gtxclk", 858 "rtc_osc"; 859 #clock-cells = <1>; 860 #reset-cells = <1>; 861 }; 862 863 aon_syscon: syscon@17010000 { 864 compatible = "starfive,jh7110-aon-syscon", "syscon"; 865 reg = <0x0 0x17010000 0x0 0x1000>; 866 #power-domain-cells = <1>; 867 }; 868 869 aongpio: pinctrl@17020000 { 870 compatible = "starfive,jh7110-aon-pinctrl"; 871 reg = <0x0 0x17020000 0x0 0x10000>; 872 resets = <&aoncrg JH7110_AONRST_IOMUX>; 873 interrupts = <85>; 874 interrupt-controller; 875 #interrupt-cells = <2>; 876 gpio-controller; 877 #gpio-cells = <2>; 878 }; 879 880 pwrc: power-controller@17030000 { 881 compatible = "starfive,jh7110-pmu"; 882 reg = <0x0 0x17030000 0x0 0x10000>; 883 interrupts = <111>; 884 #power-domain-cells = <1>; 885 }; 886 887 ispcrg: clock-controller@19810000 { 888 compatible = "starfive,jh7110-ispcrg"; 889 reg = <0x0 0x19810000 0x0 0x10000>; 890 clocks = <&syscrg JH7110_SYSCLK_ISP_TOP_CORE>, 891 <&syscrg JH7110_SYSCLK_ISP_TOP_AXI>, 892 <&syscrg JH7110_SYSCLK_NOC_BUS_ISP_AXI>, 893 <&dvp_clk>; 894 clock-names = "isp_top_core", "isp_top_axi", 895 "noc_bus_isp_axi", "dvp_clk"; 896 resets = <&syscrg JH7110_SYSRST_ISP_TOP>, 897 <&syscrg JH7110_SYSRST_ISP_TOP_AXI>, 898 <&syscrg JH7110_SYSRST_NOC_BUS_ISP_AXI>; 899 #clock-cells = <1>; 900 #reset-cells = <1>; 901 power-domains = <&pwrc JH7110_PD_ISP>; 902 }; 903 904 voutcrg: clock-controller@295c0000 { 905 compatible = "starfive,jh7110-voutcrg"; 906 reg = <0x0 0x295c0000 0x0 0x10000>; 907 clocks = <&syscrg JH7110_SYSCLK_VOUT_SRC>, 908 <&syscrg JH7110_SYSCLK_VOUT_TOP_AHB>, 909 <&syscrg JH7110_SYSCLK_VOUT_TOP_AXI>, 910 <&syscrg JH7110_SYSCLK_VOUT_TOP_HDMITX0_MCLK>, 911 <&syscrg JH7110_SYSCLK_I2STX0_BCLK>, 912 <&hdmitx0_pixelclk>; 913 clock-names = "vout_src", "vout_top_ahb", 914 "vout_top_axi", "vout_top_hdmitx0_mclk", 915 "i2stx0_bclk", "hdmitx0_pixelclk"; 916 resets = <&syscrg JH7110_SYSRST_VOUT_TOP_SRC>; 917 #clock-cells = <1>; 918 #reset-cells = <1>; 919 power-domains = <&pwrc JH7110_PD_VOUT>; 920 }; 921 }; 922}; 923