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