1 // SPDX-License-Identifier: (GPL-2.0+ OR MIT) 2 /* 3 * Copyright (c) 2017 Amlogic, Inc. All rights reserved. 4 */ 5 6 #include <dt-bindings/clock/axg-aoclkc.h> 7 #include <dt-bindings/clock/axg-audio-clkc.h> 8 #include <dt-bindings/clock/axg-clkc.h> 9 #include <dt-bindings/gpio/gpio.h> 10 #include <dt-bindings/gpio/meson-axg-gpio.h> 11 #include <dt-bindings/interrupt-controller/irq.h> 12 #include <dt-bindings/interrupt-controller/arm-gic.h> 13 #include <dt-bindings/reset/amlogic,meson-axg-audio-arb.h> 14 #include <dt-bindings/reset/amlogic,meson-axg-reset.h> 15 #include <dt-bindings/power/meson-axg-power.h> 16 17 / { 18 compatible = "amlogic,meson-axg"; 19 20 interrupt-parent = <&gic>; 21 #address-cells = <2>; 22 #size-cells = <2>; 23 24 tdmif_a: audio-controller-0 { 25 compatible = "amlogic,axg-tdm-iface"; 26 #sound-dai-cells = <0>; 27 sound-name-prefix = "TDM_A"; 28 clocks = <&clkc_audio AUD_CLKID_MST_A_SCLK>, 29 <&clkc_audio AUD_CLKID_MST_A_LRCLK>, 30 <&clkc_audio AUD_CLKID_MST_A_MCLK>; 31 clock-names = "sclk", "lrclk", "mclk"; 32 status = "disabled"; 33 }; 34 35 tdmif_b: audio-controller-1 { 36 compatible = "amlogic,axg-tdm-iface"; 37 #sound-dai-cells = <0>; 38 sound-name-prefix = "TDM_B"; 39 clocks = <&clkc_audio AUD_CLKID_MST_B_SCLK>, 40 <&clkc_audio AUD_CLKID_MST_B_LRCLK>, 41 <&clkc_audio AUD_CLKID_MST_B_MCLK>; 42 clock-names = "sclk", "lrclk", "mclk"; 43 status = "disabled"; 44 }; 45 46 tdmif_c: audio-controller-2 { 47 compatible = "amlogic,axg-tdm-iface"; 48 #sound-dai-cells = <0>; 49 sound-name-prefix = "TDM_C"; 50 clocks = <&clkc_audio AUD_CLKID_MST_C_SCLK>, 51 <&clkc_audio AUD_CLKID_MST_C_LRCLK>, 52 <&clkc_audio AUD_CLKID_MST_C_MCLK>; 53 clock-names = "sclk", "lrclk", "mclk"; 54 status = "disabled"; 55 }; 56 57 arm-pmu { 58 compatible = "arm,cortex-a53-pmu"; 59 interrupts = <GIC_SPI 137 IRQ_TYPE_LEVEL_HIGH>, 60 <GIC_SPI 138 IRQ_TYPE_LEVEL_HIGH>, 61 <GIC_SPI 153 IRQ_TYPE_LEVEL_HIGH>, 62 <GIC_SPI 154 IRQ_TYPE_LEVEL_HIGH>; 63 interrupt-affinity = <&cpu0>, <&cpu1>, <&cpu2>, <&cpu3>; 64 }; 65 66 cpus { 67 #address-cells = <0x2>; 68 #size-cells = <0x0>; 69 70 cpu0: cpu@0 { 71 device_type = "cpu"; 72 compatible = "arm,cortex-a53"; 73 reg = <0x0 0x0>; 74 enable-method = "psci"; 75 next-level-cache = <&l2>; 76 clocks = <&scpi_dvfs 0>; 77 dynamic-power-coefficient = <140>; 78 #cooling-cells = <2>; 79 }; 80 81 cpu1: cpu@1 { 82 device_type = "cpu"; 83 compatible = "arm,cortex-a53"; 84 reg = <0x0 0x1>; 85 enable-method = "psci"; 86 next-level-cache = <&l2>; 87 clocks = <&scpi_dvfs 0>; 88 dynamic-power-coefficient = <140>; 89 #cooling-cells = <2>; 90 }; 91 92 cpu2: cpu@2 { 93 device_type = "cpu"; 94 compatible = "arm,cortex-a53"; 95 reg = <0x0 0x2>; 96 enable-method = "psci"; 97 next-level-cache = <&l2>; 98 clocks = <&scpi_dvfs 0>; 99 dynamic-power-coefficient = <140>; 100 #cooling-cells = <2>; 101 }; 102 103 cpu3: cpu@3 { 104 device_type = "cpu"; 105 compatible = "arm,cortex-a53"; 106 reg = <0x0 0x3>; 107 enable-method = "psci"; 108 next-level-cache = <&l2>; 109 clocks = <&scpi_dvfs 0>; 110 dynamic-power-coefficient = <140>; 111 #cooling-cells = <2>; 112 }; 113 114 l2: l2-cache0 { 115 compatible = "cache"; 116 cache-level = <2>; 117 cache-unified; 118 }; 119 }; 120 121 sm: secure-monitor { 122 compatible = "amlogic,meson-gxbb-sm"; 123 }; 124 125 efuse: efuse { 126 compatible = "amlogic,meson-gxbb-efuse"; 127 clocks = <&clkc CLKID_EFUSE>; 128 #address-cells = <1>; 129 #size-cells = <1>; 130 read-only; 131 secure-monitor = <&sm>; 132 }; 133 134 psci { 135 compatible = "arm,psci-1.0"; 136 method = "smc"; 137 }; 138 139 reserved-memory { 140 #address-cells = <2>; 141 #size-cells = <2>; 142 ranges; 143 144 /* 16 MiB reserved for Hardware ROM Firmware */ 145 hwrom_reserved: hwrom@0 { 146 reg = <0x0 0x0 0x0 0x1000000>; 147 no-map; 148 }; 149 150 /* Alternate 3 MiB reserved for ARM Trusted Firmware (BL31) */ 151 secmon_reserved: secmon@5000000 { 152 reg = <0x0 0x05000000 0x0 0x300000>; 153 no-map; 154 }; 155 }; 156 157 scpi { 158 compatible = "arm,scpi-pre-1.0"; 159 mboxes = <&mailbox 1 &mailbox 2>; 160 shmem = <&cpu_scp_lpri &cpu_scp_hpri>; 161 162 scpi_clocks: clocks { 163 compatible = "arm,scpi-clocks"; 164 165 scpi_dvfs: clocks-0 { 166 compatible = "arm,scpi-dvfs-clocks"; 167 #clock-cells = <1>; 168 clock-indices = <0>; 169 clock-output-names = "vcpu"; 170 }; 171 }; 172 173 scpi_sensors: sensors { 174 compatible = "amlogic,meson-gxbb-scpi-sensors", "arm,scpi-sensors"; 175 #thermal-sensor-cells = <1>; 176 }; 177 }; 178 179 soc { 180 compatible = "simple-bus"; 181 #address-cells = <2>; 182 #size-cells = <2>; 183 ranges; 184 185 pcieA: pcie@f9800000 { 186 compatible = "amlogic,axg-pcie", "snps,dw-pcie"; 187 reg = <0x0 0xf9800000 0x0 0x400000>, 188 <0x0 0xff646000 0x0 0x2000>, 189 <0x0 0xf9f00000 0x0 0x100000>; 190 reg-names = "elbi", "cfg", "config"; 191 interrupts = <GIC_SPI 177 IRQ_TYPE_EDGE_RISING>; 192 #interrupt-cells = <1>; 193 interrupt-map-mask = <0 0 0 0>; 194 interrupt-map = <0 0 0 0 &gic GIC_SPI 179 IRQ_TYPE_EDGE_RISING>; 195 bus-range = <0x0 0xff>; 196 #address-cells = <3>; 197 #size-cells = <2>; 198 device_type = "pci"; 199 ranges = <0x82000000 0 0xf9c00000 0x0 0xf9c00000 0 0x00300000>; 200 201 clocks = <&clkc CLKID_USB>, <&clkc CLKID_PCIE_A>, <&clkc CLKID_PCIE_CML_EN0>; 202 clock-names = "general", "pclk", "port"; 203 resets = <&reset RESET_PCIE_A>, <&reset RESET_PCIE_APB>; 204 reset-names = "port", "apb"; 205 num-lanes = <1>; 206 phys = <&pcie_phy>; 207 phy-names = "pcie"; 208 status = "disabled"; 209 }; 210 211 pcieB: pcie@fa000000 { 212 compatible = "amlogic,axg-pcie", "snps,dw-pcie"; 213 reg = <0x0 0xfa000000 0x0 0x400000>, 214 <0x0 0xff648000 0x0 0x2000>, 215 <0x0 0xfa400000 0x0 0x100000>; 216 reg-names = "elbi", "cfg", "config"; 217 interrupts = <GIC_SPI 167 IRQ_TYPE_EDGE_RISING>; 218 #interrupt-cells = <1>; 219 interrupt-map-mask = <0 0 0 0>; 220 interrupt-map = <0 0 0 0 &gic GIC_SPI 169 IRQ_TYPE_EDGE_RISING>; 221 bus-range = <0x0 0xff>; 222 #address-cells = <3>; 223 #size-cells = <2>; 224 device_type = "pci"; 225 ranges = <0x82000000 0 0xfa500000 0x0 0xfa500000 0 0x00300000>; 226 227 clocks = <&clkc CLKID_USB>, <&clkc CLKID_PCIE_B>, <&clkc CLKID_PCIE_CML_EN1>; 228 clock-names = "general", "pclk", "port"; 229 resets = <&reset RESET_PCIE_B>, <&reset RESET_PCIE_APB>; 230 reset-names = "port", "apb"; 231 num-lanes = <1>; 232 phys = <&pcie_phy>; 233 phy-names = "pcie"; 234 status = "disabled"; 235 }; 236 237 usb: usb@ffe09080 { 238 compatible = "amlogic,meson-axg-usb-ctrl"; 239 reg = <0x0 0xffe09080 0x0 0x20>; 240 interrupts = <GIC_SPI 16 IRQ_TYPE_LEVEL_HIGH>; 241 #address-cells = <2>; 242 #size-cells = <2>; 243 ranges; 244 245 clocks = <&clkc CLKID_USB>, <&clkc CLKID_USB1_DDR_BRIDGE>; 246 clock-names = "usb_ctrl", "ddr"; 247 resets = <&reset RESET_USB_OTG>; 248 249 dr_mode = "otg"; 250 251 phys = <&usb2_phy1>; 252 phy-names = "usb2-phy1"; 253 254 dwc2: usb@ff400000 { 255 compatible = "amlogic,meson-g12a-usb", "snps,dwc2"; 256 reg = <0x0 0xff400000 0x0 0x40000>; 257 interrupts = <GIC_SPI 31 IRQ_TYPE_LEVEL_HIGH>; 258 clocks = <&clkc CLKID_USB1>; 259 clock-names = "otg"; 260 phys = <&usb2_phy1>; 261 dr_mode = "peripheral"; 262 g-rx-fifo-size = <192>; 263 g-np-tx-fifo-size = <128>; 264 g-tx-fifo-size = <128 128 16 16 16>; 265 }; 266 267 dwc3: usb@ff500000 { 268 compatible = "snps,dwc3"; 269 reg = <0x0 0xff500000 0x0 0x100000>; 270 interrupts = <GIC_SPI 30 IRQ_TYPE_LEVEL_HIGH>; 271 dr_mode = "host"; 272 maximum-speed = "high-speed"; 273 snps,dis_u2_susphy_quirk; 274 }; 275 }; 276 277 ethmac: ethernet@ff3f0000 { 278 compatible = "amlogic,meson-axg-dwmac", 279 "snps,dwmac-3.70a", 280 "snps,dwmac"; 281 reg = <0x0 0xff3f0000 0x0 0x10000>, 282 <0x0 0xff634540 0x0 0x8>; 283 interrupts = <GIC_SPI 8 IRQ_TYPE_LEVEL_HIGH>; 284 interrupt-names = "macirq"; 285 clocks = <&clkc CLKID_ETH>, 286 <&clkc CLKID_FCLK_DIV2>, 287 <&clkc CLKID_MPLL2>, 288 <&clkc CLKID_FCLK_DIV2>; 289 clock-names = "stmmaceth", "clkin0", "clkin1", 290 "timing-adjustment"; 291 rx-fifo-depth = <4096>; 292 tx-fifo-depth = <2048>; 293 power-domains = <&pwrc PWRC_AXG_ETHERNET_MEM_ID>; 294 status = "disabled"; 295 }; 296 297 pcie_phy: phy@ff644000 { 298 compatible = "amlogic,axg-pcie-phy"; 299 reg = <0x0 0xff644000 0x0 0x1c>; 300 resets = <&reset RESET_PCIE_PHY>; 301 phys = <&mipi_pcie_analog_dphy>; 302 phy-names = "analog"; 303 #phy-cells = <0>; 304 }; 305 306 pdm: audio-controller@ff632000 { 307 compatible = "amlogic,axg-pdm"; 308 reg = <0x0 0xff632000 0x0 0x34>; 309 #sound-dai-cells = <0>; 310 sound-name-prefix = "PDM"; 311 clocks = <&clkc_audio AUD_CLKID_PDM>, 312 <&clkc_audio AUD_CLKID_PDM_DCLK>, 313 <&clkc_audio AUD_CLKID_PDM_SYSCLK>; 314 clock-names = "pclk", "dclk", "sysclk"; 315 status = "disabled"; 316 }; 317 318 periphs: bus@ff634000 { 319 compatible = "simple-bus"; 320 reg = <0x0 0xff634000 0x0 0x2000>; 321 #address-cells = <2>; 322 #size-cells = <2>; 323 ranges = <0x0 0x0 0x0 0xff634000 0x0 0x2000>; 324 325 hwrng: rng@18 { 326 compatible = "amlogic,meson-rng"; 327 reg = <0x0 0x18 0x0 0x4>; 328 clocks = <&clkc CLKID_RNG0>; 329 clock-names = "core"; 330 }; 331 332 pinctrl_periphs: pinctrl@480 { 333 compatible = "amlogic,meson-axg-periphs-pinctrl"; 334 #address-cells = <2>; 335 #size-cells = <2>; 336 ranges; 337 338 gpio: bank@480 { 339 reg = <0x0 0x00480 0x0 0x40>, 340 <0x0 0x004e8 0x0 0x14>, 341 <0x0 0x00520 0x0 0x14>, 342 <0x0 0x00430 0x0 0x3c>; 343 reg-names = "mux", "pull", "pull-enable", "gpio"; 344 gpio-controller; 345 #gpio-cells = <2>; 346 gpio-ranges = <&pinctrl_periphs 0 0 86>; 347 }; 348 349 i2c0_pins: i2c0 { 350 mux { 351 groups = "i2c0_sck", 352 "i2c0_sda"; 353 function = "i2c0"; 354 bias-disable; 355 }; 356 }; 357 358 i2c1_x_pins: i2c1_x { 359 mux { 360 groups = "i2c1_sck_x", 361 "i2c1_sda_x"; 362 function = "i2c1"; 363 bias-disable; 364 }; 365 }; 366 367 i2c1_z_pins: i2c1_z { 368 mux { 369 groups = "i2c1_sck_z", 370 "i2c1_sda_z"; 371 function = "i2c1"; 372 bias-disable; 373 }; 374 }; 375 376 i2c2_a_pins: i2c2_a { 377 mux { 378 groups = "i2c2_sck_a", 379 "i2c2_sda_a"; 380 function = "i2c2"; 381 bias-disable; 382 }; 383 }; 384 385 i2c2_x_pins: i2c2_x { 386 mux { 387 groups = "i2c2_sck_x", 388 "i2c2_sda_x"; 389 function = "i2c2"; 390 bias-disable; 391 }; 392 }; 393 394 i2c3_a6_pins: i2c3_a6 { 395 mux { 396 groups = "i2c3_sda_a6", 397 "i2c3_sck_a7"; 398 function = "i2c3"; 399 bias-disable; 400 }; 401 }; 402 403 i2c3_a12_pins: i2c3_a12 { 404 mux { 405 groups = "i2c3_sda_a12", 406 "i2c3_sck_a13"; 407 function = "i2c3"; 408 bias-disable; 409 }; 410 }; 411 412 i2c3_a19_pins: i2c3_a19 { 413 mux { 414 groups = "i2c3_sda_a19", 415 "i2c3_sck_a20"; 416 function = "i2c3"; 417 bias-disable; 418 }; 419 }; 420 421 emmc_pins: emmc { 422 mux-0 { 423 groups = "emmc_nand_d0", 424 "emmc_nand_d1", 425 "emmc_nand_d2", 426 "emmc_nand_d3", 427 "emmc_nand_d4", 428 "emmc_nand_d5", 429 "emmc_nand_d6", 430 "emmc_nand_d7", 431 "emmc_cmd"; 432 function = "emmc"; 433 bias-pull-up; 434 }; 435 436 mux-1 { 437 groups = "emmc_clk"; 438 function = "emmc"; 439 bias-disable; 440 }; 441 }; 442 443 nand_all_pins: nand-all-pins { 444 mux { 445 groups = "emmc_nand_d0", 446 "emmc_nand_d1", 447 "emmc_nand_d2", 448 "emmc_nand_d3", 449 "emmc_nand_d4", 450 "emmc_nand_d5", 451 "emmc_nand_d6", 452 "emmc_nand_d7", 453 "nand_ce0", 454 "nand_ale", 455 "nand_cle", 456 "nand_wen_clk", 457 "nand_ren_wr"; 458 function = "nand"; 459 input-enable; 460 bias-pull-up; 461 }; 462 }; 463 464 emmc_ds_pins: emmc_ds { 465 mux { 466 groups = "emmc_ds"; 467 function = "emmc"; 468 bias-pull-down; 469 }; 470 }; 471 472 emmc_clk_gate_pins: emmc_clk_gate { 473 mux { 474 groups = "BOOT_8"; 475 function = "gpio_periphs"; 476 bias-pull-down; 477 }; 478 }; 479 480 eth_rgmii_x_pins: eth-x-rgmii { 481 mux { 482 groups = "eth_mdio_x", 483 "eth_mdc_x", 484 "eth_rgmii_rx_clk_x", 485 "eth_rx_dv_x", 486 "eth_rxd0_x", 487 "eth_rxd1_x", 488 "eth_rxd2_rgmii", 489 "eth_rxd3_rgmii", 490 "eth_rgmii_tx_clk", 491 "eth_txen_x", 492 "eth_txd0_x", 493 "eth_txd1_x", 494 "eth_txd2_rgmii", 495 "eth_txd3_rgmii"; 496 function = "eth"; 497 bias-disable; 498 }; 499 }; 500 501 eth_rgmii_y_pins: eth-y-rgmii { 502 mux { 503 groups = "eth_mdio_y", 504 "eth_mdc_y", 505 "eth_rgmii_rx_clk_y", 506 "eth_rx_dv_y", 507 "eth_rxd0_y", 508 "eth_rxd1_y", 509 "eth_rxd2_rgmii", 510 "eth_rxd3_rgmii", 511 "eth_rgmii_tx_clk", 512 "eth_txen_y", 513 "eth_txd0_y", 514 "eth_txd1_y", 515 "eth_txd2_rgmii", 516 "eth_txd3_rgmii"; 517 function = "eth"; 518 bias-disable; 519 }; 520 }; 521 522 eth_rmii_x_pins: eth-x-rmii { 523 mux { 524 groups = "eth_mdio_x", 525 "eth_mdc_x", 526 "eth_rgmii_rx_clk_x", 527 "eth_rx_dv_x", 528 "eth_rxd0_x", 529 "eth_rxd1_x", 530 "eth_txen_x", 531 "eth_txd0_x", 532 "eth_txd1_x"; 533 function = "eth"; 534 bias-disable; 535 }; 536 }; 537 538 eth_rmii_y_pins: eth-y-rmii { 539 mux { 540 groups = "eth_mdio_y", 541 "eth_mdc_y", 542 "eth_rgmii_rx_clk_y", 543 "eth_rx_dv_y", 544 "eth_rxd0_y", 545 "eth_rxd1_y", 546 "eth_txen_y", 547 "eth_txd0_y", 548 "eth_txd1_y"; 549 function = "eth"; 550 bias-disable; 551 }; 552 }; 553 554 mclk_b_pins: mclk_b { 555 mux { 556 groups = "mclk_b"; 557 function = "mclk_b"; 558 bias-disable; 559 }; 560 }; 561 562 mclk_c_pins: mclk_c { 563 mux { 564 groups = "mclk_c"; 565 function = "mclk_c"; 566 bias-disable; 567 }; 568 }; 569 570 pdm_dclk_a14_pins: pdm_dclk_a14 { 571 mux { 572 groups = "pdm_dclk_a14"; 573 function = "pdm"; 574 bias-disable; 575 }; 576 }; 577 578 pdm_dclk_a19_pins: pdm_dclk_a19 { 579 mux { 580 groups = "pdm_dclk_a19"; 581 function = "pdm"; 582 bias-disable; 583 }; 584 }; 585 586 pdm_din0_pins: pdm_din0 { 587 mux { 588 groups = "pdm_din0"; 589 function = "pdm"; 590 bias-disable; 591 }; 592 }; 593 594 pdm_din1_pins: pdm_din1 { 595 mux { 596 groups = "pdm_din1"; 597 function = "pdm"; 598 bias-disable; 599 }; 600 }; 601 602 pdm_din2_pins: pdm_din2 { 603 mux { 604 groups = "pdm_din2"; 605 function = "pdm"; 606 bias-disable; 607 }; 608 }; 609 610 pdm_din3_pins: pdm_din3 { 611 mux { 612 groups = "pdm_din3"; 613 function = "pdm"; 614 bias-disable; 615 }; 616 }; 617 618 pwm_a_a_pins: pwm_a_a { 619 mux { 620 groups = "pwm_a_a"; 621 function = "pwm_a"; 622 bias-disable; 623 }; 624 }; 625 626 pwm_a_x18_pins: pwm_a_x18 { 627 mux { 628 groups = "pwm_a_x18"; 629 function = "pwm_a"; 630 bias-disable; 631 }; 632 }; 633 634 pwm_a_x20_pins: pwm_a_x20 { 635 mux { 636 groups = "pwm_a_x20"; 637 function = "pwm_a"; 638 bias-disable; 639 }; 640 }; 641 642 pwm_a_z_pins: pwm_a_z { 643 mux { 644 groups = "pwm_a_z"; 645 function = "pwm_a"; 646 bias-disable; 647 }; 648 }; 649 650 pwm_b_a_pins: pwm_b_a { 651 mux { 652 groups = "pwm_b_a"; 653 function = "pwm_b"; 654 bias-disable; 655 }; 656 }; 657 658 pwm_b_x_pins: pwm_b_x { 659 mux { 660 groups = "pwm_b_x"; 661 function = "pwm_b"; 662 bias-disable; 663 }; 664 }; 665 666 pwm_b_z_pins: pwm_b_z { 667 mux { 668 groups = "pwm_b_z"; 669 function = "pwm_b"; 670 bias-disable; 671 }; 672 }; 673 674 pwm_c_a_pins: pwm_c_a { 675 mux { 676 groups = "pwm_c_a"; 677 function = "pwm_c"; 678 bias-disable; 679 }; 680 }; 681 682 pwm_c_x10_pins: pwm_c_x10 { 683 mux { 684 groups = "pwm_c_x10"; 685 function = "pwm_c"; 686 bias-disable; 687 }; 688 }; 689 690 pwm_c_x17_pins: pwm_c_x17 { 691 mux { 692 groups = "pwm_c_x17"; 693 function = "pwm_c"; 694 bias-disable; 695 }; 696 }; 697 698 pwm_d_x11_pins: pwm_d_x11 { 699 mux { 700 groups = "pwm_d_x11"; 701 function = "pwm_d"; 702 bias-disable; 703 }; 704 }; 705 706 pwm_d_x16_pins: pwm_d_x16 { 707 mux { 708 groups = "pwm_d_x16"; 709 function = "pwm_d"; 710 bias-disable; 711 }; 712 }; 713 714 sdio_pins: sdio { 715 mux-0 { 716 groups = "sdio_d0", 717 "sdio_d1", 718 "sdio_d2", 719 "sdio_d3", 720 "sdio_cmd"; 721 function = "sdio"; 722 bias-pull-up; 723 }; 724 725 mux-1 { 726 groups = "sdio_clk"; 727 function = "sdio"; 728 bias-disable; 729 }; 730 }; 731 732 sdio_clk_gate_pins: sdio_clk_gate { 733 mux { 734 groups = "GPIOX_4"; 735 function = "gpio_periphs"; 736 bias-pull-down; 737 }; 738 }; 739 740 spdif_in_z_pins: spdif_in_z { 741 mux { 742 groups = "spdif_in_z"; 743 function = "spdif_in"; 744 bias-disable; 745 }; 746 }; 747 748 spdif_in_a1_pins: spdif_in_a1 { 749 mux { 750 groups = "spdif_in_a1"; 751 function = "spdif_in"; 752 bias-disable; 753 }; 754 }; 755 756 spdif_in_a7_pins: spdif_in_a7 { 757 mux { 758 groups = "spdif_in_a7"; 759 function = "spdif_in"; 760 bias-disable; 761 }; 762 }; 763 764 spdif_in_a19_pins: spdif_in_a19 { 765 mux { 766 groups = "spdif_in_a19"; 767 function = "spdif_in"; 768 bias-disable; 769 }; 770 }; 771 772 spdif_in_a20_pins: spdif_in_a20 { 773 mux { 774 groups = "spdif_in_a20"; 775 function = "spdif_in"; 776 bias-disable; 777 }; 778 }; 779 780 spdif_out_a1_pins: spdif_out_a1 { 781 mux { 782 groups = "spdif_out_a1"; 783 function = "spdif_out"; 784 bias-disable; 785 }; 786 }; 787 788 spdif_out_a11_pins: spdif_out_a11 { 789 mux { 790 groups = "spdif_out_a11"; 791 function = "spdif_out"; 792 bias-disable; 793 }; 794 }; 795 796 spdif_out_a19_pins: spdif_out_a19 { 797 mux { 798 groups = "spdif_out_a19"; 799 function = "spdif_out"; 800 bias-disable; 801 }; 802 }; 803 804 spdif_out_a20_pins: spdif_out_a20 { 805 mux { 806 groups = "spdif_out_a20"; 807 function = "spdif_out"; 808 bias-disable; 809 }; 810 }; 811 812 spdif_out_z_pins: spdif_out_z { 813 mux { 814 groups = "spdif_out_z"; 815 function = "spdif_out"; 816 bias-disable; 817 }; 818 }; 819 820 spi0_pins: spi0 { 821 mux { 822 groups = "spi0_miso", 823 "spi0_mosi", 824 "spi0_clk"; 825 function = "spi0"; 826 bias-disable; 827 }; 828 }; 829 830 spi0_ss0_pins: spi0_ss0 { 831 mux { 832 groups = "spi0_ss0"; 833 function = "spi0"; 834 bias-disable; 835 }; 836 }; 837 838 spi0_ss1_pins: spi0_ss1 { 839 mux { 840 groups = "spi0_ss1"; 841 function = "spi0"; 842 bias-disable; 843 }; 844 }; 845 846 spi0_ss2_pins: spi0_ss2 { 847 mux { 848 groups = "spi0_ss2"; 849 function = "spi0"; 850 bias-disable; 851 }; 852 }; 853 854 spi1_a_pins: spi1_a { 855 mux { 856 groups = "spi1_miso_a", 857 "spi1_mosi_a", 858 "spi1_clk_a"; 859 function = "spi1"; 860 bias-disable; 861 }; 862 }; 863 864 spi1_ss0_a_pins: spi1_ss0_a { 865 mux { 866 groups = "spi1_ss0_a"; 867 function = "spi1"; 868 bias-disable; 869 }; 870 }; 871 872 spi1_ss1_pins: spi1_ss1 { 873 mux { 874 groups = "spi1_ss1"; 875 function = "spi1"; 876 bias-disable; 877 }; 878 }; 879 880 spi1_x_pins: spi1_x { 881 mux { 882 groups = "spi1_miso_x", 883 "spi1_mosi_x", 884 "spi1_clk_x"; 885 function = "spi1"; 886 bias-disable; 887 }; 888 }; 889 890 spi1_ss0_x_pins: spi1_ss0_x { 891 mux { 892 groups = "spi1_ss0_x"; 893 function = "spi1"; 894 bias-disable; 895 }; 896 }; 897 898 tdma_din0_pins: tdma_din0 { 899 mux { 900 groups = "tdma_din0"; 901 function = "tdma"; 902 bias-disable; 903 }; 904 }; 905 906 tdma_dout0_x14_pins: tdma_dout0_x14 { 907 mux { 908 groups = "tdma_dout0_x14"; 909 function = "tdma"; 910 bias-disable; 911 }; 912 }; 913 914 tdma_dout0_x15_pins: tdma_dout0_x15 { 915 mux { 916 groups = "tdma_dout0_x15"; 917 function = "tdma"; 918 bias-disable; 919 }; 920 }; 921 922 tdma_dout1_pins: tdma_dout1 { 923 mux { 924 groups = "tdma_dout1"; 925 function = "tdma"; 926 bias-disable; 927 }; 928 }; 929 930 tdma_din1_pins: tdma_din1 { 931 mux { 932 groups = "tdma_din1"; 933 function = "tdma"; 934 bias-disable; 935 }; 936 }; 937 938 tdma_fs_pins: tdma_fs { 939 mux { 940 groups = "tdma_fs"; 941 function = "tdma"; 942 bias-disable; 943 }; 944 }; 945 946 tdma_fs_slv_pins: tdma_fs_slv { 947 mux { 948 groups = "tdma_fs_slv"; 949 function = "tdma"; 950 bias-disable; 951 }; 952 }; 953 954 tdma_sclk_pins: tdma_sclk { 955 mux { 956 groups = "tdma_sclk"; 957 function = "tdma"; 958 bias-disable; 959 }; 960 }; 961 962 tdma_sclk_slv_pins: tdma_sclk_slv { 963 mux { 964 groups = "tdma_sclk_slv"; 965 function = "tdma"; 966 bias-disable; 967 }; 968 }; 969 970 tdmb_din0_pins: tdmb_din0 { 971 mux { 972 groups = "tdmb_din0"; 973 function = "tdmb"; 974 bias-disable; 975 }; 976 }; 977 978 tdmb_din1_pins: tdmb_din1 { 979 mux { 980 groups = "tdmb_din1"; 981 function = "tdmb"; 982 bias-disable; 983 }; 984 }; 985 986 tdmb_din2_pins: tdmb_din2 { 987 mux { 988 groups = "tdmb_din2"; 989 function = "tdmb"; 990 bias-disable; 991 }; 992 }; 993 994 tdmb_din3_pins: tdmb_din3 { 995 mux { 996 groups = "tdmb_din3"; 997 function = "tdmb"; 998 bias-disable; 999 }; 1000 }; 1001 1002 tdmb_dout0_pins: tdmb_dout0 { 1003 mux { 1004 groups = "tdmb_dout0"; 1005 function = "tdmb"; 1006 bias-disable; 1007 }; 1008 }; 1009 1010 tdmb_dout1_pins: tdmb_dout1 { 1011 mux { 1012 groups = "tdmb_dout1"; 1013 function = "tdmb"; 1014 bias-disable; 1015 }; 1016 }; 1017 1018 tdmb_dout2_pins: tdmb_dout2 { 1019 mux { 1020 groups = "tdmb_dout2"; 1021 function = "tdmb"; 1022 bias-disable; 1023 }; 1024 }; 1025 1026 tdmb_dout3_pins: tdmb_dout3 { 1027 mux { 1028 groups = "tdmb_dout3"; 1029 function = "tdmb"; 1030 bias-disable; 1031 }; 1032 }; 1033 1034 tdmb_fs_pins: tdmb_fs { 1035 mux { 1036 groups = "tdmb_fs"; 1037 function = "tdmb"; 1038 bias-disable; 1039 }; 1040 }; 1041 1042 tdmb_fs_slv_pins: tdmb_fs_slv { 1043 mux { 1044 groups = "tdmb_fs_slv"; 1045 function = "tdmb"; 1046 bias-disable; 1047 }; 1048 }; 1049 1050 tdmb_sclk_pins: tdmb_sclk { 1051 mux { 1052 groups = "tdmb_sclk"; 1053 function = "tdmb"; 1054 bias-disable; 1055 }; 1056 }; 1057 1058 tdmb_sclk_slv_pins: tdmb_sclk_slv { 1059 mux { 1060 groups = "tdmb_sclk_slv"; 1061 function = "tdmb"; 1062 bias-disable; 1063 }; 1064 }; 1065 1066 tdmc_fs_pins: tdmc_fs { 1067 mux { 1068 groups = "tdmc_fs"; 1069 function = "tdmc"; 1070 bias-disable; 1071 }; 1072 }; 1073 1074 tdmc_fs_slv_pins: tdmc_fs_slv { 1075 mux { 1076 groups = "tdmc_fs_slv"; 1077 function = "tdmc"; 1078 bias-disable; 1079 }; 1080 }; 1081 1082 tdmc_sclk_pins: tdmc_sclk { 1083 mux { 1084 groups = "tdmc_sclk"; 1085 function = "tdmc"; 1086 bias-disable; 1087 }; 1088 }; 1089 1090 tdmc_sclk_slv_pins: tdmc_sclk_slv { 1091 mux { 1092 groups = "tdmc_sclk_slv"; 1093 function = "tdmc"; 1094 bias-disable; 1095 }; 1096 }; 1097 1098 tdmc_din0_pins: tdmc_din0 { 1099 mux { 1100 groups = "tdmc_din0"; 1101 function = "tdmc"; 1102 bias-disable; 1103 }; 1104 }; 1105 1106 tdmc_din1_pins: tdmc_din1 { 1107 mux { 1108 groups = "tdmc_din1"; 1109 function = "tdmc"; 1110 bias-disable; 1111 }; 1112 }; 1113 1114 tdmc_din2_pins: tdmc_din2 { 1115 mux { 1116 groups = "tdmc_din2"; 1117 function = "tdmc"; 1118 bias-disable; 1119 }; 1120 }; 1121 1122 tdmc_din3_pins: tdmc_din3 { 1123 mux { 1124 groups = "tdmc_din3"; 1125 function = "tdmc"; 1126 bias-disable; 1127 }; 1128 }; 1129 1130 tdmc_dout0_pins: tdmc_dout0 { 1131 mux { 1132 groups = "tdmc_dout0"; 1133 function = "tdmc"; 1134 bias-disable; 1135 }; 1136 }; 1137 1138 tdmc_dout1_pins: tdmc_dout1 { 1139 mux { 1140 groups = "tdmc_dout1"; 1141 function = "tdmc"; 1142 bias-disable; 1143 }; 1144 }; 1145 1146 tdmc_dout2_pins: tdmc_dout2 { 1147 mux { 1148 groups = "tdmc_dout2"; 1149 function = "tdmc"; 1150 bias-disable; 1151 }; 1152 }; 1153 1154 tdmc_dout3_pins: tdmc_dout3 { 1155 mux { 1156 groups = "tdmc_dout3"; 1157 function = "tdmc"; 1158 bias-disable; 1159 }; 1160 }; 1161 1162 uart_a_pins: uart_a { 1163 mux { 1164 groups = "uart_tx_a", 1165 "uart_rx_a"; 1166 function = "uart_a"; 1167 bias-disable; 1168 }; 1169 }; 1170 1171 uart_a_cts_rts_pins: uart_a_cts_rts { 1172 mux { 1173 groups = "uart_cts_a", 1174 "uart_rts_a"; 1175 function = "uart_a"; 1176 bias-disable; 1177 }; 1178 }; 1179 1180 uart_b_x_pins: uart_b_x { 1181 mux { 1182 groups = "uart_tx_b_x", 1183 "uart_rx_b_x"; 1184 function = "uart_b"; 1185 bias-disable; 1186 }; 1187 }; 1188 1189 uart_b_x_cts_rts_pins: uart_b_x_cts_rts { 1190 mux { 1191 groups = "uart_cts_b_x", 1192 "uart_rts_b_x"; 1193 function = "uart_b"; 1194 bias-disable; 1195 }; 1196 }; 1197 1198 uart_b_z_pins: uart_b_z { 1199 mux { 1200 groups = "uart_tx_b_z", 1201 "uart_rx_b_z"; 1202 function = "uart_b"; 1203 bias-disable; 1204 }; 1205 }; 1206 1207 uart_b_z_cts_rts_pins: uart_b_z_cts_rts { 1208 mux { 1209 groups = "uart_cts_b_z", 1210 "uart_rts_b_z"; 1211 function = "uart_b"; 1212 bias-disable; 1213 }; 1214 }; 1215 1216 uart_ao_b_z_pins: uart_ao_b_z { 1217 mux { 1218 groups = "uart_ao_tx_b_z", 1219 "uart_ao_rx_b_z"; 1220 function = "uart_ao_b_z"; 1221 bias-disable; 1222 }; 1223 }; 1224 1225 uart_ao_b_z_cts_rts_pins: uart_ao_b_z_cts_rts { 1226 mux { 1227 groups = "uart_ao_cts_b_z", 1228 "uart_ao_rts_b_z"; 1229 function = "uart_ao_b_z"; 1230 bias-disable; 1231 }; 1232 }; 1233 }; 1234 }; 1235 1236 hiubus: bus@ff63c000 { 1237 compatible = "simple-bus"; 1238 reg = <0x0 0xff63c000 0x0 0x1c00>; 1239 #address-cells = <2>; 1240 #size-cells = <2>; 1241 ranges = <0x0 0x0 0x0 0xff63c000 0x0 0x1c00>; 1242 1243 sysctrl: system-controller@0 { 1244 compatible = "amlogic,meson-axg-hhi-sysctrl", 1245 "simple-mfd", "syscon"; 1246 reg = <0 0 0 0x400>; 1247 1248 clkc: clock-controller { 1249 compatible = "amlogic,axg-clkc"; 1250 #clock-cells = <1>; 1251 clocks = <&xtal>; 1252 clock-names = "xtal"; 1253 }; 1254 1255 pwrc: power-controller { 1256 compatible = "amlogic,meson-axg-pwrc"; 1257 #power-domain-cells = <1>; 1258 amlogic,ao-sysctrl = <&sysctrl_AO>; 1259 resets = <&reset RESET_VIU>, 1260 <&reset RESET_VENC>, 1261 <&reset RESET_VCBUS>, 1262 <&reset RESET_VENCL>, 1263 <&reset RESET_VID_LOCK>; 1264 reset-names = "viu", "venc", "vcbus", 1265 "vencl", "vid_lock"; 1266 clocks = <&clkc CLKID_VPU>, 1267 <&clkc CLKID_VAPB>; 1268 clock-names = "vpu", "vapb"; 1269 /* 1270 * VPU clocking is provided by two identical clock paths 1271 * VPU_0 and VPU_1 muxed to a single clock by a glitch 1272 * free mux to safely change frequency while running. 1273 * Same for VAPB but with a final gate after the glitch free mux. 1274 */ 1275 assigned-clocks = <&clkc CLKID_VPU_0_SEL>, 1276 <&clkc CLKID_VPU_0>, 1277 <&clkc CLKID_VPU>, /* Glitch free mux */ 1278 <&clkc CLKID_VAPB_0_SEL>, 1279 <&clkc CLKID_VAPB_0>, 1280 <&clkc CLKID_VAPB_SEL>; /* Glitch free mux */ 1281 assigned-clock-parents = <&clkc CLKID_FCLK_DIV4>, 1282 <0>, /* Do Nothing */ 1283 <&clkc CLKID_VPU_0>, 1284 <&clkc CLKID_FCLK_DIV4>, 1285 <0>, /* Do Nothing */ 1286 <&clkc CLKID_VAPB_0>; 1287 assigned-clock-rates = <0>, /* Do Nothing */ 1288 <250000000>, 1289 <0>, /* Do Nothing */ 1290 <0>, /* Do Nothing */ 1291 <250000000>, 1292 <0>; /* Do Nothing */ 1293 }; 1294 1295 mipi_pcie_analog_dphy: phy { 1296 compatible = "amlogic,axg-mipi-pcie-analog-phy"; 1297 #phy-cells = <0>; 1298 status = "disabled"; 1299 }; 1300 }; 1301 }; 1302 1303 mailbox: mailbox@ff63c404 { 1304 compatible = "amlogic,meson-gxbb-mhu"; 1305 reg = <0 0xff63c404 0 0x4c>; 1306 interrupts = <GIC_SPI 208 IRQ_TYPE_EDGE_RISING>, 1307 <GIC_SPI 209 IRQ_TYPE_EDGE_RISING>, 1308 <GIC_SPI 210 IRQ_TYPE_EDGE_RISING>; 1309 #mbox-cells = <1>; 1310 }; 1311 1312 mipi_dphy: phy@ff640000 { 1313 compatible = "amlogic,axg-mipi-dphy"; 1314 reg = <0x0 0xff640000 0x0 0x100>; 1315 clocks = <&clkc CLKID_MIPI_DSI_PHY>; 1316 clock-names = "pclk"; 1317 resets = <&reset RESET_MIPI_PHY>; 1318 reset-names = "phy"; 1319 phys = <&mipi_pcie_analog_dphy>; 1320 phy-names = "analog"; 1321 #phy-cells = <0>; 1322 status = "disabled"; 1323 }; 1324 1325 audio: bus@ff642000 { 1326 compatible = "simple-bus"; 1327 reg = <0x0 0xff642000 0x0 0x2000>; 1328 #address-cells = <2>; 1329 #size-cells = <2>; 1330 ranges = <0x0 0x0 0x0 0xff642000 0x0 0x2000>; 1331 1332 clkc_audio: clock-controller@0 { 1333 compatible = "amlogic,axg-audio-clkc"; 1334 reg = <0x0 0x0 0x0 0xb4>; 1335 #clock-cells = <1>; 1336 1337 clocks = <&clkc CLKID_AUDIO>, 1338 <&clkc CLKID_MPLL0>, 1339 <&clkc CLKID_MPLL1>, 1340 <&clkc CLKID_MPLL2>, 1341 <&clkc CLKID_MPLL3>, 1342 <&clkc CLKID_HIFI_PLL>, 1343 <&clkc CLKID_FCLK_DIV3>, 1344 <&clkc CLKID_FCLK_DIV4>, 1345 <&clkc CLKID_GP0_PLL>; 1346 clock-names = "pclk", 1347 "mst_in0", 1348 "mst_in1", 1349 "mst_in2", 1350 "mst_in3", 1351 "mst_in4", 1352 "mst_in5", 1353 "mst_in6", 1354 "mst_in7"; 1355 1356 resets = <&reset RESET_AUDIO>; 1357 }; 1358 1359 toddr_a: audio-controller@100 { 1360 compatible = "amlogic,axg-toddr"; 1361 reg = <0x0 0x100 0x0 0x2c>; 1362 #sound-dai-cells = <0>; 1363 sound-name-prefix = "TODDR_A"; 1364 interrupts = <GIC_SPI 84 IRQ_TYPE_EDGE_RISING>; 1365 clocks = <&clkc_audio AUD_CLKID_TODDR_A>; 1366 resets = <&arb AXG_ARB_TODDR_A>; 1367 amlogic,fifo-depth = <512>; 1368 status = "disabled"; 1369 }; 1370 1371 toddr_b: audio-controller@140 { 1372 compatible = "amlogic,axg-toddr"; 1373 reg = <0x0 0x140 0x0 0x2c>; 1374 #sound-dai-cells = <0>; 1375 sound-name-prefix = "TODDR_B"; 1376 interrupts = <GIC_SPI 85 IRQ_TYPE_EDGE_RISING>; 1377 clocks = <&clkc_audio AUD_CLKID_TODDR_B>; 1378 resets = <&arb AXG_ARB_TODDR_B>; 1379 amlogic,fifo-depth = <256>; 1380 status = "disabled"; 1381 }; 1382 1383 toddr_c: audio-controller@180 { 1384 compatible = "amlogic,axg-toddr"; 1385 reg = <0x0 0x180 0x0 0x2c>; 1386 #sound-dai-cells = <0>; 1387 sound-name-prefix = "TODDR_C"; 1388 interrupts = <GIC_SPI 86 IRQ_TYPE_EDGE_RISING>; 1389 clocks = <&clkc_audio AUD_CLKID_TODDR_C>; 1390 resets = <&arb AXG_ARB_TODDR_C>; 1391 amlogic,fifo-depth = <256>; 1392 status = "disabled"; 1393 }; 1394 1395 frddr_a: audio-controller@1c0 { 1396 compatible = "amlogic,axg-frddr"; 1397 reg = <0x0 0x1c0 0x0 0x2c>; 1398 #sound-dai-cells = <0>; 1399 sound-name-prefix = "FRDDR_A"; 1400 interrupts = <GIC_SPI 88 IRQ_TYPE_EDGE_RISING>; 1401 clocks = <&clkc_audio AUD_CLKID_FRDDR_A>; 1402 resets = <&arb AXG_ARB_FRDDR_A>; 1403 amlogic,fifo-depth = <512>; 1404 status = "disabled"; 1405 }; 1406 1407 frddr_b: audio-controller@200 { 1408 compatible = "amlogic,axg-frddr"; 1409 reg = <0x0 0x200 0x0 0x2c>; 1410 #sound-dai-cells = <0>; 1411 sound-name-prefix = "FRDDR_B"; 1412 interrupts = <GIC_SPI 89 IRQ_TYPE_EDGE_RISING>; 1413 clocks = <&clkc_audio AUD_CLKID_FRDDR_B>; 1414 resets = <&arb AXG_ARB_FRDDR_B>; 1415 amlogic,fifo-depth = <256>; 1416 status = "disabled"; 1417 }; 1418 1419 frddr_c: audio-controller@240 { 1420 compatible = "amlogic,axg-frddr"; 1421 reg = <0x0 0x240 0x0 0x2c>; 1422 #sound-dai-cells = <0>; 1423 sound-name-prefix = "FRDDR_C"; 1424 interrupts = <GIC_SPI 90 IRQ_TYPE_EDGE_RISING>; 1425 clocks = <&clkc_audio AUD_CLKID_FRDDR_C>; 1426 resets = <&arb AXG_ARB_FRDDR_C>; 1427 amlogic,fifo-depth = <256>; 1428 status = "disabled"; 1429 }; 1430 1431 arb: reset-controller@280 { 1432 compatible = "amlogic,meson-axg-audio-arb"; 1433 reg = <0x0 0x280 0x0 0x4>; 1434 #reset-cells = <1>; 1435 clocks = <&clkc_audio AUD_CLKID_DDR_ARB>; 1436 }; 1437 1438 tdmin_a: audio-controller@300 { 1439 compatible = "amlogic,axg-tdmin"; 1440 reg = <0x0 0x300 0x0 0x40>; 1441 sound-name-prefix = "TDMIN_A"; 1442 clocks = <&clkc_audio AUD_CLKID_TDMIN_A>, 1443 <&clkc_audio AUD_CLKID_TDMIN_A_SCLK>, 1444 <&clkc_audio AUD_CLKID_TDMIN_A_SCLK_SEL>, 1445 <&clkc_audio AUD_CLKID_TDMIN_A_LRCLK>, 1446 <&clkc_audio AUD_CLKID_TDMIN_A_LRCLK>; 1447 clock-names = "pclk", "sclk", "sclk_sel", 1448 "lrclk", "lrclk_sel"; 1449 status = "disabled"; 1450 }; 1451 1452 tdmin_b: audio-controller@340 { 1453 compatible = "amlogic,axg-tdmin"; 1454 reg = <0x0 0x340 0x0 0x40>; 1455 sound-name-prefix = "TDMIN_B"; 1456 clocks = <&clkc_audio AUD_CLKID_TDMIN_B>, 1457 <&clkc_audio AUD_CLKID_TDMIN_B_SCLK>, 1458 <&clkc_audio AUD_CLKID_TDMIN_B_SCLK_SEL>, 1459 <&clkc_audio AUD_CLKID_TDMIN_B_LRCLK>, 1460 <&clkc_audio AUD_CLKID_TDMIN_B_LRCLK>; 1461 clock-names = "pclk", "sclk", "sclk_sel", 1462 "lrclk", "lrclk_sel"; 1463 status = "disabled"; 1464 }; 1465 1466 tdmin_c: audio-controller@380 { 1467 compatible = "amlogic,axg-tdmin"; 1468 reg = <0x0 0x380 0x0 0x40>; 1469 sound-name-prefix = "TDMIN_C"; 1470 clocks = <&clkc_audio AUD_CLKID_TDMIN_C>, 1471 <&clkc_audio AUD_CLKID_TDMIN_C_SCLK>, 1472 <&clkc_audio AUD_CLKID_TDMIN_C_SCLK_SEL>, 1473 <&clkc_audio AUD_CLKID_TDMIN_C_LRCLK>, 1474 <&clkc_audio AUD_CLKID_TDMIN_C_LRCLK>; 1475 clock-names = "pclk", "sclk", "sclk_sel", 1476 "lrclk", "lrclk_sel"; 1477 status = "disabled"; 1478 }; 1479 1480 tdmin_lb: audio-controller@3c0 { 1481 compatible = "amlogic,axg-tdmin"; 1482 reg = <0x0 0x3c0 0x0 0x40>; 1483 sound-name-prefix = "TDMIN_LB"; 1484 clocks = <&clkc_audio AUD_CLKID_TDMIN_LB>, 1485 <&clkc_audio AUD_CLKID_TDMIN_LB_SCLK>, 1486 <&clkc_audio AUD_CLKID_TDMIN_LB_SCLK_SEL>, 1487 <&clkc_audio AUD_CLKID_TDMIN_LB_LRCLK>, 1488 <&clkc_audio AUD_CLKID_TDMIN_LB_LRCLK>; 1489 clock-names = "pclk", "sclk", "sclk_sel", 1490 "lrclk", "lrclk_sel"; 1491 status = "disabled"; 1492 }; 1493 1494 spdifin: audio-controller@400 { 1495 compatible = "amlogic,axg-spdifin"; 1496 reg = <0x0 0x400 0x0 0x30>; 1497 #sound-dai-cells = <0>; 1498 sound-name-prefix = "SPDIFIN"; 1499 interrupts = <GIC_SPI 87 IRQ_TYPE_EDGE_RISING>; 1500 clocks = <&clkc_audio AUD_CLKID_SPDIFIN>, 1501 <&clkc_audio AUD_CLKID_SPDIFIN_CLK>; 1502 clock-names = "pclk", "refclk"; 1503 status = "disabled"; 1504 }; 1505 1506 spdifout: audio-controller@480 { 1507 compatible = "amlogic,axg-spdifout"; 1508 reg = <0x0 0x480 0x0 0x50>; 1509 #sound-dai-cells = <0>; 1510 sound-name-prefix = "SPDIFOUT"; 1511 clocks = <&clkc_audio AUD_CLKID_SPDIFOUT>, 1512 <&clkc_audio AUD_CLKID_SPDIFOUT_CLK>; 1513 clock-names = "pclk", "mclk"; 1514 status = "disabled"; 1515 }; 1516 1517 tdmout_a: audio-controller@500 { 1518 compatible = "amlogic,axg-tdmout"; 1519 reg = <0x0 0x500 0x0 0x40>; 1520 sound-name-prefix = "TDMOUT_A"; 1521 clocks = <&clkc_audio AUD_CLKID_TDMOUT_A>, 1522 <&clkc_audio AUD_CLKID_TDMOUT_A_SCLK>, 1523 <&clkc_audio AUD_CLKID_TDMOUT_A_SCLK_SEL>, 1524 <&clkc_audio AUD_CLKID_TDMOUT_A_LRCLK>, 1525 <&clkc_audio AUD_CLKID_TDMOUT_A_LRCLK>; 1526 clock-names = "pclk", "sclk", "sclk_sel", 1527 "lrclk", "lrclk_sel"; 1528 status = "disabled"; 1529 }; 1530 1531 tdmout_b: audio-controller@540 { 1532 compatible = "amlogic,axg-tdmout"; 1533 reg = <0x0 0x540 0x0 0x40>; 1534 sound-name-prefix = "TDMOUT_B"; 1535 clocks = <&clkc_audio AUD_CLKID_TDMOUT_B>, 1536 <&clkc_audio AUD_CLKID_TDMOUT_B_SCLK>, 1537 <&clkc_audio AUD_CLKID_TDMOUT_B_SCLK_SEL>, 1538 <&clkc_audio AUD_CLKID_TDMOUT_B_LRCLK>, 1539 <&clkc_audio AUD_CLKID_TDMOUT_B_LRCLK>; 1540 clock-names = "pclk", "sclk", "sclk_sel", 1541 "lrclk", "lrclk_sel"; 1542 status = "disabled"; 1543 }; 1544 1545 tdmout_c: audio-controller@580 { 1546 compatible = "amlogic,axg-tdmout"; 1547 reg = <0x0 0x580 0x0 0x40>; 1548 sound-name-prefix = "TDMOUT_C"; 1549 clocks = <&clkc_audio AUD_CLKID_TDMOUT_C>, 1550 <&clkc_audio AUD_CLKID_TDMOUT_C_SCLK>, 1551 <&clkc_audio AUD_CLKID_TDMOUT_C_SCLK_SEL>, 1552 <&clkc_audio AUD_CLKID_TDMOUT_C_LRCLK>, 1553 <&clkc_audio AUD_CLKID_TDMOUT_C_LRCLK>; 1554 clock-names = "pclk", "sclk", "sclk_sel", 1555 "lrclk", "lrclk_sel"; 1556 status = "disabled"; 1557 }; 1558 }; 1559 1560 aobus: bus@ff800000 { 1561 compatible = "simple-bus"; 1562 reg = <0x0 0xff800000 0x0 0x100000>; 1563 #address-cells = <2>; 1564 #size-cells = <2>; 1565 ranges = <0x0 0x0 0x0 0xff800000 0x0 0x100000>; 1566 1567 sysctrl_AO: sys-ctrl@0 { 1568 compatible = "amlogic,meson-axg-ao-sysctrl", "simple-mfd", "syscon"; 1569 reg = <0x0 0x0 0x0 0x100>; 1570 1571 clkc_AO: clock-controller { 1572 compatible = "amlogic,meson-axg-aoclkc"; 1573 #clock-cells = <1>; 1574 #reset-cells = <1>; 1575 clocks = <&xtal>, <&clkc CLKID_CLK81>; 1576 clock-names = "xtal", "mpeg-clk"; 1577 }; 1578 }; 1579 1580 pinctrl_aobus: pinctrl@14 { 1581 compatible = "amlogic,meson-axg-aobus-pinctrl"; 1582 #address-cells = <2>; 1583 #size-cells = <2>; 1584 ranges; 1585 1586 gpio_ao: bank@14 { 1587 reg = <0x0 0x00014 0x0 0x8>, 1588 <0x0 0x0002c 0x0 0x4>, 1589 <0x0 0x00024 0x0 0x8>; 1590 reg-names = "mux", "pull", "gpio"; 1591 gpio-controller; 1592 #gpio-cells = <2>; 1593 gpio-ranges = <&pinctrl_aobus 0 0 15>; 1594 }; 1595 1596 i2c_ao_sck_4_pins: i2c_ao_sck_4 { 1597 mux { 1598 groups = "i2c_ao_sck_4"; 1599 function = "i2c_ao"; 1600 bias-disable; 1601 }; 1602 }; 1603 1604 i2c_ao_sck_8_pins: i2c_ao_sck_8 { 1605 mux { 1606 groups = "i2c_ao_sck_8"; 1607 function = "i2c_ao"; 1608 bias-disable; 1609 }; 1610 }; 1611 1612 i2c_ao_sck_10_pins: i2c_ao_sck_10 { 1613 mux { 1614 groups = "i2c_ao_sck_10"; 1615 function = "i2c_ao"; 1616 bias-disable; 1617 }; 1618 }; 1619 1620 i2c_ao_sda_5_pins: i2c_ao_sda_5 { 1621 mux { 1622 groups = "i2c_ao_sda_5"; 1623 function = "i2c_ao"; 1624 bias-disable; 1625 }; 1626 }; 1627 1628 i2c_ao_sda_9_pins: i2c_ao_sda_9 { 1629 mux { 1630 groups = "i2c_ao_sda_9"; 1631 function = "i2c_ao"; 1632 bias-disable; 1633 }; 1634 }; 1635 1636 i2c_ao_sda_11_pins: i2c_ao_sda_11 { 1637 mux { 1638 groups = "i2c_ao_sda_11"; 1639 function = "i2c_ao"; 1640 bias-disable; 1641 }; 1642 }; 1643 1644 remote_input_ao_pins: remote_input_ao { 1645 mux { 1646 groups = "remote_input_ao"; 1647 function = "remote_input_ao"; 1648 bias-disable; 1649 }; 1650 }; 1651 1652 uart_ao_a_pins: uart_ao_a { 1653 mux { 1654 groups = "uart_ao_tx_a", 1655 "uart_ao_rx_a"; 1656 function = "uart_ao_a"; 1657 bias-disable; 1658 }; 1659 }; 1660 1661 uart_ao_a_cts_rts_pins: uart_ao_a_cts_rts { 1662 mux { 1663 groups = "uart_ao_cts_a", 1664 "uart_ao_rts_a"; 1665 function = "uart_ao_a"; 1666 bias-disable; 1667 }; 1668 }; 1669 1670 uart_ao_b_pins: uart_ao_b { 1671 mux { 1672 groups = "uart_ao_tx_b", 1673 "uart_ao_rx_b"; 1674 function = "uart_ao_b"; 1675 bias-disable; 1676 }; 1677 }; 1678 1679 uart_ao_b_cts_rts_pins: uart_ao_b_cts_rts { 1680 mux { 1681 groups = "uart_ao_cts_b", 1682 "uart_ao_rts_b"; 1683 function = "uart_ao_b"; 1684 bias-disable; 1685 }; 1686 }; 1687 }; 1688 1689 sec_AO: ao-secure@140 { 1690 compatible = "amlogic,meson-gx-ao-secure", "syscon"; 1691 reg = <0x0 0x140 0x0 0x140>; 1692 amlogic,has-chip-id; 1693 }; 1694 1695 pwm_AO_cd: pwm@2000 { 1696 compatible = "amlogic,meson-axg-ao-pwm"; 1697 reg = <0x0 0x02000 0x0 0x20>; 1698 #pwm-cells = <3>; 1699 status = "disabled"; 1700 }; 1701 1702 uart_AO: serial@3000 { 1703 compatible = "amlogic,meson-gx-uart", "amlogic,meson-ao-uart"; 1704 reg = <0x0 0x3000 0x0 0x18>; 1705 interrupts = <GIC_SPI 193 IRQ_TYPE_EDGE_RISING>; 1706 clocks = <&xtal>, <&clkc_AO CLKID_AO_UART1>, <&xtal>; 1707 clock-names = "xtal", "pclk", "baud"; 1708 status = "disabled"; 1709 }; 1710 1711 uart_AO_B: serial@4000 { 1712 compatible = "amlogic,meson-gx-uart", "amlogic,meson-ao-uart"; 1713 reg = <0x0 0x4000 0x0 0x18>; 1714 interrupts = <GIC_SPI 197 IRQ_TYPE_EDGE_RISING>; 1715 clocks = <&xtal>, <&clkc_AO CLKID_AO_UART2>, <&xtal>; 1716 clock-names = "xtal", "pclk", "baud"; 1717 status = "disabled"; 1718 }; 1719 1720 i2c_AO: i2c@5000 { 1721 compatible = "amlogic,meson-axg-i2c"; 1722 reg = <0x0 0x05000 0x0 0x20>; 1723 interrupts = <GIC_SPI 195 IRQ_TYPE_EDGE_RISING>; 1724 clocks = <&clkc CLKID_AO_I2C>; 1725 #address-cells = <1>; 1726 #size-cells = <0>; 1727 status = "disabled"; 1728 }; 1729 1730 pwm_AO_ab: pwm@7000 { 1731 compatible = "amlogic,meson-axg-ao-pwm"; 1732 reg = <0x0 0x07000 0x0 0x20>; 1733 #pwm-cells = <3>; 1734 status = "disabled"; 1735 }; 1736 1737 ir: ir@8000 { 1738 compatible = "amlogic,meson-gxbb-ir"; 1739 reg = <0x0 0x8000 0x0 0x20>; 1740 interrupts = <GIC_SPI 196 IRQ_TYPE_EDGE_RISING>; 1741 status = "disabled"; 1742 }; 1743 1744 saradc: adc@9000 { 1745 compatible = "amlogic,meson-axg-saradc", 1746 "amlogic,meson-saradc"; 1747 reg = <0x0 0x9000 0x0 0x38>; 1748 #io-channel-cells = <1>; 1749 interrupts = <GIC_SPI 73 IRQ_TYPE_EDGE_RISING>; 1750 clocks = <&xtal>, 1751 <&clkc_AO CLKID_AO_SAR_ADC>, 1752 <&clkc_AO CLKID_AO_SAR_ADC_CLK>, 1753 <&clkc_AO CLKID_AO_SAR_ADC_SEL>; 1754 clock-names = "clkin", "core", "adc_clk", "adc_sel"; 1755 status = "disabled"; 1756 }; 1757 }; 1758 1759 ge2d: ge2d@ff940000 { 1760 compatible = "amlogic,axg-ge2d"; 1761 reg = <0x0 0xff940000 0x0 0x10000>; 1762 interrupts = <GIC_SPI 150 IRQ_TYPE_EDGE_RISING>; 1763 clocks = <&clkc CLKID_VAPB>; 1764 resets = <&reset RESET_GE2D>; 1765 }; 1766 1767 gic: interrupt-controller@ffc01000 { 1768 compatible = "arm,gic-400"; 1769 reg = <0x0 0xffc01000 0 0x1000>, 1770 <0x0 0xffc02000 0 0x2000>, 1771 <0x0 0xffc04000 0 0x2000>, 1772 <0x0 0xffc06000 0 0x2000>; 1773 interrupt-controller; 1774 interrupts = <GIC_PPI 9 1775 (GIC_CPU_MASK_SIMPLE(8) | IRQ_TYPE_LEVEL_HIGH)>; 1776 #interrupt-cells = <3>; 1777 #address-cells = <0>; 1778 }; 1779 1780 cbus: bus@ffd00000 { 1781 compatible = "simple-bus"; 1782 reg = <0x0 0xffd00000 0x0 0x25000>; 1783 #address-cells = <2>; 1784 #size-cells = <2>; 1785 ranges = <0x0 0x0 0x0 0xffd00000 0x0 0x25000>; 1786 1787 reset: reset-controller@1004 { 1788 compatible = "amlogic,meson-axg-reset"; 1789 reg = <0x0 0x01004 0x0 0x9c>; 1790 #reset-cells = <1>; 1791 }; 1792 1793 gpio_intc: interrupt-controller@f080 { 1794 compatible = "amlogic,meson-axg-gpio-intc", 1795 "amlogic,meson-gpio-intc"; 1796 reg = <0x0 0xf080 0x0 0x10>; 1797 interrupt-controller; 1798 #interrupt-cells = <2>; 1799 amlogic,channel-interrupts = <64 65 66 67 68 69 70 71>; 1800 }; 1801 1802 watchdog@f0d0 { 1803 compatible = "amlogic,meson-gxbb-wdt"; 1804 reg = <0x0 0xf0d0 0x0 0x10>; 1805 clocks = <&xtal>; 1806 }; 1807 1808 pwm_ab: pwm@1b000 { 1809 compatible = "amlogic,meson-axg-ee-pwm"; 1810 reg = <0x0 0x1b000 0x0 0x20>; 1811 #pwm-cells = <3>; 1812 status = "disabled"; 1813 }; 1814 1815 pwm_cd: pwm@1a000 { 1816 compatible = "amlogic,meson-axg-ee-pwm"; 1817 reg = <0x0 0x1a000 0x0 0x20>; 1818 #pwm-cells = <3>; 1819 status = "disabled"; 1820 }; 1821 1822 spicc0: spi@13000 { 1823 compatible = "amlogic,meson-axg-spicc"; 1824 reg = <0x0 0x13000 0x0 0x3c>; 1825 interrupts = <GIC_SPI 81 IRQ_TYPE_LEVEL_HIGH>; 1826 clocks = <&clkc CLKID_SPICC0>; 1827 clock-names = "core"; 1828 #address-cells = <1>; 1829 #size-cells = <0>; 1830 status = "disabled"; 1831 }; 1832 1833 spicc1: spi@15000 { 1834 compatible = "amlogic,meson-axg-spicc"; 1835 reg = <0x0 0x15000 0x0 0x3c>; 1836 interrupts = <GIC_SPI 82 IRQ_TYPE_LEVEL_HIGH>; 1837 clocks = <&clkc CLKID_SPICC1>; 1838 clock-names = "core"; 1839 #address-cells = <1>; 1840 #size-cells = <0>; 1841 status = "disabled"; 1842 }; 1843 1844 clk_msr: clock-measure@18000 { 1845 compatible = "amlogic,meson-axg-clk-measure"; 1846 reg = <0x0 0x18000 0x0 0x10>; 1847 }; 1848 1849 i2c3: i2c@1c000 { 1850 compatible = "amlogic,meson-axg-i2c"; 1851 reg = <0x0 0x1c000 0x0 0x20>; 1852 interrupts = <GIC_SPI 39 IRQ_TYPE_EDGE_RISING>; 1853 clocks = <&clkc CLKID_I2C>; 1854 #address-cells = <1>; 1855 #size-cells = <0>; 1856 status = "disabled"; 1857 }; 1858 1859 i2c2: i2c@1d000 { 1860 compatible = "amlogic,meson-axg-i2c"; 1861 reg = <0x0 0x1d000 0x0 0x20>; 1862 interrupts = <GIC_SPI 215 IRQ_TYPE_EDGE_RISING>; 1863 clocks = <&clkc CLKID_I2C>; 1864 #address-cells = <1>; 1865 #size-cells = <0>; 1866 status = "disabled"; 1867 }; 1868 1869 i2c1: i2c@1e000 { 1870 compatible = "amlogic,meson-axg-i2c"; 1871 reg = <0x0 0x1e000 0x0 0x20>; 1872 interrupts = <GIC_SPI 214 IRQ_TYPE_EDGE_RISING>; 1873 clocks = <&clkc CLKID_I2C>; 1874 #address-cells = <1>; 1875 #size-cells = <0>; 1876 status = "disabled"; 1877 }; 1878 1879 i2c0: i2c@1f000 { 1880 compatible = "amlogic,meson-axg-i2c"; 1881 reg = <0x0 0x1f000 0x0 0x20>; 1882 interrupts = <GIC_SPI 21 IRQ_TYPE_EDGE_RISING>; 1883 clocks = <&clkc CLKID_I2C>; 1884 #address-cells = <1>; 1885 #size-cells = <0>; 1886 status = "disabled"; 1887 }; 1888 1889 uart_B: serial@23000 { 1890 compatible = "amlogic,meson-gx-uart"; 1891 reg = <0x0 0x23000 0x0 0x18>; 1892 interrupts = <GIC_SPI 75 IRQ_TYPE_EDGE_RISING>; 1893 status = "disabled"; 1894 clocks = <&xtal>, <&clkc CLKID_UART1>, <&xtal>; 1895 clock-names = "xtal", "pclk", "baud"; 1896 }; 1897 1898 uart_A: serial@24000 { 1899 compatible = "amlogic,meson-gx-uart"; 1900 reg = <0x0 0x24000 0x0 0x18>; 1901 interrupts = <GIC_SPI 26 IRQ_TYPE_EDGE_RISING>; 1902 status = "disabled"; 1903 clocks = <&xtal>, <&clkc CLKID_UART0>, <&xtal>; 1904 clock-names = "xtal", "pclk", "baud"; 1905 fifo-size = <128>; 1906 }; 1907 }; 1908 1909 apb: bus@ffe00000 { 1910 compatible = "simple-bus"; 1911 reg = <0x0 0xffe00000 0x0 0x200000>; 1912 #address-cells = <2>; 1913 #size-cells = <2>; 1914 ranges = <0x0 0x0 0x0 0xffe00000 0x0 0x200000>; 1915 1916 sd_emmc_b: mmc@5000 { 1917 compatible = "amlogic,meson-axg-mmc"; 1918 reg = <0x0 0x5000 0x0 0x800>; 1919 interrupts = <GIC_SPI 217 IRQ_TYPE_LEVEL_HIGH>; 1920 status = "disabled"; 1921 clocks = <&clkc CLKID_SD_EMMC_B>, 1922 <&clkc CLKID_SD_EMMC_B_CLK0>, 1923 <&clkc CLKID_FCLK_DIV2>; 1924 clock-names = "core", "clkin0", "clkin1"; 1925 resets = <&reset RESET_SD_EMMC_B>; 1926 }; 1927 1928 sd_emmc_c: mmc@7000 { 1929 compatible = "amlogic,meson-axg-mmc"; 1930 reg = <0x0 0x7000 0x0 0x800>; 1931 interrupts = <GIC_SPI 218 IRQ_TYPE_LEVEL_HIGH>; 1932 status = "disabled"; 1933 clocks = <&clkc CLKID_SD_EMMC_C>, 1934 <&clkc CLKID_SD_EMMC_C_CLK0>, 1935 <&clkc CLKID_FCLK_DIV2>; 1936 clock-names = "core", "clkin0", "clkin1"; 1937 resets = <&reset RESET_SD_EMMC_C>; 1938 }; 1939 1940 nfc: nand-controller@7800 { 1941 compatible = "amlogic,meson-axg-nfc"; 1942 reg = <0x0 0x7800 0x0 0x100>, 1943 <0x0 0x7000 0x0 0x800>; 1944 reg-names = "nfc", "emmc"; 1945 pinctrl-0 = <&nand_all_pins>; 1946 pinctrl-names = "default"; 1947 #address-cells = <1>; 1948 #size-cells = <0>; 1949 interrupts = <GIC_SPI 34 IRQ_TYPE_EDGE_RISING>; 1950 clocks = <&clkc CLKID_SD_EMMC_C>, 1951 <&clkc CLKID_FCLK_DIV2>; 1952 clock-names = "core", "device"; 1953 }; 1954 1955 usb2_phy1: phy@9020 { 1956 compatible = "amlogic,meson-gxl-usb2-phy"; 1957 #phy-cells = <0>; 1958 reg = <0x0 0x9020 0x0 0x20>; 1959 clocks = <&clkc CLKID_USB>; 1960 clock-names = "phy"; 1961 resets = <&reset RESET_USB_OTG>; 1962 reset-names = "phy"; 1963 }; 1964 }; 1965 1966 sram: sram@fffc0000 { 1967 compatible = "mmio-sram"; 1968 reg = <0x0 0xfffc0000 0x0 0x20000>; 1969 #address-cells = <1>; 1970 #size-cells = <1>; 1971 ranges = <0 0x0 0xfffc0000 0x20000>; 1972 1973 cpu_scp_lpri: scp-sram@13000 { 1974 compatible = "amlogic,meson-axg-scp-shmem"; 1975 reg = <0x13000 0x400>; 1976 }; 1977 1978 cpu_scp_hpri: scp-sram@13400 { 1979 compatible = "amlogic,meson-axg-scp-shmem"; 1980 reg = <0x13400 0x400>; 1981 }; 1982 }; 1983 }; 1984 1985 timer { 1986 compatible = "arm,armv8-timer"; 1987 interrupts = <GIC_PPI 13 1988 (GIC_CPU_MASK_RAW(0xff) | IRQ_TYPE_LEVEL_LOW)>, 1989 <GIC_PPI 14 1990 (GIC_CPU_MASK_RAW(0xff) | IRQ_TYPE_LEVEL_LOW)>, 1991 <GIC_PPI 11 1992 (GIC_CPU_MASK_RAW(0xff) | IRQ_TYPE_LEVEL_LOW)>, 1993 <GIC_PPI 10 1994 (GIC_CPU_MASK_RAW(0xff) | IRQ_TYPE_LEVEL_LOW)>; 1995 }; 1996 1997 xtal: xtal-clk { 1998 compatible = "fixed-clock"; 1999 clock-frequency = <24000000>; 2000 clock-output-names = "xtal"; 2001 #clock-cells = <0>; 2002 }; 2003 };
Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.