1// SPDX-License-Identifier: GPL-2.0 2/* 3 * SDM670 SoC device tree source, adapted from SDM845 SoC device tree 4 * 5 * Copyright (c) 2018, The Linux Foundation. All rights reserved. 6 * Copyright (c) 2022, Richard Acayan. All rights reserved. 7 */ 8 9#include <dt-bindings/clock/qcom,dispcc-sdm845.h> 10#include <dt-bindings/clock/qcom,gcc-sdm845.h> 11#include <dt-bindings/clock/qcom,rpmh.h> 12#include <dt-bindings/dma/qcom-gpi.h> 13#include <dt-bindings/gpio/gpio.h> 14#include <dt-bindings/interconnect/qcom,osm-l3.h> 15#include <dt-bindings/interconnect/qcom,sdm670-rpmh.h> 16#include <dt-bindings/interrupt-controller/arm-gic.h> 17#include <dt-bindings/phy/phy-qcom-qusb2.h> 18#include <dt-bindings/power/qcom-rpmpd.h> 19#include <dt-bindings/soc/qcom,rpmh-rsc.h> 20 21/ { 22 interrupt-parent = <&intc>; 23 24 #address-cells = <2>; 25 #size-cells = <2>; 26 27 aliases { }; 28 29 chosen { }; 30 31 cpus { 32 #address-cells = <2>; 33 #size-cells = <0>; 34 35 cpu0: cpu@0 { 36 device_type = "cpu"; 37 compatible = "qcom,kryo360"; 38 reg = <0x0 0x0>; 39 enable-method = "psci"; 40 capacity-dmips-mhz = <610>; 41 dynamic-power-coefficient = <203>; 42 qcom,freq-domain = <&cpufreq_hw 0>; 43 operating-points-v2 = <&cpu0_opp_table>; 44 interconnects = <&gladiator_noc MASTER_AMPSS_M0 3 &mem_noc SLAVE_EBI_CH0 3>, 45 <&osm_l3 MASTER_OSM_L3_APPS &osm_l3 SLAVE_OSM_L3>; 46 power-domains = <&cpu_pd0>; 47 power-domain-names = "psci"; 48 next-level-cache = <&l2_0>; 49 l2_0: l2-cache { 50 compatible = "cache"; 51 next-level-cache = <&l3_0>; 52 cache-level = <2>; 53 cache-unified; 54 l3_0: l3-cache { 55 compatible = "cache"; 56 cache-level = <3>; 57 cache-unified; 58 }; 59 }; 60 }; 61 62 cpu1: cpu@100 { 63 device_type = "cpu"; 64 compatible = "qcom,kryo360"; 65 reg = <0x0 0x100>; 66 enable-method = "psci"; 67 capacity-dmips-mhz = <610>; 68 dynamic-power-coefficient = <203>; 69 qcom,freq-domain = <&cpufreq_hw 0>; 70 operating-points-v2 = <&cpu0_opp_table>; 71 interconnects = <&gladiator_noc MASTER_AMPSS_M0 3 &mem_noc SLAVE_EBI_CH0 3>, 72 <&osm_l3 MASTER_OSM_L3_APPS &osm_l3 SLAVE_OSM_L3>; 73 power-domains = <&cpu_pd1>; 74 power-domain-names = "psci"; 75 next-level-cache = <&l2_100>; 76 l2_100: l2-cache { 77 compatible = "cache"; 78 cache-level = <2>; 79 cache-unified; 80 next-level-cache = <&l3_0>; 81 }; 82 }; 83 84 cpu2: cpu@200 { 85 device_type = "cpu"; 86 compatible = "qcom,kryo360"; 87 reg = <0x0 0x200>; 88 enable-method = "psci"; 89 capacity-dmips-mhz = <610>; 90 dynamic-power-coefficient = <203>; 91 qcom,freq-domain = <&cpufreq_hw 0>; 92 operating-points-v2 = <&cpu0_opp_table>; 93 interconnects = <&gladiator_noc MASTER_AMPSS_M0 3 &mem_noc SLAVE_EBI_CH0 3>, 94 <&osm_l3 MASTER_OSM_L3_APPS &osm_l3 SLAVE_OSM_L3>; 95 power-domains = <&cpu_pd2>; 96 power-domain-names = "psci"; 97 next-level-cache = <&l2_200>; 98 l2_200: l2-cache { 99 compatible = "cache"; 100 cache-level = <2>; 101 cache-unified; 102 next-level-cache = <&l3_0>; 103 }; 104 }; 105 106 cpu3: cpu@300 { 107 device_type = "cpu"; 108 compatible = "qcom,kryo360"; 109 reg = <0x0 0x300>; 110 enable-method = "psci"; 111 capacity-dmips-mhz = <610>; 112 dynamic-power-coefficient = <203>; 113 qcom,freq-domain = <&cpufreq_hw 0>; 114 operating-points-v2 = <&cpu0_opp_table>; 115 interconnects = <&gladiator_noc MASTER_AMPSS_M0 3 &mem_noc SLAVE_EBI_CH0 3>, 116 <&osm_l3 MASTER_OSM_L3_APPS &osm_l3 SLAVE_OSM_L3>; 117 power-domains = <&cpu_pd3>; 118 power-domain-names = "psci"; 119 next-level-cache = <&l2_300>; 120 l2_300: l2-cache { 121 compatible = "cache"; 122 cache-level = <2>; 123 cache-unified; 124 next-level-cache = <&l3_0>; 125 }; 126 }; 127 128 cpu4: cpu@400 { 129 device_type = "cpu"; 130 compatible = "qcom,kryo360"; 131 reg = <0x0 0x400>; 132 enable-method = "psci"; 133 capacity-dmips-mhz = <610>; 134 dynamic-power-coefficient = <203>; 135 qcom,freq-domain = <&cpufreq_hw 0>; 136 operating-points-v2 = <&cpu0_opp_table>; 137 interconnects = <&gladiator_noc MASTER_AMPSS_M0 3 &mem_noc SLAVE_EBI_CH0 3>, 138 <&osm_l3 MASTER_OSM_L3_APPS &osm_l3 SLAVE_OSM_L3>; 139 power-domains = <&cpu_pd4>; 140 power-domain-names = "psci"; 141 next-level-cache = <&l2_400>; 142 l2_400: l2-cache { 143 compatible = "cache"; 144 cache-level = <2>; 145 cache-unified; 146 next-level-cache = <&l3_0>; 147 }; 148 }; 149 150 cpu5: cpu@500 { 151 device_type = "cpu"; 152 compatible = "qcom,kryo360"; 153 reg = <0x0 0x500>; 154 enable-method = "psci"; 155 capacity-dmips-mhz = <610>; 156 dynamic-power-coefficient = <203>; 157 qcom,freq-domain = <&cpufreq_hw 0>; 158 operating-points-v2 = <&cpu0_opp_table>; 159 interconnects = <&gladiator_noc MASTER_AMPSS_M0 3 &mem_noc SLAVE_EBI_CH0 3>, 160 <&osm_l3 MASTER_OSM_L3_APPS &osm_l3 SLAVE_OSM_L3>; 161 power-domains = <&cpu_pd5>; 162 power-domain-names = "psci"; 163 next-level-cache = <&l2_500>; 164 l2_500: l2-cache { 165 compatible = "cache"; 166 cache-level = <2>; 167 cache-unified; 168 next-level-cache = <&l3_0>; 169 }; 170 }; 171 172 cpu6: cpu@600 { 173 device_type = "cpu"; 174 compatible = "qcom,kryo360"; 175 reg = <0x0 0x600>; 176 enable-method = "psci"; 177 capacity-dmips-mhz = <1024>; 178 dynamic-power-coefficient = <393>; 179 qcom,freq-domain = <&cpufreq_hw 1>; 180 operating-points-v2 = <&cpu6_opp_table>; 181 interconnects = <&gladiator_noc MASTER_AMPSS_M0 3 &mem_noc SLAVE_EBI_CH0 3>, 182 <&osm_l3 MASTER_OSM_L3_APPS &osm_l3 SLAVE_OSM_L3>; 183 power-domains = <&cpu_pd6>; 184 power-domain-names = "psci"; 185 next-level-cache = <&l2_600>; 186 l2_600: l2-cache { 187 compatible = "cache"; 188 cache-level = <2>; 189 cache-unified; 190 next-level-cache = <&l3_0>; 191 }; 192 }; 193 194 cpu7: cpu@700 { 195 device_type = "cpu"; 196 compatible = "qcom,kryo360"; 197 reg = <0x0 0x700>; 198 enable-method = "psci"; 199 capacity-dmips-mhz = <1024>; 200 dynamic-power-coefficient = <393>; 201 qcom,freq-domain = <&cpufreq_hw 1>; 202 operating-points-v2 = <&cpu6_opp_table>; 203 interconnects = <&gladiator_noc MASTER_AMPSS_M0 3 &mem_noc SLAVE_EBI_CH0 3>, 204 <&osm_l3 MASTER_OSM_L3_APPS &osm_l3 SLAVE_OSM_L3>; 205 power-domains = <&cpu_pd7>; 206 power-domain-names = "psci"; 207 next-level-cache = <&l2_700>; 208 l2_700: l2-cache { 209 compatible = "cache"; 210 cache-level = <2>; 211 cache-unified; 212 next-level-cache = <&l3_0>; 213 }; 214 }; 215 216 cpu-map { 217 cluster0 { 218 core0 { 219 cpu = <&cpu0>; 220 }; 221 222 core1 { 223 cpu = <&cpu1>; 224 }; 225 226 core2 { 227 cpu = <&cpu2>; 228 }; 229 230 core3 { 231 cpu = <&cpu3>; 232 }; 233 234 core4 { 235 cpu = <&cpu4>; 236 }; 237 238 core5 { 239 cpu = <&cpu5>; 240 }; 241 242 core6 { 243 cpu = <&cpu6>; 244 }; 245 246 core7 { 247 cpu = <&cpu7>; 248 }; 249 }; 250 }; 251 252 idle-states { 253 entry-method = "psci"; 254 255 little_cpu_sleep_0: cpu-sleep-0-0 { 256 compatible = "arm,idle-state"; 257 idle-state-name = "little-rail-power-collapse"; 258 arm,psci-suspend-param = <0x40000004>; 259 entry-latency-us = <702>; 260 exit-latency-us = <915>; 261 min-residency-us = <1617>; 262 local-timer-stop; 263 }; 264 265 big_cpu_sleep_0: cpu-sleep-1-0 { 266 compatible = "arm,idle-state"; 267 idle-state-name = "big-rail-power-collapse"; 268 arm,psci-suspend-param = <0x40000004>; 269 entry-latency-us = <526>; 270 exit-latency-us = <1854>; 271 min-residency-us = <2380>; 272 local-timer-stop; 273 }; 274 }; 275 276 domain-idle-states { 277 cluster_sleep_0: cluster-sleep-0 { 278 compatible = "domain-idle-state"; 279 arm,psci-suspend-param = <0x4100c244>; 280 entry-latency-us = <3263>; 281 exit-latency-us = <6562>; 282 min-residency-us = <9825>; 283 }; 284 }; 285 }; 286 287 firmware { 288 scm { 289 compatible = "qcom,scm-sdm670", "qcom,scm"; 290 }; 291 }; 292 293 memory@80000000 { 294 device_type = "memory"; 295 /* We expect the bootloader to fill in the size */ 296 reg = <0x0 0x80000000 0x0 0x0>; 297 }; 298 299 cpu0_opp_table: opp-table-cpu0 { 300 compatible = "operating-points-v2"; 301 opp-shared; 302 303 cpu0_opp1: opp-300000000 { 304 opp-hz = /bits/ 64 <300000000>; 305 opp-peak-kBps = <400000 4800000>; 306 }; 307 308 cpu0_opp2: opp-576000000 { 309 opp-hz = /bits/ 64 <576000000>; 310 opp-peak-kBps = <400000 4800000>; 311 }; 312 313 cpu0_opp3: opp-748800000 { 314 opp-hz = /bits/ 64 <748800000>; 315 opp-peak-kBps = <1200000 4800000>; 316 }; 317 318 cpu0_opp4: opp-998400000 { 319 opp-hz = /bits/ 64 <998400000>; 320 opp-peak-kBps = <1804000 8908800>; 321 }; 322 323 cpu0_opp5: opp-1209600000 { 324 opp-hz = /bits/ 64 <1209600000>; 325 opp-peak-kBps = <2188000 8908800>; 326 }; 327 328 cpu0_opp6: opp-1324800000 { 329 opp-hz = /bits/ 64 <1324800000>; 330 opp-peak-kBps = <2188000 13516800>; 331 }; 332 333 cpu0_opp7: opp-1516800000 { 334 opp-hz = /bits/ 64 <1516800000>; 335 opp-peak-kBps = <3072000 15052800>; 336 }; 337 338 cpu0_opp8: opp-1612800000 { 339 opp-hz = /bits/ 64 <1612800000>; 340 opp-peak-kBps = <3072000 22118400>; 341 }; 342 343 cpu0_opp9: opp-1708800000 { 344 opp-hz = /bits/ 64 <1708800000>; 345 opp-peak-kBps = <4068000 23040000>; 346 }; 347 }; 348 349 cpu6_opp_table: opp-table-cpu6 { 350 compatible = "operating-points-v2"; 351 opp-shared; 352 353 cpu6_opp1: opp-300000000 { 354 opp-hz = /bits/ 64 <300000000>; 355 opp-peak-kBps = <400000 4800000>; 356 }; 357 358 cpu6_opp2: opp-652800000 { 359 opp-hz = /bits/ 64 <652800000>; 360 opp-peak-kBps = <400000 4800000>; 361 }; 362 363 cpu6_opp3: opp-825600000 { 364 opp-hz = /bits/ 64 <825600000>; 365 opp-peak-kBps = <1200000 4800000>; 366 }; 367 368 cpu6_opp4: opp-979200000 { 369 opp-hz = /bits/ 64 <979200000>; 370 opp-peak-kBps = <1200000 4800000>; 371 }; 372 373 cpu6_opp5: opp-1132800000 { 374 opp-hz = /bits/ 64 <1132800000>; 375 opp-peak-kBps = <2188000 8908800>; 376 }; 377 378 cpu6_opp6: opp-1363200000 { 379 opp-hz = /bits/ 64 <1363200000>; 380 opp-peak-kBps = <4068000 12902400>; 381 }; 382 383 cpu6_opp7: opp-1536000000 { 384 opp-hz = /bits/ 64 <1536000000>; 385 opp-peak-kBps = <4068000 12902400>; 386 }; 387 388 cpu6_opp8: opp-1747200000 { 389 opp-hz = /bits/ 64 <1747200000>; 390 opp-peak-kBps = <4068000 15052800>; 391 }; 392 393 cpu6_opp9: opp-1843200000 { 394 opp-hz = /bits/ 64 <1843200000>; 395 opp-peak-kBps = <4068000 15052800>; 396 }; 397 398 cpu6_opp10: opp-1996800000 { 399 opp-hz = /bits/ 64 <1996800000>; 400 opp-peak-kBps = <6220000 19046400>; 401 }; 402 }; 403 404 dsi_opp_table: opp-table-dsi { 405 compatible = "operating-points-v2"; 406 407 opp-19200000 { 408 opp-hz = /bits/ 64 <19200000>; 409 required-opps = <&rpmhpd_opp_min_svs>; 410 }; 411 412 opp-180000000 { 413 opp-hz = /bits/ 64 <180000000>; 414 required-opps = <&rpmhpd_opp_low_svs>; 415 }; 416 417 opp-275000000 { 418 opp-hz = /bits/ 64 <275000000>; 419 required-opps = <&rpmhpd_opp_svs>; 420 }; 421 422 opp-358000000 { 423 opp-hz = /bits/ 64 <358000000>; 424 required-opps = <&rpmhpd_opp_svs_l1>; 425 }; 426 }; 427 428 psci { 429 compatible = "arm,psci-1.0"; 430 method = "smc"; 431 432 cpu_pd0: power-domain-cpu0 { 433 #power-domain-cells = <0>; 434 power-domains = <&cluster_pd>; 435 domain-idle-states = <&little_cpu_sleep_0>; 436 }; 437 438 cpu_pd1: power-domain-cpu1 { 439 #power-domain-cells = <0>; 440 power-domains = <&cluster_pd>; 441 domain-idle-states = <&little_cpu_sleep_0>; 442 }; 443 444 cpu_pd2: power-domain-cpu2 { 445 #power-domain-cells = <0>; 446 power-domains = <&cluster_pd>; 447 domain-idle-states = <&little_cpu_sleep_0>; 448 }; 449 450 cpu_pd3: power-domain-cpu3 { 451 #power-domain-cells = <0>; 452 power-domains = <&cluster_pd>; 453 domain-idle-states = <&little_cpu_sleep_0>; 454 }; 455 456 cpu_pd4: power-domain-cpu4 { 457 #power-domain-cells = <0>; 458 power-domains = <&cluster_pd>; 459 domain-idle-states = <&little_cpu_sleep_0>; 460 }; 461 462 cpu_pd5: power-domain-cpu5 { 463 #power-domain-cells = <0>; 464 power-domains = <&cluster_pd>; 465 domain-idle-states = <&little_cpu_sleep_0>; 466 }; 467 468 cpu_pd6: power-domain-cpu6 { 469 #power-domain-cells = <0>; 470 power-domains = <&cluster_pd>; 471 domain-idle-states = <&big_cpu_sleep_0>; 472 }; 473 474 cpu_pd7: power-domain-cpu7 { 475 #power-domain-cells = <0>; 476 power-domains = <&cluster_pd>; 477 domain-idle-states = <&big_cpu_sleep_0>; 478 }; 479 480 cluster_pd: power-domain-cluster { 481 #power-domain-cells = <0>; 482 domain-idle-states = <&cluster_sleep_0>; 483 }; 484 }; 485 486 reserved-memory { 487 #address-cells = <2>; 488 #size-cells = <2>; 489 ranges; 490 491 hyp_mem: hyp-mem@85700000 { 492 reg = <0 0x85700000 0 0x600000>; 493 no-map; 494 }; 495 496 xbl_mem: xbl-mem@85e00000 { 497 reg = <0 0x85e00000 0 0x100000>; 498 no-map; 499 }; 500 501 aop_mem: aop-mem@85fc0000 { 502 reg = <0 0x85fc0000 0 0x20000>; 503 no-map; 504 }; 505 506 aop_cmd_db_mem: aop-cmd-db-mem@85fe0000 { 507 compatible = "qcom,cmd-db"; 508 reg = <0 0x85fe0000 0 0x20000>; 509 no-map; 510 }; 511 512 smem@86000000 { 513 compatible = "qcom,smem"; 514 reg = <0 0x86000000 0 0x200000>; 515 no-map; 516 hwlocks = <&tcsr_mutex 3>; 517 }; 518 519 tz_mem: tz@86200000 { 520 reg = <0 0x86200000 0 0x2d00000>; 521 no-map; 522 }; 523 524 camera_mem: camera-mem@8ab00000 { 525 reg = <0 0x8ab00000 0 0x500000>; 526 no-map; 527 }; 528 529 mpss_region: mpss@8b000000 { 530 reg = <0 0x8b000000 0 0x7e00000>; 531 no-map; 532 }; 533 534 venus_mem: venus@92e00000 { 535 reg = <0 0x92e00000 0 0x500000>; 536 no-map; 537 }; 538 539 wlan_msa_mem: wlan-msa@93300000 { 540 reg = <0 0x93300000 0 0x100000>; 541 no-map; 542 }; 543 544 cdsp_mem: cdsp@93400000 { 545 reg = <0 0x93400000 0 0x800000>; 546 no-map; 547 }; 548 549 mba_region: mba@93c00000 { 550 reg = <0 0x93c00000 0 0x200000>; 551 no-map; 552 }; 553 554 adsp_mem: adsp@93e00000 { 555 reg = <0 0x93e00000 0 0x1e00000>; 556 no-map; 557 }; 558 559 ipa_fw_mem: ipa-fw@95c00000 { 560 reg = <0 0x95c00000 0 0x10000>; 561 no-map; 562 }; 563 564 ipa_gsi_mem: ipa-gsi@95c10000 { 565 reg = <0 0x95c10000 0 0x5000>; 566 no-map; 567 }; 568 569 gpu_mem: gpu@95c15000 { 570 reg = <0 0x95c15000 0 0x2000>; 571 no-map; 572 }; 573 574 spss_mem: spss@97b00000 { 575 reg = <0 0x97b00000 0 0x100000>; 576 no-map; 577 }; 578 579 qseecom_mem: qseecom@9e400000 { 580 reg = <0 0x9e400000 0 0x1400000>; 581 no-map; 582 }; 583 }; 584 585 timer { 586 compatible = "arm,armv8-timer"; 587 interrupts = <GIC_PPI 1 IRQ_TYPE_LEVEL_LOW>, 588 <GIC_PPI 2 IRQ_TYPE_LEVEL_LOW>, 589 <GIC_PPI 3 IRQ_TYPE_LEVEL_LOW>, 590 <GIC_PPI 0 IRQ_TYPE_LEVEL_LOW>; 591 }; 592 593 soc: soc@0 { 594 #address-cells = <2>; 595 #size-cells = <2>; 596 ranges = <0 0 0 0 0x10 0>; 597 dma-ranges = <0 0 0 0 0x10 0>; 598 compatible = "simple-bus"; 599 600 gcc: clock-controller@100000 { 601 compatible = "qcom,gcc-sdm670"; 602 reg = <0 0x00100000 0 0x1f0000>; 603 clocks = <&rpmhcc RPMH_CXO_CLK>, 604 <&rpmhcc RPMH_CXO_CLK_A>, 605 <&sleep_clk>; 606 clock-names = "bi_tcxo", 607 "bi_tcxo_ao", 608 "sleep_clk"; 609 #clock-cells = <1>; 610 #reset-cells = <1>; 611 #power-domain-cells = <1>; 612 }; 613 614 qfprom: qfprom@784000 { 615 compatible = "qcom,sdm670-qfprom", "qcom,qfprom"; 616 reg = <0 0x00784000 0 0x1000>; 617 #address-cells = <1>; 618 #size-cells = <1>; 619 620 qusb2_hstx_trim: hstx-trim@1eb { 621 reg = <0x1eb 0x1>; 622 bits = <1 4>; 623 }; 624 }; 625 626 sdhc_1: mmc@7c4000 { 627 compatible = "qcom,sdm670-sdhci", "qcom,sdhci-msm-v5"; 628 reg = <0 0x007c4000 0 0x1000>, 629 <0 0x007c5000 0 0x1000>, 630 <0 0x007c8000 0 0x8000>; 631 reg-names = "hc", "cqhci", "ice"; 632 633 interrupts = <GIC_SPI 641 IRQ_TYPE_LEVEL_HIGH>, 634 <GIC_SPI 644 IRQ_TYPE_LEVEL_HIGH>; 635 interrupt-names = "hc_irq", "pwr_irq"; 636 637 clocks = <&gcc GCC_SDCC1_AHB_CLK>, 638 <&gcc GCC_SDCC1_APPS_CLK>, 639 <&rpmhcc RPMH_CXO_CLK>, 640 <&gcc GCC_SDCC1_ICE_CORE_CLK>, 641 <&gcc GCC_AGGRE_UFS_PHY_AXI_CLK>; 642 clock-names = "iface", "core", "xo", "ice", "bus"; 643 interconnects = <&aggre1_noc MASTER_EMMC 0 &aggre1_noc SLAVE_A1NOC_SNOC 0>, 644 <&gladiator_noc MASTER_AMPSS_M0 0 &config_noc SLAVE_EMMC_CFG 0>; 645 interconnect-names = "sdhc-ddr", "cpu-sdhc"; 646 operating-points-v2 = <&sdhc1_opp_table>; 647 648 iommus = <&apps_smmu 0x140 0xf>; 649 650 pinctrl-names = "default", "sleep"; 651 pinctrl-0 = <&sdc1_state_on>; 652 pinctrl-1 = <&sdc1_state_off>; 653 power-domains = <&rpmhpd SDM670_CX>; 654 655 bus-width = <8>; 656 non-removable; 657 658 status = "disabled"; 659 660 sdhc1_opp_table: opp-table { 661 compatible = "operating-points-v2"; 662 663 opp-20000000 { 664 opp-hz = /bits/ 64 <20000000>; 665 required-opps = <&rpmhpd_opp_min_svs>; 666 opp-peak-kBps = <80000 80000>; 667 opp-avg-kBps = <52286 80000>; 668 }; 669 670 opp-50000000 { 671 opp-hz = /bits/ 64 <50000000>; 672 required-opps = <&rpmhpd_opp_low_svs>; 673 opp-peak-kBps = <200000 100000>; 674 opp-avg-kBps = <130718 100000>; 675 }; 676 677 opp-100000000 { 678 opp-hz = /bits/ 64 <100000000>; 679 required-opps = <&rpmhpd_opp_svs>; 680 opp-peak-kBps = <200000 130000>; 681 opp-avg-kBps = <130718 130000>; 682 }; 683 684 opp-384000000 { 685 opp-hz = /bits/ 64 <384000000>; 686 required-opps = <&rpmhpd_opp_nom>; 687 opp-peak-kBps = <4096000 4096000>; 688 opp-avg-kBps = <1338562 1338562>; 689 }; 690 }; 691 }; 692 693 gpi_dma0: dma-controller@800000 { 694 #dma-cells = <3>; 695 compatible = "qcom,sdm670-gpi-dma", "qcom,sdm845-gpi-dma"; 696 reg = <0 0x00800000 0 0x60000>; 697 interrupts = <GIC_SPI 244 IRQ_TYPE_LEVEL_HIGH>, 698 <GIC_SPI 245 IRQ_TYPE_LEVEL_HIGH>, 699 <GIC_SPI 246 IRQ_TYPE_LEVEL_HIGH>, 700 <GIC_SPI 247 IRQ_TYPE_LEVEL_HIGH>, 701 <GIC_SPI 248 IRQ_TYPE_LEVEL_HIGH>, 702 <GIC_SPI 249 IRQ_TYPE_LEVEL_HIGH>, 703 <GIC_SPI 250 IRQ_TYPE_LEVEL_HIGH>, 704 <GIC_SPI 251 IRQ_TYPE_LEVEL_HIGH>, 705 <GIC_SPI 252 IRQ_TYPE_LEVEL_HIGH>, 706 <GIC_SPI 253 IRQ_TYPE_LEVEL_HIGH>, 707 <GIC_SPI 254 IRQ_TYPE_LEVEL_HIGH>, 708 <GIC_SPI 255 IRQ_TYPE_LEVEL_HIGH>, 709 <GIC_SPI 256 IRQ_TYPE_LEVEL_HIGH>; 710 dma-channels = <13>; 711 dma-channel-mask = <0xfa>; 712 iommus = <&apps_smmu 0x16 0x0>; 713 status = "disabled"; 714 }; 715 716 qupv3_id_0: geniqup@8c0000 { 717 compatible = "qcom,geni-se-qup"; 718 reg = <0 0x008c0000 0 0x6000>; 719 clock-names = "m-ahb", "s-ahb"; 720 clocks = <&gcc GCC_QUPV3_WRAP_0_M_AHB_CLK>, 721 <&gcc GCC_QUPV3_WRAP_0_S_AHB_CLK>; 722 iommus = <&apps_smmu 0x3 0x0>; 723 #address-cells = <2>; 724 #size-cells = <2>; 725 ranges; 726 interconnects = <&aggre1_noc MASTER_BLSP_1 0 &config_noc SLAVE_BLSP_1 0>; 727 interconnect-names = "qup-core"; 728 status = "disabled"; 729 730 i2c0: i2c@880000 { 731 compatible = "qcom,geni-i2c"; 732 reg = <0 0x00880000 0 0x4000>; 733 clock-names = "se"; 734 clocks = <&gcc GCC_QUPV3_WRAP0_S0_CLK>; 735 pinctrl-names = "default"; 736 pinctrl-0 = <&qup_i2c0_default>; 737 interrupts = <GIC_SPI 601 IRQ_TYPE_LEVEL_HIGH>; 738 #address-cells = <1>; 739 #size-cells = <0>; 740 power-domains = <&rpmhpd SDM670_CX>; 741 interconnects = <&aggre1_noc MASTER_BLSP_1 0 &config_noc SLAVE_BLSP_1 0>, 742 <&gladiator_noc MASTER_AMPSS_M0 0 &config_noc SLAVE_BLSP_1 0>, 743 <&aggre1_noc MASTER_BLSP_1 0 &mem_noc SLAVE_EBI_CH0 0>; 744 interconnect-names = "qup-core", "qup-config", "qup-memory"; 745 dmas = <&gpi_dma0 0 0 QCOM_GPI_I2C>, 746 <&gpi_dma0 1 0 QCOM_GPI_I2C>; 747 dma-names = "tx", "rx"; 748 status = "disabled"; 749 }; 750 751 i2c1: i2c@884000 { 752 compatible = "qcom,geni-i2c"; 753 reg = <0 0x00884000 0 0x4000>; 754 clock-names = "se"; 755 clocks = <&gcc GCC_QUPV3_WRAP0_S1_CLK>; 756 pinctrl-names = "default"; 757 pinctrl-0 = <&qup_i2c1_default>; 758 interrupts = <GIC_SPI 602 IRQ_TYPE_LEVEL_HIGH>; 759 #address-cells = <1>; 760 #size-cells = <0>; 761 power-domains = <&rpmhpd SDM670_CX>; 762 interconnects = <&aggre1_noc MASTER_BLSP_1 0 &config_noc SLAVE_BLSP_1 0>, 763 <&gladiator_noc MASTER_AMPSS_M0 0 &config_noc SLAVE_BLSP_1 0>, 764 <&aggre1_noc MASTER_BLSP_1 0 &mem_noc SLAVE_EBI_CH0 0>; 765 interconnect-names = "qup-core", "qup-config", "qup-memory"; 766 dmas = <&gpi_dma0 0 1 QCOM_GPI_I2C>, 767 <&gpi_dma0 1 1 QCOM_GPI_I2C>; 768 dma-names = "tx", "rx"; 769 status = "disabled"; 770 }; 771 772 i2c2: i2c@888000 { 773 compatible = "qcom,geni-i2c"; 774 reg = <0 0x00888000 0 0x4000>; 775 clock-names = "se"; 776 clocks = <&gcc GCC_QUPV3_WRAP0_S2_CLK>; 777 pinctrl-names = "default"; 778 pinctrl-0 = <&qup_i2c2_default>; 779 interrupts = <GIC_SPI 603 IRQ_TYPE_LEVEL_HIGH>; 780 #address-cells = <1>; 781 #size-cells = <0>; 782 power-domains = <&rpmhpd SDM670_CX>; 783 interconnects = <&aggre1_noc MASTER_BLSP_1 0 &config_noc SLAVE_BLSP_1 0>, 784 <&gladiator_noc MASTER_AMPSS_M0 0 &config_noc SLAVE_BLSP_1 0>, 785 <&aggre1_noc MASTER_BLSP_1 0 &mem_noc SLAVE_EBI_CH0 0>; 786 interconnect-names = "qup-core", "qup-config", "qup-memory"; 787 dmas = <&gpi_dma0 0 2 QCOM_GPI_I2C>, 788 <&gpi_dma0 1 2 QCOM_GPI_I2C>; 789 dma-names = "tx", "rx"; 790 status = "disabled"; 791 }; 792 793 i2c3: i2c@88c000 { 794 compatible = "qcom,geni-i2c"; 795 reg = <0 0x0088c000 0 0x4000>; 796 clock-names = "se"; 797 clocks = <&gcc GCC_QUPV3_WRAP0_S3_CLK>; 798 pinctrl-names = "default"; 799 pinctrl-0 = <&qup_i2c3_default>; 800 interrupts = <GIC_SPI 604 IRQ_TYPE_LEVEL_HIGH>; 801 #address-cells = <1>; 802 #size-cells = <0>; 803 power-domains = <&rpmhpd SDM670_CX>; 804 interconnects = <&aggre1_noc MASTER_BLSP_1 0 &config_noc SLAVE_BLSP_1 0>, 805 <&gladiator_noc MASTER_AMPSS_M0 0 &config_noc SLAVE_BLSP_1 0>, 806 <&aggre1_noc MASTER_BLSP_1 0 &mem_noc SLAVE_EBI_CH0 0>; 807 interconnect-names = "qup-core", "qup-config", "qup-memory"; 808 dmas = <&gpi_dma0 0 3 QCOM_GPI_I2C>, 809 <&gpi_dma0 1 3 QCOM_GPI_I2C>; 810 dma-names = "tx", "rx"; 811 status = "disabled"; 812 }; 813 814 i2c4: i2c@890000 { 815 compatible = "qcom,geni-i2c"; 816 reg = <0 0x00890000 0 0x4000>; 817 clock-names = "se"; 818 clocks = <&gcc GCC_QUPV3_WRAP0_S4_CLK>; 819 pinctrl-names = "default"; 820 pinctrl-0 = <&qup_i2c4_default>; 821 interrupts = <GIC_SPI 605 IRQ_TYPE_LEVEL_HIGH>; 822 #address-cells = <1>; 823 #size-cells = <0>; 824 power-domains = <&rpmhpd SDM670_CX>; 825 interconnects = <&aggre1_noc MASTER_BLSP_1 0 &config_noc SLAVE_BLSP_1 0>, 826 <&gladiator_noc MASTER_AMPSS_M0 0 &config_noc SLAVE_BLSP_1 0>, 827 <&aggre1_noc MASTER_BLSP_1 0 &mem_noc SLAVE_EBI_CH0 0>; 828 interconnect-names = "qup-core", "qup-config", "qup-memory"; 829 dmas = <&gpi_dma0 0 4 QCOM_GPI_I2C>, 830 <&gpi_dma0 1 4 QCOM_GPI_I2C>; 831 dma-names = "tx", "rx"; 832 status = "disabled"; 833 }; 834 835 i2c5: i2c@894000 { 836 compatible = "qcom,geni-i2c"; 837 reg = <0 0x00894000 0 0x4000>; 838 clock-names = "se"; 839 clocks = <&gcc GCC_QUPV3_WRAP0_S5_CLK>; 840 pinctrl-names = "default"; 841 pinctrl-0 = <&qup_i2c5_default>; 842 interrupts = <GIC_SPI 606 IRQ_TYPE_LEVEL_HIGH>; 843 #address-cells = <1>; 844 #size-cells = <0>; 845 power-domains = <&rpmhpd SDM670_CX>; 846 interconnects = <&aggre1_noc MASTER_BLSP_1 0 &config_noc SLAVE_BLSP_1 0>, 847 <&gladiator_noc MASTER_AMPSS_M0 0 &config_noc SLAVE_BLSP_1 0>, 848 <&aggre1_noc MASTER_BLSP_1 0 &mem_noc SLAVE_EBI_CH0 0>; 849 interconnect-names = "qup-core", "qup-config", "qup-memory"; 850 dmas = <&gpi_dma0 0 5 QCOM_GPI_I2C>, 851 <&gpi_dma0 1 5 QCOM_GPI_I2C>; 852 dma-names = "tx", "rx"; 853 status = "disabled"; 854 }; 855 856 i2c6: i2c@898000 { 857 compatible = "qcom,geni-i2c"; 858 reg = <0 0x00898000 0 0x4000>; 859 clock-names = "se"; 860 clocks = <&gcc GCC_QUPV3_WRAP0_S6_CLK>; 861 pinctrl-names = "default"; 862 pinctrl-0 = <&qup_i2c6_default>; 863 interrupts = <GIC_SPI 607 IRQ_TYPE_LEVEL_HIGH>; 864 #address-cells = <1>; 865 #size-cells = <0>; 866 power-domains = <&rpmhpd SDM670_CX>; 867 interconnects = <&aggre1_noc MASTER_BLSP_1 0 &config_noc SLAVE_BLSP_1 0>, 868 <&gladiator_noc MASTER_AMPSS_M0 0 &config_noc SLAVE_BLSP_1 0>, 869 <&aggre1_noc MASTER_BLSP_1 0 &mem_noc SLAVE_EBI_CH0 0>; 870 interconnect-names = "qup-core", "qup-config", "qup-memory"; 871 dmas = <&gpi_dma0 0 6 QCOM_GPI_I2C>, 872 <&gpi_dma0 1 6 QCOM_GPI_I2C>; 873 dma-names = "tx", "rx"; 874 status = "disabled"; 875 }; 876 877 i2c7: i2c@89c000 { 878 compatible = "qcom,geni-i2c"; 879 reg = <0 0x0089c000 0 0x4000>; 880 clock-names = "se"; 881 clocks = <&gcc GCC_QUPV3_WRAP0_S7_CLK>; 882 pinctrl-names = "default"; 883 pinctrl-0 = <&qup_i2c7_default>; 884 interrupts = <GIC_SPI 608 IRQ_TYPE_LEVEL_HIGH>; 885 #address-cells = <1>; 886 #size-cells = <0>; 887 power-domains = <&rpmhpd SDM670_CX>; 888 interconnects = <&aggre1_noc MASTER_BLSP_1 0 &config_noc SLAVE_BLSP_1 0>, 889 <&gladiator_noc MASTER_AMPSS_M0 0 &config_noc SLAVE_BLSP_1 0>, 890 <&aggre1_noc MASTER_BLSP_1 0 &mem_noc SLAVE_EBI_CH0 0>; 891 interconnect-names = "qup-core", "qup-config", "qup-memory"; 892 dmas = <&gpi_dma0 0 7 QCOM_GPI_I2C>, 893 <&gpi_dma0 1 7 QCOM_GPI_I2C>; 894 dma-names = "tx", "rx"; 895 status = "disabled"; 896 }; 897 }; 898 899 gpi_dma1: dma-controller@a00000 { 900 #dma-cells = <3>; 901 compatible = "qcom,sdm670-gpi-dma", "qcom,sdm845-gpi-dma"; 902 reg = <0 0x00a00000 0 0x60000>; 903 interrupts = <GIC_SPI 279 IRQ_TYPE_LEVEL_HIGH>, 904 <GIC_SPI 280 IRQ_TYPE_LEVEL_HIGH>, 905 <GIC_SPI 281 IRQ_TYPE_LEVEL_HIGH>, 906 <GIC_SPI 282 IRQ_TYPE_LEVEL_HIGH>, 907 <GIC_SPI 283 IRQ_TYPE_LEVEL_HIGH>, 908 <GIC_SPI 284 IRQ_TYPE_LEVEL_HIGH>, 909 <GIC_SPI 293 IRQ_TYPE_LEVEL_HIGH>, 910 <GIC_SPI 294 IRQ_TYPE_LEVEL_HIGH>, 911 <GIC_SPI 295 IRQ_TYPE_LEVEL_HIGH>, 912 <GIC_SPI 296 IRQ_TYPE_LEVEL_HIGH>, 913 <GIC_SPI 297 IRQ_TYPE_LEVEL_HIGH>, 914 <GIC_SPI 298 IRQ_TYPE_LEVEL_HIGH>, 915 <GIC_SPI 299 IRQ_TYPE_LEVEL_HIGH>; 916 dma-channels = <13>; 917 dma-channel-mask = <0xfa>; 918 iommus = <&apps_smmu 0x6d6 0x0>; 919 status = "disabled"; 920 }; 921 922 qupv3_id_1: geniqup@ac0000 { 923 compatible = "qcom,geni-se-qup"; 924 reg = <0 0x00ac0000 0 0x6000>; 925 clock-names = "m-ahb", "s-ahb"; 926 clocks = <&gcc GCC_QUPV3_WRAP_1_M_AHB_CLK>, 927 <&gcc GCC_QUPV3_WRAP_1_S_AHB_CLK>; 928 iommus = <&apps_smmu 0x6c3 0x0>; 929 #address-cells = <2>; 930 #size-cells = <2>; 931 ranges; 932 interconnects = <&aggre2_noc MASTER_BLSP_2 0 &config_noc SLAVE_BLSP_2 0>; 933 interconnect-names = "qup-core"; 934 status = "disabled"; 935 936 i2c8: i2c@a80000 { 937 compatible = "qcom,geni-i2c"; 938 reg = <0 0x00a80000 0 0x4000>; 939 clock-names = "se"; 940 clocks = <&gcc GCC_QUPV3_WRAP1_S0_CLK>; 941 pinctrl-names = "default"; 942 pinctrl-0 = <&qup_i2c8_default>; 943 interrupts = <GIC_SPI 353 IRQ_TYPE_LEVEL_HIGH>; 944 #address-cells = <1>; 945 #size-cells = <0>; 946 power-domains = <&rpmhpd SDM670_CX>; 947 interconnects = <&aggre2_noc MASTER_BLSP_2 0 &config_noc SLAVE_BLSP_2 0>, 948 <&gladiator_noc MASTER_AMPSS_M0 0 &config_noc SLAVE_BLSP_2 0>, 949 <&aggre2_noc MASTER_BLSP_2 0 &mem_noc SLAVE_EBI_CH0 0>; 950 interconnect-names = "qup-core", "qup-config", "qup-memory"; 951 dmas = <&gpi_dma1 0 0 QCOM_GPI_I2C>, 952 <&gpi_dma1 1 0 QCOM_GPI_I2C>; 953 dma-names = "tx", "rx"; 954 status = "disabled"; 955 }; 956 957 i2c9: i2c@a84000 { 958 compatible = "qcom,geni-i2c"; 959 reg = <0 0x00a84000 0 0x4000>; 960 clock-names = "se"; 961 clocks = <&gcc GCC_QUPV3_WRAP1_S1_CLK>; 962 pinctrl-names = "default"; 963 pinctrl-0 = <&qup_i2c9_default>; 964 interrupts = <GIC_SPI 354 IRQ_TYPE_LEVEL_HIGH>; 965 #address-cells = <1>; 966 #size-cells = <0>; 967 power-domains = <&rpmhpd SDM670_CX>; 968 interconnects = <&aggre2_noc MASTER_BLSP_2 0 &config_noc SLAVE_BLSP_2 0>, 969 <&gladiator_noc MASTER_AMPSS_M0 0 &config_noc SLAVE_BLSP_2 0>, 970 <&aggre2_noc MASTER_BLSP_2 0 &mem_noc SLAVE_EBI_CH0 0>; 971 interconnect-names = "qup-core", "qup-config", "qup-memory"; 972 dmas = <&gpi_dma1 0 1 QCOM_GPI_I2C>, 973 <&gpi_dma1 1 1 QCOM_GPI_I2C>; 974 dma-names = "tx", "rx"; 975 status = "disabled"; 976 }; 977 978 i2c10: i2c@a88000 { 979 compatible = "qcom,geni-i2c"; 980 reg = <0 0x00a88000 0 0x4000>; 981 clock-names = "se"; 982 clocks = <&gcc GCC_QUPV3_WRAP1_S2_CLK>; 983 pinctrl-names = "default"; 984 pinctrl-0 = <&qup_i2c10_default>; 985 interrupts = <GIC_SPI 355 IRQ_TYPE_LEVEL_HIGH>; 986 #address-cells = <1>; 987 #size-cells = <0>; 988 power-domains = <&rpmhpd SDM670_CX>; 989 interconnects = <&aggre2_noc MASTER_BLSP_2 0 &config_noc SLAVE_BLSP_2 0>, 990 <&gladiator_noc MASTER_AMPSS_M0 0 &config_noc SLAVE_BLSP_2 0>, 991 <&aggre2_noc MASTER_BLSP_2 0 &mem_noc SLAVE_EBI_CH0 0>; 992 interconnect-names = "qup-core", "qup-config", "qup-memory"; 993 dmas = <&gpi_dma1 0 2 QCOM_GPI_I2C>, 994 <&gpi_dma1 1 2 QCOM_GPI_I2C>; 995 dma-names = "tx", "rx"; 996 status = "disabled"; 997 }; 998 999 i2c11: i2c@a8c000 { 1000 compatible = "qcom,geni-i2c"; 1001 reg = <0 0x00a8c000 0 0x4000>; 1002 clock-names = "se"; 1003 clocks = <&gcc GCC_QUPV3_WRAP1_S3_CLK>; 1004 pinctrl-names = "default"; 1005 pinctrl-0 = <&qup_i2c11_default>; 1006 interrupts = <GIC_SPI 356 IRQ_TYPE_LEVEL_HIGH>; 1007 #address-cells = <1>; 1008 #size-cells = <0>; 1009 power-domains = <&rpmhpd SDM670_CX>; 1010 interconnects = <&aggre2_noc MASTER_BLSP_2 0 &config_noc SLAVE_BLSP_2 0>, 1011 <&gladiator_noc MASTER_AMPSS_M0 0 &config_noc SLAVE_BLSP_2 0>, 1012 <&aggre2_noc MASTER_BLSP_2 0 &mem_noc SLAVE_EBI_CH0 0>; 1013 interconnect-names = "qup-core", "qup-config", "qup-memory"; 1014 dmas = <&gpi_dma1 0 3 QCOM_GPI_I2C>, 1015 <&gpi_dma1 1 3 QCOM_GPI_I2C>; 1016 dma-names = "tx", "rx"; 1017 status = "disabled"; 1018 }; 1019 1020 i2c12: i2c@a90000 { 1021 compatible = "qcom,geni-i2c"; 1022 reg = <0 0x00a90000 0 0x4000>; 1023 clock-names = "se"; 1024 clocks = <&gcc GCC_QUPV3_WRAP1_S4_CLK>; 1025 pinctrl-names = "default"; 1026 pinctrl-0 = <&qup_i2c12_default>; 1027 interrupts = <GIC_SPI 357 IRQ_TYPE_LEVEL_HIGH>; 1028 #address-cells = <1>; 1029 #size-cells = <0>; 1030 power-domains = <&rpmhpd SDM670_CX>; 1031 interconnects = <&aggre2_noc MASTER_BLSP_2 0 &config_noc SLAVE_BLSP_2 0>, 1032 <&gladiator_noc MASTER_AMPSS_M0 0 &config_noc SLAVE_BLSP_2 0>, 1033 <&aggre2_noc MASTER_BLSP_2 0 &mem_noc SLAVE_EBI_CH0 0>; 1034 interconnect-names = "qup-core", "qup-config", "qup-memory"; 1035 dmas = <&gpi_dma1 0 4 QCOM_GPI_I2C>, 1036 <&gpi_dma1 1 4 QCOM_GPI_I2C>; 1037 dma-names = "tx", "rx"; 1038 status = "disabled"; 1039 }; 1040 1041 i2c13: i2c@a94000 { 1042 compatible = "qcom,geni-i2c"; 1043 reg = <0 0x00a94000 0 0x4000>; 1044 clock-names = "se"; 1045 clocks = <&gcc GCC_QUPV3_WRAP1_S5_CLK>; 1046 pinctrl-names = "default"; 1047 pinctrl-0 = <&qup_i2c13_default>; 1048 interrupts = <GIC_SPI 358 IRQ_TYPE_LEVEL_HIGH>; 1049 #address-cells = <1>; 1050 #size-cells = <0>; 1051 power-domains = <&rpmhpd SDM670_CX>; 1052 interconnects = <&aggre2_noc MASTER_BLSP_2 0 &config_noc SLAVE_BLSP_2 0>, 1053 <&gladiator_noc MASTER_AMPSS_M0 0 &config_noc SLAVE_BLSP_2 0>, 1054 <&aggre2_noc MASTER_BLSP_2 0 &mem_noc SLAVE_EBI_CH0 0>; 1055 interconnect-names = "qup-core", "qup-config", "qup-memory"; 1056 dmas = <&gpi_dma1 0 5 QCOM_GPI_I2C>, 1057 <&gpi_dma1 1 5 QCOM_GPI_I2C>; 1058 dma-names = "tx", "rx"; 1059 status = "disabled"; 1060 }; 1061 1062 i2c14: i2c@a98000 { 1063 compatible = "qcom,geni-i2c"; 1064 reg = <0 0x00a98000 0 0x4000>; 1065 clock-names = "se"; 1066 clocks = <&gcc GCC_QUPV3_WRAP1_S6_CLK>; 1067 pinctrl-names = "default"; 1068 pinctrl-0 = <&qup_i2c14_default>; 1069 interrupts = <GIC_SPI 359 IRQ_TYPE_LEVEL_HIGH>; 1070 #address-cells = <1>; 1071 #size-cells = <0>; 1072 power-domains = <&rpmhpd SDM670_CX>; 1073 interconnects = <&aggre2_noc MASTER_BLSP_2 0 &config_noc SLAVE_BLSP_2 0>, 1074 <&gladiator_noc MASTER_AMPSS_M0 0 &config_noc SLAVE_BLSP_2 0>, 1075 <&aggre2_noc MASTER_BLSP_2 0 &mem_noc SLAVE_EBI_CH0 0>; 1076 interconnect-names = "qup-core", "qup-config", "qup-memory"; 1077 dmas = <&gpi_dma1 0 6 QCOM_GPI_I2C>, 1078 <&gpi_dma1 1 6 QCOM_GPI_I2C>; 1079 dma-names = "tx", "rx"; 1080 status = "disabled"; 1081 }; 1082 1083 i2c15: i2c@a9c000 { 1084 compatible = "qcom,geni-i2c"; 1085 reg = <0 0x00a9c000 0 0x4000>; 1086 clock-names = "se"; 1087 clocks = <&gcc GCC_QUPV3_WRAP1_S7_CLK>; 1088 pinctrl-names = "default"; 1089 pinctrl-0 = <&qup_i2c15_default>; 1090 interrupts = <GIC_SPI 360 IRQ_TYPE_LEVEL_HIGH>; 1091 #address-cells = <1>; 1092 #size-cells = <0>; 1093 power-domains = <&rpmhpd SDM670_CX>; 1094 interconnects = <&aggre2_noc MASTER_BLSP_2 0 &config_noc SLAVE_BLSP_2 0>, 1095 <&gladiator_noc MASTER_AMPSS_M0 0 &config_noc SLAVE_BLSP_2 0>, 1096 <&aggre2_noc MASTER_BLSP_2 0 &mem_noc SLAVE_EBI_CH0 0>; 1097 interconnect-names = "qup-core", "qup-config", "qup-memory"; 1098 dmas = <&gpi_dma1 0 7 QCOM_GPI_I2C>, 1099 <&gpi_dma1 1 7 QCOM_GPI_I2C>; 1100 dma-names = "tx", "rx"; 1101 status = "disabled"; 1102 }; 1103 }; 1104 1105 mem_noc: interconnect@1380000 { 1106 compatible = "qcom,sdm670-mem-noc"; 1107 reg = <0 0x01380000 0 0x27200>; 1108 #interconnect-cells = <2>; 1109 qcom,bcm-voters = <&apps_bcm_voter>; 1110 }; 1111 1112 dc_noc: interconnect@14e0000 { 1113 compatible = "qcom,sdm670-dc-noc"; 1114 reg = <0 0x014e0000 0 0x400>; 1115 #interconnect-cells = <2>; 1116 qcom,bcm-voters = <&apps_bcm_voter>; 1117 }; 1118 1119 config_noc: interconnect@1500000 { 1120 compatible = "qcom,sdm670-config-noc"; 1121 reg = <0 0x01500000 0 0x5080>; 1122 #interconnect-cells = <2>; 1123 qcom,bcm-voters = <&apps_bcm_voter>; 1124 }; 1125 1126 system_noc: interconnect@1620000 { 1127 compatible = "qcom,sdm670-system-noc"; 1128 reg = <0 0x01620000 0 0x18080>; 1129 #interconnect-cells = <2>; 1130 qcom,bcm-voters = <&apps_bcm_voter>; 1131 }; 1132 1133 aggre1_noc: interconnect@16e0000 { 1134 compatible = "qcom,sdm670-aggre1-noc"; 1135 reg = <0 0x016e0000 0 0x15080>; 1136 #interconnect-cells = <2>; 1137 qcom,bcm-voters = <&apps_bcm_voter>; 1138 }; 1139 1140 aggre2_noc: interconnect@1700000 { 1141 compatible = "qcom,sdm670-aggre2-noc"; 1142 reg = <0 0x01700000 0 0x1f300>; 1143 #interconnect-cells = <2>; 1144 qcom,bcm-voters = <&apps_bcm_voter>; 1145 }; 1146 1147 mmss_noc: interconnect@1740000 { 1148 compatible = "qcom,sdm670-mmss-noc"; 1149 reg = <0 0x01740000 0 0x1c100>; 1150 #interconnect-cells = <2>; 1151 qcom,bcm-voters = <&apps_bcm_voter>; 1152 }; 1153 1154 tcsr_mutex: hwlock@1f40000 { 1155 compatible = "qcom,tcsr-mutex"; 1156 reg = <0 0x01f40000 0 0x20000>; 1157 #hwlock-cells = <1>; 1158 }; 1159 1160 tlmm: pinctrl@3400000 { 1161 compatible = "qcom,sdm670-tlmm"; 1162 reg = <0 0x03400000 0 0xc00000>; 1163 interrupts = <GIC_SPI 208 IRQ_TYPE_LEVEL_HIGH>; 1164 gpio-controller; 1165 #gpio-cells = <2>; 1166 interrupt-controller; 1167 #interrupt-cells = <2>; 1168 gpio-ranges = <&tlmm 0 0 151>; 1169 wakeup-parent = <&pdc>; 1170 1171 qup_i2c0_default: qup-i2c0-default-state { 1172 pins = "gpio0", "gpio1"; 1173 function = "qup0"; 1174 }; 1175 1176 qup_i2c1_default: qup-i2c1-default-state { 1177 pins = "gpio17", "gpio18"; 1178 function = "qup1"; 1179 }; 1180 1181 qup_i2c2_default: qup-i2c2-default-state { 1182 pins = "gpio27", "gpio28"; 1183 function = "qup2"; 1184 }; 1185 1186 qup_i2c3_default: qup-i2c3-default-state { 1187 pins = "gpio41", "gpio42"; 1188 function = "qup3"; 1189 }; 1190 1191 qup_i2c4_default: qup-i2c4-default-state { 1192 pins = "gpio89", "gpio90"; 1193 function = "qup4"; 1194 }; 1195 1196 qup_i2c5_default: qup-i2c5-default-state { 1197 pins = "gpio85", "gpio86"; 1198 function = "qup5"; 1199 }; 1200 1201 qup_i2c6_default: qup-i2c6-default-state { 1202 pins = "gpio45", "gpio46"; 1203 function = "qup6"; 1204 }; 1205 1206 qup_i2c7_default: qup-i2c7-default-state { 1207 pins = "gpio93", "gpio94"; 1208 function = "qup7"; 1209 }; 1210 1211 qup_i2c8_default: qup-i2c8-default-state { 1212 pins = "gpio65", "gpio66"; 1213 function = "qup8"; 1214 }; 1215 1216 qup_i2c9_default: qup-i2c9-default-state { 1217 pins = "gpio6", "gpio7"; 1218 function = "qup9"; 1219 }; 1220 1221 qup_i2c10_default: qup-i2c10-default-state { 1222 pins = "gpio55", "gpio56"; 1223 function = "qup10"; 1224 }; 1225 1226 qup_i2c11_default: qup-i2c11-default-state { 1227 pins = "gpio31", "gpio32"; 1228 function = "qup11"; 1229 }; 1230 1231 qup_i2c12_default: qup-i2c12-default-state { 1232 pins = "gpio49", "gpio50"; 1233 function = "qup12"; 1234 }; 1235 1236 qup_i2c13_default: qup-i2c13-default-state { 1237 pins = "gpio105", "gpio106"; 1238 function = "qup13"; 1239 }; 1240 1241 qup_i2c14_default: qup-i2c14-default-state { 1242 pins = "gpio33", "gpio34"; 1243 function = "qup14"; 1244 }; 1245 1246 qup_i2c15_default: qup-i2c15-default-state { 1247 pins = "gpio81", "gpio82"; 1248 function = "qup15"; 1249 }; 1250 1251 sdc1_state_on: sdc1-on-state { 1252 clk-pins { 1253 pins = "sdc1_clk"; 1254 bias-disable; 1255 drive-strength = <16>; 1256 }; 1257 1258 cmd-pins { 1259 pins = "sdc1_cmd"; 1260 bias-pull-up; 1261 drive-strength = <10>; 1262 }; 1263 1264 data-pins { 1265 pins = "sdc1_data"; 1266 bias-pull-up; 1267 drive-strength = <10>; 1268 }; 1269 1270 rclk-pins { 1271 pins = "sdc1_rclk"; 1272 bias-pull-down; 1273 }; 1274 }; 1275 1276 sdc1_state_off: sdc1-off-state { 1277 clk-pins { 1278 pins = "sdc1_clk"; 1279 bias-disable; 1280 drive-strength = <2>; 1281 }; 1282 1283 cmd-pins { 1284 pins = "sdc1_cmd"; 1285 bias-pull-up; 1286 drive-strength = <2>; 1287 }; 1288 1289 data-pins { 1290 pins = "sdc1_data"; 1291 bias-pull-up; 1292 drive-strength = <2>; 1293 }; 1294 1295 rclk-pins { 1296 pins = "sdc1_rclk"; 1297 bias-pull-down; 1298 }; 1299 }; 1300 }; 1301 1302 usb_1_hsphy: phy@88e2000 { 1303 compatible = "qcom,sdm670-qusb2-phy", "qcom,qusb2-v2-phy"; 1304 reg = <0 0x088e2000 0 0x400>; 1305 #phy-cells = <0>; 1306 1307 clocks = <&gcc GCC_USB_PHY_CFG_AHB2PHY_CLK>, 1308 <&rpmhcc RPMH_CXO_CLK>; 1309 clock-names = "cfg_ahb", "ref"; 1310 1311 resets = <&gcc GCC_QUSB2PHY_PRIM_BCR>; 1312 1313 nvmem-cells = <&qusb2_hstx_trim>; 1314 1315 status = "disabled"; 1316 }; 1317 1318 usb_1: usb@a6f8800 { 1319 compatible = "qcom,sdm670-dwc3", "qcom,dwc3"; 1320 reg = <0 0x0a6f8800 0 0x400>; 1321 #address-cells = <2>; 1322 #size-cells = <2>; 1323 ranges; 1324 dma-ranges; 1325 1326 clocks = <&gcc GCC_CFG_NOC_USB3_PRIM_AXI_CLK>, 1327 <&gcc GCC_USB30_PRIM_MASTER_CLK>, 1328 <&gcc GCC_AGGRE_USB3_PRIM_AXI_CLK>, 1329 <&gcc GCC_USB30_PRIM_SLEEP_CLK>, 1330 <&gcc GCC_USB30_PRIM_MOCK_UTMI_CLK>; 1331 clock-names = "cfg_noc", 1332 "core", 1333 "iface", 1334 "sleep", 1335 "mock_utmi"; 1336 1337 assigned-clocks = <&gcc GCC_USB30_PRIM_MOCK_UTMI_CLK>, 1338 <&gcc GCC_USB30_PRIM_MASTER_CLK>; 1339 assigned-clock-rates = <19200000>, <150000000>; 1340 1341 interrupts-extended = <&intc GIC_SPI 130 IRQ_TYPE_LEVEL_HIGH>, 1342 <&intc GIC_SPI 131 IRQ_TYPE_LEVEL_HIGH>, 1343 <&pdc 9 IRQ_TYPE_EDGE_BOTH>, 1344 <&pdc 8 IRQ_TYPE_EDGE_BOTH>, 1345 <&pdc 6 IRQ_TYPE_LEVEL_HIGH>; 1346 interrupt-names = "pwr_event", 1347 "hs_phy_irq", 1348 "dp_hs_phy_irq", 1349 "dm_hs_phy_irq", 1350 "ss_phy_irq"; 1351 1352 power-domains = <&gcc USB30_PRIM_GDSC>; 1353 1354 resets = <&gcc GCC_USB30_PRIM_BCR>; 1355 1356 interconnects = <&aggre2_noc MASTER_USB3 0 &mem_noc SLAVE_EBI_CH0 0>, 1357 <&gladiator_noc MASTER_AMPSS_M0 0 &config_noc SLAVE_USB3 0>; 1358 interconnect-names = "usb-ddr", "apps-usb"; 1359 1360 status = "disabled"; 1361 1362 usb_1_dwc3: usb@a600000 { 1363 compatible = "snps,dwc3"; 1364 reg = <0 0x0a600000 0 0xcd00>; 1365 interrupts = <GIC_SPI 133 IRQ_TYPE_LEVEL_HIGH>; 1366 iommus = <&apps_smmu 0x740 0>; 1367 snps,dis_u2_susphy_quirk; 1368 snps,dis_enblslpm_quirk; 1369 phys = <&usb_1_hsphy>; 1370 phy-names = "usb2-phy"; 1371 }; 1372 }; 1373 1374 pdc: interrupt-controller@b220000 { 1375 compatible = "qcom,sdm670-pdc", "qcom,pdc"; 1376 reg = <0 0x0b220000 0 0x30000>; 1377 qcom,pdc-ranges = <0 480 40>, <41 521 7>, <49 529 4>, 1378 <54 534 24>, <79 559 15>, <94 609 15>, 1379 <115 630 7>; 1380 #interrupt-cells = <2>; 1381 interrupt-parent = <&intc>; 1382 interrupt-controller; 1383 }; 1384 1385 spmi_bus: spmi@c440000 { 1386 compatible = "qcom,spmi-pmic-arb"; 1387 reg = <0 0x0c440000 0 0x1100>, 1388 <0 0x0c600000 0 0x2000000>, 1389 <0 0x0e600000 0 0x100000>, 1390 <0 0x0e700000 0 0xa0000>, 1391 <0 0x0c40a000 0 0x26000>; 1392 reg-names = "core", "chnls", "obsrvr", "intr", "cnfg"; 1393 interrupt-names = "periph_irq"; 1394 interrupts = <GIC_SPI 481 IRQ_TYPE_LEVEL_HIGH>; 1395 qcom,ee = <0>; 1396 qcom,channel = <0>; 1397 #address-cells = <2>; 1398 #size-cells = <0>; 1399 interrupt-controller; 1400 #interrupt-cells = <4>; 1401 }; 1402 1403 mdss: display-subsystem@ae00000 { 1404 compatible = "qcom,sdm670-mdss"; 1405 reg = <0 0x0ae00000 0 0x1000>; 1406 reg-names = "mdss"; 1407 1408 power-domains = <&dispcc MDSS_GDSC>; 1409 1410 clocks = <&dispcc DISP_CC_MDSS_AHB_CLK>, 1411 <&dispcc DISP_CC_MDSS_MDP_CLK>; 1412 clock-names = "iface", "core"; 1413 1414 interrupts = <GIC_SPI 83 IRQ_TYPE_LEVEL_HIGH>; 1415 interrupt-controller; 1416 #interrupt-cells = <1>; 1417 1418 interconnects = <&mmss_noc MASTER_MDP_PORT0 0 &mem_noc SLAVE_EBI_CH0 0>, 1419 <&mmss_noc MASTER_MDP_PORT1 0 &mem_noc SLAVE_EBI_CH0 0>; 1420 interconnect-names = "mdp0-mem", "mdp1-mem"; 1421 1422 iommus = <&apps_smmu 0x880 0x8>, 1423 <&apps_smmu 0xc80 0x8>; 1424 1425 #address-cells = <2>; 1426 #size-cells = <2>; 1427 ranges; 1428 1429 status = "disabled"; 1430 1431 mdss_mdp: display-controller@ae01000 { 1432 compatible = "qcom,sdm670-dpu"; 1433 reg = <0 0x0ae01000 0 0x8f000>, 1434 <0 0x0aeb0000 0 0x2008>; 1435 reg-names = "mdp", "vbif"; 1436 1437 clocks = <&gcc GCC_DISP_AXI_CLK>, 1438 <&dispcc DISP_CC_MDSS_AHB_CLK>, 1439 <&dispcc DISP_CC_MDSS_AXI_CLK>, 1440 <&dispcc DISP_CC_MDSS_MDP_CLK>, 1441 <&dispcc DISP_CC_MDSS_VSYNC_CLK>; 1442 clock-names = "gcc-bus", "iface", "bus", "core", "vsync"; 1443 1444 assigned-clocks = <&dispcc DISP_CC_MDSS_VSYNC_CLK>; 1445 assigned-clock-rates = <19200000>; 1446 operating-points-v2 = <&mdp_opp_table>; 1447 power-domains = <&rpmhpd SDM670_CX>; 1448 1449 interrupt-parent = <&mdss>; 1450 interrupts = <0>; 1451 1452 ports { 1453 #address-cells = <1>; 1454 #size-cells = <0>; 1455 1456 port@0 { 1457 reg = <0>; 1458 dpu_intf0_out: endpoint { 1459 remote-endpoint = <&mdss_dsi0_in>; 1460 }; 1461 }; 1462 1463 port@1 { 1464 reg = <1>; 1465 dpu_intf1_out: endpoint { 1466 remote-endpoint = <&mdss_dsi1_in>; 1467 }; 1468 }; 1469 }; 1470 1471 mdp_opp_table: opp-table { 1472 compatible = "operating-points-v2"; 1473 1474 opp-19200000 { 1475 opp-hz = /bits/ 64 <19200000>; 1476 required-opps = <&rpmhpd_opp_min_svs>; 1477 }; 1478 1479 opp-171428571 { 1480 opp-hz = /bits/ 64 <171428571>; 1481 required-opps = <&rpmhpd_opp_low_svs>; 1482 }; 1483 1484 opp-358000000 { 1485 opp-hz = /bits/ 64 <358000000>; 1486 required-opps = <&rpmhpd_opp_svs_l1>; 1487 }; 1488 1489 opp-430000000 { 1490 opp-hz = /bits/ 64 <430000000>; 1491 required-opps = <&rpmhpd_opp_nom>; 1492 }; 1493 }; 1494 }; 1495 1496 mdss_dsi0: dsi@ae94000 { 1497 compatible = "qcom,sdm670-dsi-ctrl", 1498 "qcom,mdss-dsi-ctrl"; 1499 reg = <0 0x0ae94000 0 0x400>; 1500 reg-names = "dsi_ctrl"; 1501 1502 interrupt-parent = <&mdss>; 1503 interrupts = <4>; 1504 1505 clocks = <&dispcc DISP_CC_MDSS_BYTE0_CLK>, 1506 <&dispcc DISP_CC_MDSS_BYTE0_INTF_CLK>, 1507 <&dispcc DISP_CC_MDSS_PCLK0_CLK>, 1508 <&dispcc DISP_CC_MDSS_ESC0_CLK>, 1509 <&dispcc DISP_CC_MDSS_AHB_CLK>, 1510 <&dispcc DISP_CC_MDSS_AXI_CLK>; 1511 clock-names = "byte", 1512 "byte_intf", 1513 "pixel", 1514 "core", 1515 "iface", 1516 "bus"; 1517 assigned-clocks = <&dispcc DISP_CC_MDSS_BYTE0_CLK_SRC>, 1518 <&dispcc DISP_CC_MDSS_PCLK0_CLK_SRC>; 1519 assigned-clock-parents = <&mdss_dsi0_phy 0>, 1520 <&mdss_dsi0_phy 1>; 1521 1522 operating-points-v2 = <&dsi_opp_table>; 1523 power-domains = <&rpmhpd SDM670_CX>; 1524 1525 phys = <&mdss_dsi0_phy>; 1526 1527 #address-cells = <1>; 1528 #size-cells = <0>; 1529 1530 status = "disabled"; 1531 1532 ports { 1533 #address-cells = <1>; 1534 #size-cells = <0>; 1535 1536 port@0 { 1537 reg = <0>; 1538 mdss_dsi0_in: endpoint { 1539 remote-endpoint = <&dpu_intf0_out>; 1540 }; 1541 }; 1542 1543 port@1 { 1544 reg = <1>; 1545 mdss_dsi0_out: endpoint { 1546 }; 1547 }; 1548 }; 1549 }; 1550 1551 mdss_dsi0_phy: phy@ae94400 { 1552 compatible = "qcom,dsi-phy-10nm"; 1553 reg = <0 0x0ae94400 0 0x200>, 1554 <0 0x0ae94600 0 0x280>, 1555 <0 0x0ae94a00 0 0x1e0>; 1556 reg-names = "dsi_phy", 1557 "dsi_phy_lane", 1558 "dsi_pll"; 1559 1560 #clock-cells = <1>; 1561 #phy-cells = <0>; 1562 1563 clocks = <&dispcc DISP_CC_MDSS_AHB_CLK>, 1564 <&rpmhcc RPMH_CXO_CLK>; 1565 clock-names = "iface", "ref"; 1566 1567 status = "disabled"; 1568 }; 1569 1570 mdss_dsi1: dsi@ae96000 { 1571 compatible = "qcom,sdm670-dsi-ctrl", 1572 "qcom,mdss-dsi-ctrl"; 1573 reg = <0 0x0ae96000 0 0x400>; 1574 reg-names = "dsi_ctrl"; 1575 1576 interrupt-parent = <&mdss>; 1577 interrupts = <5>; 1578 1579 clocks = <&dispcc DISP_CC_MDSS_BYTE1_CLK>, 1580 <&dispcc DISP_CC_MDSS_BYTE1_INTF_CLK>, 1581 <&dispcc DISP_CC_MDSS_PCLK1_CLK>, 1582 <&dispcc DISP_CC_MDSS_ESC1_CLK>, 1583 <&dispcc DISP_CC_MDSS_AHB_CLK>, 1584 <&dispcc DISP_CC_MDSS_AXI_CLK>; 1585 clock-names = "byte", 1586 "byte_intf", 1587 "pixel", 1588 "core", 1589 "iface", 1590 "bus"; 1591 assigned-clocks = <&dispcc DISP_CC_MDSS_BYTE1_CLK_SRC>, 1592 <&dispcc DISP_CC_MDSS_PCLK1_CLK_SRC>; 1593 assigned-clock-parents = <&mdss_dsi1_phy 0>, <&mdss_dsi1_phy 1>; 1594 1595 operating-points-v2 = <&dsi_opp_table>; 1596 power-domains = <&rpmhpd SDM670_CX>; 1597 1598 phys = <&mdss_dsi1_phy>; 1599 1600 #address-cells = <1>; 1601 #size-cells = <0>; 1602 1603 status = "disabled"; 1604 1605 ports { 1606 #address-cells = <1>; 1607 #size-cells = <0>; 1608 1609 port@0 { 1610 reg = <0>; 1611 mdss_dsi1_in: endpoint { 1612 remote-endpoint = <&dpu_intf1_out>; 1613 }; 1614 }; 1615 1616 port@1 { 1617 reg = <1>; 1618 mdss_dsi1_out: endpoint { 1619 }; 1620 }; 1621 }; 1622 }; 1623 1624 mdss_dsi1_phy: phy@ae96400 { 1625 compatible = "qcom,dsi-phy-10nm"; 1626 reg = <0 0x0ae96400 0 0x200>, 1627 <0 0x0ae96600 0 0x280>, 1628 <0 0x0ae96a00 0 0x10e>; 1629 reg-names = "dsi_phy", 1630 "dsi_phy_lane", 1631 "dsi_pll"; 1632 1633 #clock-cells = <1>; 1634 #phy-cells = <0>; 1635 1636 clocks = <&dispcc DISP_CC_MDSS_AHB_CLK>, 1637 <&rpmhcc RPMH_CXO_CLK>; 1638 clock-names = "iface", "ref"; 1639 1640 status = "disabled"; 1641 }; 1642 }; 1643 1644 dispcc: clock-controller@af00000 { 1645 compatible = "qcom,sdm845-dispcc"; 1646 reg = <0 0x0af00000 0 0x10000>; 1647 clocks = <&rpmhcc RPMH_CXO_CLK>, 1648 <&gcc GCC_DISP_GPLL0_CLK_SRC>, 1649 <&gcc GCC_DISP_GPLL0_DIV_CLK_SRC>, 1650 <&mdss_dsi0_phy 0>, 1651 <&mdss_dsi0_phy 1>, 1652 <&mdss_dsi1_phy 0>, 1653 <&mdss_dsi1_phy 1>, 1654 <0>, 1655 <0>; 1656 clock-names = "bi_tcxo", 1657 "gcc_disp_gpll0_clk_src", 1658 "gcc_disp_gpll0_div_clk_src", 1659 "dsi0_phy_pll_out_byteclk", 1660 "dsi0_phy_pll_out_dsiclk", 1661 "dsi1_phy_pll_out_byteclk", 1662 "dsi1_phy_pll_out_dsiclk", 1663 "dp_link_clk_divsel_ten", 1664 "dp_vco_divided_clk_src_mux"; 1665 #clock-cells = <1>; 1666 #reset-cells = <1>; 1667 #power-domain-cells = <1>; 1668 }; 1669 1670 apps_smmu: iommu@15000000 { 1671 compatible = "qcom,sdm670-smmu-500", "qcom,smmu-500", "arm,mmu-500"; 1672 reg = <0 0x15000000 0 0x80000>; 1673 #iommu-cells = <2>; 1674 #global-interrupts = <1>; 1675 interrupts = <GIC_SPI 65 IRQ_TYPE_LEVEL_HIGH>, 1676 <GIC_SPI 96 IRQ_TYPE_LEVEL_HIGH>, 1677 <GIC_SPI 97 IRQ_TYPE_LEVEL_HIGH>, 1678 <GIC_SPI 98 IRQ_TYPE_LEVEL_HIGH>, 1679 <GIC_SPI 99 IRQ_TYPE_LEVEL_HIGH>, 1680 <GIC_SPI 100 IRQ_TYPE_LEVEL_HIGH>, 1681 <GIC_SPI 101 IRQ_TYPE_LEVEL_HIGH>, 1682 <GIC_SPI 102 IRQ_TYPE_LEVEL_HIGH>, 1683 <GIC_SPI 103 IRQ_TYPE_LEVEL_HIGH>, 1684 <GIC_SPI 104 IRQ_TYPE_LEVEL_HIGH>, 1685 <GIC_SPI 105 IRQ_TYPE_LEVEL_HIGH>, 1686 <GIC_SPI 106 IRQ_TYPE_LEVEL_HIGH>, 1687 <GIC_SPI 107 IRQ_TYPE_LEVEL_HIGH>, 1688 <GIC_SPI 108 IRQ_TYPE_LEVEL_HIGH>, 1689 <GIC_SPI 109 IRQ_TYPE_LEVEL_HIGH>, 1690 <GIC_SPI 110 IRQ_TYPE_LEVEL_HIGH>, 1691 <GIC_SPI 111 IRQ_TYPE_LEVEL_HIGH>, 1692 <GIC_SPI 112 IRQ_TYPE_LEVEL_HIGH>, 1693 <GIC_SPI 113 IRQ_TYPE_LEVEL_HIGH>, 1694 <GIC_SPI 114 IRQ_TYPE_LEVEL_HIGH>, 1695 <GIC_SPI 115 IRQ_TYPE_LEVEL_HIGH>, 1696 <GIC_SPI 116 IRQ_TYPE_LEVEL_HIGH>, 1697 <GIC_SPI 117 IRQ_TYPE_LEVEL_HIGH>, 1698 <GIC_SPI 118 IRQ_TYPE_LEVEL_HIGH>, 1699 <GIC_SPI 181 IRQ_TYPE_LEVEL_HIGH>, 1700 <GIC_SPI 182 IRQ_TYPE_LEVEL_HIGH>, 1701 <GIC_SPI 183 IRQ_TYPE_LEVEL_HIGH>, 1702 <GIC_SPI 184 IRQ_TYPE_LEVEL_HIGH>, 1703 <GIC_SPI 185 IRQ_TYPE_LEVEL_HIGH>, 1704 <GIC_SPI 186 IRQ_TYPE_LEVEL_HIGH>, 1705 <GIC_SPI 187 IRQ_TYPE_LEVEL_HIGH>, 1706 <GIC_SPI 188 IRQ_TYPE_LEVEL_HIGH>, 1707 <GIC_SPI 189 IRQ_TYPE_LEVEL_HIGH>, 1708 <GIC_SPI 190 IRQ_TYPE_LEVEL_HIGH>, 1709 <GIC_SPI 191 IRQ_TYPE_LEVEL_HIGH>, 1710 <GIC_SPI 192 IRQ_TYPE_LEVEL_HIGH>, 1711 <GIC_SPI 315 IRQ_TYPE_LEVEL_HIGH>, 1712 <GIC_SPI 316 IRQ_TYPE_LEVEL_HIGH>, 1713 <GIC_SPI 317 IRQ_TYPE_LEVEL_HIGH>, 1714 <GIC_SPI 318 IRQ_TYPE_LEVEL_HIGH>, 1715 <GIC_SPI 319 IRQ_TYPE_LEVEL_HIGH>, 1716 <GIC_SPI 320 IRQ_TYPE_LEVEL_HIGH>, 1717 <GIC_SPI 321 IRQ_TYPE_LEVEL_HIGH>, 1718 <GIC_SPI 322 IRQ_TYPE_LEVEL_HIGH>, 1719 <GIC_SPI 323 IRQ_TYPE_LEVEL_HIGH>, 1720 <GIC_SPI 324 IRQ_TYPE_LEVEL_HIGH>, 1721 <GIC_SPI 325 IRQ_TYPE_LEVEL_HIGH>, 1722 <GIC_SPI 326 IRQ_TYPE_LEVEL_HIGH>, 1723 <GIC_SPI 327 IRQ_TYPE_LEVEL_HIGH>, 1724 <GIC_SPI 328 IRQ_TYPE_LEVEL_HIGH>, 1725 <GIC_SPI 329 IRQ_TYPE_LEVEL_HIGH>, 1726 <GIC_SPI 330 IRQ_TYPE_LEVEL_HIGH>, 1727 <GIC_SPI 331 IRQ_TYPE_LEVEL_HIGH>, 1728 <GIC_SPI 332 IRQ_TYPE_LEVEL_HIGH>, 1729 <GIC_SPI 333 IRQ_TYPE_LEVEL_HIGH>, 1730 <GIC_SPI 334 IRQ_TYPE_LEVEL_HIGH>, 1731 <GIC_SPI 335 IRQ_TYPE_LEVEL_HIGH>, 1732 <GIC_SPI 336 IRQ_TYPE_LEVEL_HIGH>, 1733 <GIC_SPI 337 IRQ_TYPE_LEVEL_HIGH>, 1734 <GIC_SPI 338 IRQ_TYPE_LEVEL_HIGH>, 1735 <GIC_SPI 339 IRQ_TYPE_LEVEL_HIGH>, 1736 <GIC_SPI 340 IRQ_TYPE_LEVEL_HIGH>, 1737 <GIC_SPI 341 IRQ_TYPE_LEVEL_HIGH>, 1738 <GIC_SPI 342 IRQ_TYPE_LEVEL_HIGH>, 1739 <GIC_SPI 343 IRQ_TYPE_LEVEL_HIGH>; 1740 dma-coherent; 1741 }; 1742 1743 gladiator_noc: interconnect@17900000 { 1744 compatible = "qcom,sdm670-gladiator-noc"; 1745 reg = <0 0x17900000 0 0xd080>; 1746 #interconnect-cells = <2>; 1747 qcom,bcm-voters = <&apps_bcm_voter>; 1748 }; 1749 1750 apps_rsc: rsc@179c0000 { 1751 compatible = "qcom,rpmh-rsc"; 1752 reg = <0 0x179c0000 0 0x10000>, 1753 <0 0x179d0000 0 0x10000>, 1754 <0 0x179e0000 0 0x10000>; 1755 reg-names = "drv-0", "drv-1", "drv-2"; 1756 interrupts = <GIC_SPI 3 IRQ_TYPE_LEVEL_HIGH>, 1757 <GIC_SPI 4 IRQ_TYPE_LEVEL_HIGH>, 1758 <GIC_SPI 5 IRQ_TYPE_LEVEL_HIGH>; 1759 label = "apps_rsc"; 1760 qcom,tcs-offset = <0xd00>; 1761 qcom,drv-id = <2>; 1762 qcom,tcs-config = <ACTIVE_TCS 2>, 1763 <SLEEP_TCS 3>, 1764 <WAKE_TCS 3>, 1765 <CONTROL_TCS 1>; 1766 power-domains = <&cluster_pd>; 1767 1768 apps_bcm_voter: bcm-voter { 1769 compatible = "qcom,bcm-voter"; 1770 }; 1771 1772 rpmhcc: clock-controller { 1773 compatible = "qcom,sdm670-rpmh-clk"; 1774 #clock-cells = <1>; 1775 clock-names = "xo"; 1776 clocks = <&xo_board>; 1777 }; 1778 1779 rpmhpd: power-controller { 1780 compatible = "qcom,sdm670-rpmhpd"; 1781 #power-domain-cells = <1>; 1782 operating-points-v2 = <&rpmhpd_opp_table>; 1783 1784 rpmhpd_opp_table: opp-table { 1785 compatible = "operating-points-v2"; 1786 1787 rpmhpd_opp_ret: opp1 { 1788 opp-level = <RPMH_REGULATOR_LEVEL_RETENTION>; 1789 }; 1790 1791 rpmhpd_opp_min_svs: opp2 { 1792 opp-level = <RPMH_REGULATOR_LEVEL_MIN_SVS>; 1793 }; 1794 1795 rpmhpd_opp_low_svs: opp3 { 1796 opp-level = <RPMH_REGULATOR_LEVEL_LOW_SVS>; 1797 }; 1798 1799 rpmhpd_opp_svs: opp4 { 1800 opp-level = <RPMH_REGULATOR_LEVEL_SVS>; 1801 }; 1802 1803 rpmhpd_opp_svs_l1: opp5 { 1804 opp-level = <RPMH_REGULATOR_LEVEL_SVS_L1>; 1805 }; 1806 1807 rpmhpd_opp_nom: opp6 { 1808 opp-level = <RPMH_REGULATOR_LEVEL_NOM>; 1809 }; 1810 1811 rpmhpd_opp_nom_l1: opp7 { 1812 opp-level = <RPMH_REGULATOR_LEVEL_NOM_L1>; 1813 }; 1814 1815 rpmhpd_opp_nom_l2: opp8 { 1816 opp-level = <RPMH_REGULATOR_LEVEL_NOM_L2>; 1817 }; 1818 1819 rpmhpd_opp_turbo: opp9 { 1820 opp-level = <RPMH_REGULATOR_LEVEL_TURBO>; 1821 }; 1822 1823 rpmhpd_opp_turbo_l1: opp10 { 1824 opp-level = <RPMH_REGULATOR_LEVEL_TURBO_L1>; 1825 }; 1826 }; 1827 }; 1828 }; 1829 1830 intc: interrupt-controller@17a00000 { 1831 compatible = "arm,gic-v3"; 1832 reg = <0 0x17a00000 0 0x10000>, /* GICD */ 1833 <0 0x17a60000 0 0x100000>; /* GICR * 8 */ 1834 interrupt-controller; 1835 interrupts = <GIC_PPI 9 IRQ_TYPE_LEVEL_HIGH>; 1836 #interrupt-cells = <3>; 1837 }; 1838 1839 osm_l3: interconnect@17d41000 { 1840 compatible = "qcom,sdm670-osm-l3", "qcom,osm-l3"; 1841 reg = <0 0x17d41000 0 0x1400>; 1842 1843 clocks = <&rpmhcc RPMH_CXO_CLK>, <&gcc GPLL0>; 1844 clock-names = "xo", "alternate"; 1845 1846 #interconnect-cells = <1>; 1847 }; 1848 1849 cpufreq_hw: cpufreq@17d43000 { 1850 compatible = "qcom,sdm670-cpufreq-hw", "qcom,cpufreq-hw"; 1851 reg = <0 0x17d43000 0 0x1400>, <0 0x17d45800 0 0x1400>; 1852 reg-names = "freq-domain0", "freq-domain1"; 1853 1854 clocks = <&rpmhcc RPMH_CXO_CLK>, <&gcc GPLL0>; 1855 clock-names = "xo", "alternate"; 1856 1857 #freq-domain-cells = <1>; 1858 }; 1859 }; 1860}; 1861