Lines Matching +full:mt8192 +full:- +full:pericfg
1 // SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
4 * Author: Allen-KH Cheng <allen-kh.cheng@mediatek.com>
6 /dts-v1/;
7 #include <dt-bindings/clock/mt8186-clk.h>
8 #include <dt-bindings/gce/mt8186-gce.h>
9 #include <dt-bindings/interrupt-controller/arm-gic.h>
10 #include <dt-bindings/interrupt-controller/irq.h>
11 #include <dt-bindings/memory/mt8186-memory-port.h>
12 #include <dt-bindings/pinctrl/mt8186-pinfunc.h>
13 #include <dt-bindings/power/mt8186-power.h>
14 #include <dt-bindings/phy/phy.h>
15 #include <dt-bindings/reset/mt8186-resets.h>
19 interrupt-parent = <&gic>;
20 #address-cells = <2>;
21 #size-cells = <2>;
25 ovl-2l0 = &ovl_2l0;
31 compatible = "mediatek,mt8186-cci";
34 clock-names = "cci", "intermediate";
35 operating-points-v2 = <&cci_opp>;
38 cci_opp: opp-table-cci {
39 compatible = "operating-points-v2";
40 opp-shared;
42 cci_opp_0: opp-500000000 {
43 opp-hz = /bits/ 64 <500000000>;
44 opp-microvolt = <600000>;
47 cci_opp_1: opp-560000000 {
48 opp-hz = /bits/ 64 <560000000>;
49 opp-microvolt = <675000>;
52 cci_opp_2: opp-612000000 {
53 opp-hz = /bits/ 64 <612000000>;
54 opp-microvolt = <693750>;
57 cci_opp_3: opp-682000000 {
58 opp-hz = /bits/ 64 <682000000>;
59 opp-microvolt = <718750>;
62 cci_opp_4: opp-752000000 {
63 opp-hz = /bits/ 64 <752000000>;
64 opp-microvolt = <743750>;
67 cci_opp_5: opp-822000000 {
68 opp-hz = /bits/ 64 <822000000>;
69 opp-microvolt = <768750>;
72 cci_opp_6: opp-875000000 {
73 opp-hz = /bits/ 64 <875000000>;
74 opp-microvolt = <781250>;
77 cci_opp_7: opp-927000000 {
78 opp-hz = /bits/ 64 <927000000>;
79 opp-microvolt = <800000>;
82 cci_opp_8: opp-980000000 {
83 opp-hz = /bits/ 64 <980000000>;
84 opp-microvolt = <818750>;
87 cci_opp_9: opp-1050000000 {
88 opp-hz = /bits/ 64 <1050000000>;
89 opp-microvolt = <843750>;
92 cci_opp_10: opp-1120000000 {
93 opp-hz = /bits/ 64 <1120000000>;
94 opp-microvolt = <862500>;
97 cci_opp_11: opp-1155000000 {
98 opp-hz = /bits/ 64 <1155000000>;
99 opp-microvolt = <887500>;
102 cci_opp_12: opp-1190000000 {
103 opp-hz = /bits/ 64 <1190000000>;
104 opp-microvolt = <906250>;
107 cci_opp_13: opp-1260000000 {
108 opp-hz = /bits/ 64 <1260000000>;
109 opp-microvolt = <950000>;
112 cci_opp_14: opp-1330000000 {
113 opp-hz = /bits/ 64 <1330000000>;
114 opp-microvolt = <993750>;
117 cci_opp_15: opp-1400000000 {
118 opp-hz = /bits/ 64 <1400000000>;
119 opp-microvolt = <1031250>;
123 cluster0_opp: opp-table-cluster0 {
124 compatible = "operating-points-v2";
125 opp-shared;
127 opp-500000000 {
128 opp-hz = /bits/ 64 <500000000>;
129 opp-microvolt = <600000>;
130 required-opps = <&cci_opp_0>;
133 opp-774000000 {
134 opp-hz = /bits/ 64 <774000000>;
135 opp-microvolt = <675000>;
136 required-opps = <&cci_opp_1>;
139 opp-875000000 {
140 opp-hz = /bits/ 64 <875000000>;
141 opp-microvolt = <700000>;
142 required-opps = <&cci_opp_2>;
145 opp-975000000 {
146 opp-hz = /bits/ 64 <975000000>;
147 opp-microvolt = <725000>;
148 required-opps = <&cci_opp_3>;
151 opp-1075000000 {
152 opp-hz = /bits/ 64 <1075000000>;
153 opp-microvolt = <750000>;
154 required-opps = <&cci_opp_4>;
157 opp-1175000000 {
158 opp-hz = /bits/ 64 <1175000000>;
159 opp-microvolt = <775000>;
160 required-opps = <&cci_opp_5>;
163 opp-1275000000 {
164 opp-hz = /bits/ 64 <1275000000>;
165 opp-microvolt = <800000>;
166 required-opps = <&cci_opp_6>;
169 opp-1375000000 {
170 opp-hz = /bits/ 64 <1375000000>;
171 opp-microvolt = <825000>;
172 required-opps = <&cci_opp_7>;
175 opp-1500000000 {
176 opp-hz = /bits/ 64 <1500000000>;
177 opp-microvolt = <856250>;
178 required-opps = <&cci_opp_8>;
181 opp-1618000000 {
182 opp-hz = /bits/ 64 <1618000000>;
183 opp-microvolt = <875000>;
184 required-opps = <&cci_opp_9>;
187 opp-1666000000 {
188 opp-hz = /bits/ 64 <1666000000>;
189 opp-microvolt = <900000>;
190 required-opps = <&cci_opp_10>;
193 opp-1733000000 {
194 opp-hz = /bits/ 64 <1733000000>;
195 opp-microvolt = <925000>;
196 required-opps = <&cci_opp_11>;
199 opp-1800000000 {
200 opp-hz = /bits/ 64 <1800000000>;
201 opp-microvolt = <950000>;
202 required-opps = <&cci_opp_12>;
205 opp-1866000000 {
206 opp-hz = /bits/ 64 <1866000000>;
207 opp-microvolt = <981250>;
208 required-opps = <&cci_opp_13>;
211 opp-1933000000 {
212 opp-hz = /bits/ 64 <1933000000>;
213 opp-microvolt = <1006250>;
214 required-opps = <&cci_opp_14>;
217 opp-2000000000 {
218 opp-hz = /bits/ 64 <2000000000>;
219 opp-microvolt = <1031250>;
220 required-opps = <&cci_opp_15>;
224 cluster1_opp: opp-table-cluster1 {
225 compatible = "operating-points-v2";
226 opp-shared;
228 opp-774000000 {
229 opp-hz = /bits/ 64 <774000000>;
230 opp-microvolt = <675000>;
231 required-opps = <&cci_opp_0>;
234 opp-835000000 {
235 opp-hz = /bits/ 64 <835000000>;
236 opp-microvolt = <693750>;
237 required-opps = <&cci_opp_1>;
240 opp-919000000 {
241 opp-hz = /bits/ 64 <919000000>;
242 opp-microvolt = <718750>;
243 required-opps = <&cci_opp_2>;
246 opp-1002000000 {
247 opp-hz = /bits/ 64 <1002000000>;
248 opp-microvolt = <743750>;
249 required-opps = <&cci_opp_3>;
252 opp-1085000000 {
253 opp-hz = /bits/ 64 <1085000000>;
254 opp-microvolt = <775000>;
255 required-opps = <&cci_opp_4>;
258 opp-1169000000 {
259 opp-hz = /bits/ 64 <1169000000>;
260 opp-microvolt = <800000>;
261 required-opps = <&cci_opp_5>;
264 opp-1308000000 {
265 opp-hz = /bits/ 64 <1308000000>;
266 opp-microvolt = <843750>;
267 required-opps = <&cci_opp_6>;
270 opp-1419000000 {
271 opp-hz = /bits/ 64 <1419000000>;
272 opp-microvolt = <875000>;
273 required-opps = <&cci_opp_7>;
276 opp-1530000000 {
277 opp-hz = /bits/ 64 <1530000000>;
278 opp-microvolt = <912500>;
279 required-opps = <&cci_opp_8>;
282 opp-1670000000 {
283 opp-hz = /bits/ 64 <1670000000>;
284 opp-microvolt = <956250>;
285 required-opps = <&cci_opp_9>;
288 opp-1733000000 {
289 opp-hz = /bits/ 64 <1733000000>;
290 opp-microvolt = <981250>;
291 required-opps = <&cci_opp_10>;
294 opp-1796000000 {
295 opp-hz = /bits/ 64 <1796000000>;
296 opp-microvolt = <1012500>;
297 required-opps = <&cci_opp_11>;
300 opp-1860000000 {
301 opp-hz = /bits/ 64 <1860000000>;
302 opp-microvolt = <1037500>;
303 required-opps = <&cci_opp_12>;
306 opp-1923000000 {
307 opp-hz = /bits/ 64 <1923000000>;
308 opp-microvolt = <1062500>;
309 required-opps = <&cci_opp_13>;
312 cluster1_opp_14: opp-1986000000 {
313 opp-hz = /bits/ 64 <1986000000>;
314 opp-microvolt = <1093750>;
315 required-opps = <&cci_opp_14>;
318 cluster1_opp_15: opp-2050000000 {
319 opp-hz = /bits/ 64 <2050000000>;
320 opp-microvolt = <1118750>;
321 required-opps = <&cci_opp_15>;
326 #address-cells = <1>;
327 #size-cells = <0>;
329 cpu-map {
367 compatible = "arm,cortex-a55";
369 enable-method = "psci";
370 clock-frequency = <2000000000>;
373 clock-names = "cpu", "intermediate";
374 operating-points-v2 = <&cluster0_opp>;
375 dynamic-power-coefficient = <84>;
376 capacity-dmips-mhz = <382>;
377 cpu-idle-states = <&cpu_ret_l &cpu_off_l>;
378 i-cache-size = <32768>;
379 i-cache-line-size = <64>;
380 i-cache-sets = <128>;
381 d-cache-size = <32768>;
382 d-cache-line-size = <64>;
383 d-cache-sets = <128>;
384 next-level-cache = <&l2_0>;
385 #cooling-cells = <2>;
391 compatible = "arm,cortex-a55";
393 enable-method = "psci";
394 clock-frequency = <2000000000>;
397 clock-names = "cpu", "intermediate";
398 operating-points-v2 = <&cluster0_opp>;
399 dynamic-power-coefficient = <84>;
400 capacity-dmips-mhz = <382>;
401 cpu-idle-states = <&cpu_ret_l &cpu_off_l>;
402 i-cache-size = <32768>;
403 i-cache-line-size = <64>;
404 i-cache-sets = <128>;
405 d-cache-size = <32768>;
406 d-cache-line-size = <64>;
407 d-cache-sets = <128>;
408 next-level-cache = <&l2_0>;
409 #cooling-cells = <2>;
415 compatible = "arm,cortex-a55";
417 enable-method = "psci";
418 clock-frequency = <2000000000>;
421 clock-names = "cpu", "intermediate";
422 operating-points-v2 = <&cluster0_opp>;
423 dynamic-power-coefficient = <84>;
424 capacity-dmips-mhz = <382>;
425 cpu-idle-states = <&cpu_ret_l &cpu_off_l>;
426 i-cache-size = <32768>;
427 i-cache-line-size = <64>;
428 i-cache-sets = <128>;
429 d-cache-size = <32768>;
430 d-cache-line-size = <64>;
431 d-cache-sets = <128>;
432 next-level-cache = <&l2_0>;
433 #cooling-cells = <2>;
439 compatible = "arm,cortex-a55";
441 enable-method = "psci";
442 clock-frequency = <2000000000>;
445 clock-names = "cpu", "intermediate";
446 operating-points-v2 = <&cluster0_opp>;
447 dynamic-power-coefficient = <84>;
448 capacity-dmips-mhz = <382>;
449 cpu-idle-states = <&cpu_ret_l &cpu_off_l>;
450 i-cache-size = <32768>;
451 i-cache-line-size = <64>;
452 i-cache-sets = <128>;
453 d-cache-size = <32768>;
454 d-cache-line-size = <64>;
455 d-cache-sets = <128>;
456 next-level-cache = <&l2_0>;
457 #cooling-cells = <2>;
463 compatible = "arm,cortex-a55";
465 enable-method = "psci";
466 clock-frequency = <2000000000>;
469 clock-names = "cpu", "intermediate";
470 operating-points-v2 = <&cluster0_opp>;
471 dynamic-power-coefficient = <84>;
472 capacity-dmips-mhz = <382>;
473 cpu-idle-states = <&cpu_ret_l &cpu_off_l>;
474 i-cache-size = <32768>;
475 i-cache-line-size = <64>;
476 i-cache-sets = <128>;
477 d-cache-size = <32768>;
478 d-cache-line-size = <64>;
479 d-cache-sets = <128>;
480 next-level-cache = <&l2_0>;
481 #cooling-cells = <2>;
487 compatible = "arm,cortex-a55";
489 enable-method = "psci";
490 clock-frequency = <2000000000>;
493 clock-names = "cpu", "intermediate";
494 operating-points-v2 = <&cluster0_opp>;
495 dynamic-power-coefficient = <84>;
496 capacity-dmips-mhz = <382>;
497 cpu-idle-states = <&cpu_ret_l &cpu_off_l>;
498 i-cache-size = <32768>;
499 i-cache-line-size = <64>;
500 i-cache-sets = <128>;
501 d-cache-size = <32768>;
502 d-cache-line-size = <64>;
503 d-cache-sets = <128>;
504 next-level-cache = <&l2_0>;
505 #cooling-cells = <2>;
511 compatible = "arm,cortex-a76";
513 enable-method = "psci";
514 clock-frequency = <2050000000>;
517 clock-names = "cpu", "intermediate";
518 operating-points-v2 = <&cluster1_opp>;
519 dynamic-power-coefficient = <335>;
520 capacity-dmips-mhz = <1024>;
521 cpu-idle-states = <&cpu_ret_b &cpu_off_b>;
522 i-cache-size = <65536>;
523 i-cache-line-size = <64>;
524 i-cache-sets = <256>;
525 d-cache-size = <65536>;
526 d-cache-line-size = <64>;
527 d-cache-sets = <256>;
528 next-level-cache = <&l2_1>;
529 #cooling-cells = <2>;
535 compatible = "arm,cortex-a76";
537 enable-method = "psci";
538 clock-frequency = <2050000000>;
541 clock-names = "cpu", "intermediate";
542 operating-points-v2 = <&cluster1_opp>;
543 dynamic-power-coefficient = <335>;
544 capacity-dmips-mhz = <1024>;
545 cpu-idle-states = <&cpu_ret_b &cpu_off_b>;
546 i-cache-size = <65536>;
547 i-cache-line-size = <64>;
548 i-cache-sets = <256>;
549 d-cache-size = <65536>;
550 d-cache-line-size = <64>;
551 d-cache-sets = <256>;
552 next-level-cache = <&l2_1>;
553 #cooling-cells = <2>;
557 idle-states {
558 entry-method = "psci";
560 cpu_ret_l: cpu-retention-l {
561 compatible = "arm,idle-state";
562 arm,psci-suspend-param = <0x00010001>;
563 local-timer-stop;
564 entry-latency-us = <50>;
565 exit-latency-us = <100>;
566 min-residency-us = <1600>;
569 cpu_ret_b: cpu-retention-b {
570 compatible = "arm,idle-state";
571 arm,psci-suspend-param = <0x00010001>;
572 local-timer-stop;
573 entry-latency-us = <50>;
574 exit-latency-us = <100>;
575 min-residency-us = <1400>;
578 cpu_off_l: cpu-off-l {
579 compatible = "arm,idle-state";
580 arm,psci-suspend-param = <0x01010001>;
581 local-timer-stop;
582 entry-latency-us = <100>;
583 exit-latency-us = <250>;
584 min-residency-us = <2100>;
587 cpu_off_b: cpu-off-b {
588 compatible = "arm,idle-state";
589 arm,psci-suspend-param = <0x01010001>;
590 local-timer-stop;
591 entry-latency-us = <100>;
592 exit-latency-us = <250>;
593 min-residency-us = <1900>;
597 l2_0: l2-cache0 {
599 cache-level = <2>;
600 cache-size = <131072>;
601 cache-line-size = <64>;
602 cache-sets = <512>;
603 next-level-cache = <&l3_0>;
604 cache-unified;
607 l2_1: l2-cache1 {
609 cache-level = <2>;
610 cache-size = <262144>;
611 cache-line-size = <64>;
612 cache-sets = <512>;
613 next-level-cache = <&l3_0>;
614 cache-unified;
617 l3_0: l3-cache {
619 cache-level = <3>;
620 cache-size = <1048576>;
621 cache-line-size = <64>;
622 cache-sets = <1024>;
623 cache-unified;
627 clk13m: fixed-factor-clock-13m {
628 compatible = "fixed-factor-clock";
629 #clock-cells = <0>;
631 clock-div = <2>;
632 clock-mult = <1>;
633 clock-output-names = "clk13m";
636 clk26m: oscillator-26m {
637 compatible = "fixed-clock";
638 #clock-cells = <0>;
639 clock-frequency = <26000000>;
640 clock-output-names = "clk26m";
643 clk32k: oscillator-32k {
644 compatible = "fixed-clock";
645 #clock-cells = <0>;
646 clock-frequency = <32768>;
647 clock-output-names = "clk32k";
650 gpu_opp_table: opp-table-gpu {
651 compatible = "operating-points-v2";
653 opp-299000000 {
654 opp-hz = /bits/ 64 <299000000>;
655 opp-microvolt = <612500>;
656 opp-supported-hw = <0xff>;
659 opp-332000000 {
660 opp-hz = /bits/ 64 <332000000>;
661 opp-microvolt = <625000>;
662 opp-supported-hw = <0xff>;
665 opp-366000000 {
666 opp-hz = /bits/ 64 <366000000>;
667 opp-microvolt = <637500>;
668 opp-supported-hw = <0xff>;
671 opp-400000000 {
672 opp-hz = /bits/ 64 <400000000>;
673 opp-microvolt = <643750>;
674 opp-supported-hw = <0xff>;
677 opp-434000000 {
678 opp-hz = /bits/ 64 <434000000>;
679 opp-microvolt = <656250>;
680 opp-supported-hw = <0xff>;
683 opp-484000000 {
684 opp-hz = /bits/ 64 <484000000>;
685 opp-microvolt = <668750>;
686 opp-supported-hw = <0xff>;
689 opp-535000000 {
690 opp-hz = /bits/ 64 <535000000>;
691 opp-microvolt = <687500>;
692 opp-supported-hw = <0xff>;
695 opp-586000000 {
696 opp-hz = /bits/ 64 <586000000>;
697 opp-microvolt = <700000>;
698 opp-supported-hw = <0xff>;
701 opp-637000000 {
702 opp-hz = /bits/ 64 <637000000>;
703 opp-microvolt = <712500>;
704 opp-supported-hw = <0xff>;
707 opp-690000000 {
708 opp-hz = /bits/ 64 <690000000>;
709 opp-microvolt = <737500>;
710 opp-supported-hw = <0xff>;
713 opp-743000000 {
714 opp-hz = /bits/ 64 <743000000>;
715 opp-microvolt = <756250>;
716 opp-supported-hw = <0xff>;
719 opp-796000000 {
720 opp-hz = /bits/ 64 <796000000>;
721 opp-microvolt = <781250>;
722 opp-supported-hw = <0xff>;
725 opp-850000000 {
726 opp-hz = /bits/ 64 <850000000>;
727 opp-microvolt = <800000>;
728 opp-supported-hw = <0xff>;
731 opp-900000000-3 {
732 opp-hz = /bits/ 64 <900000000>;
733 opp-microvolt = <850000>;
734 opp-supported-hw = <0x8>;
737 opp-900000000-4 {
738 opp-hz = /bits/ 64 <900000000>;
739 opp-microvolt = <837500>;
740 opp-supported-hw = <0x10>;
743 opp-900000000-5 {
744 opp-hz = /bits/ 64 <900000000>;
745 opp-microvolt = <825000>;
746 opp-supported-hw = <0x30>;
749 opp-950000000-3 {
750 opp-hz = /bits/ 64 <950000000>;
751 opp-microvolt = <900000>;
752 opp-supported-hw = <0x8>;
755 opp-950000000-4 {
756 opp-hz = /bits/ 64 <950000000>;
757 opp-microvolt = <875000>;
758 opp-supported-hw = <0x10>;
761 opp-950000000-5 {
762 opp-hz = /bits/ 64 <950000000>;
763 opp-microvolt = <850000>;
764 opp-supported-hw = <0x30>;
767 opp-1000000000-3 {
768 opp-hz = /bits/ 64 <1000000000>;
769 opp-microvolt = <950000>;
770 opp-supported-hw = <0x8>;
773 opp-1000000000-4 {
774 opp-hz = /bits/ 64 <1000000000>;
775 opp-microvolt = <912500>;
776 opp-supported-hw = <0x10>;
779 opp-1000000000-5 {
780 opp-hz = /bits/ 64 <1000000000>;
781 opp-microvolt = <875000>;
782 opp-supported-hw = <0x30>;
786 pmu-a55 {
787 compatible = "arm,cortex-a55-pmu";
788 interrupt-parent = <&gic>;
792 pmu-a76 {
793 compatible = "arm,cortex-a76-pmu";
794 interrupt-parent = <&gic>;
799 compatible = "arm,psci-1.0";
804 compatible = "arm,armv8-timer";
805 interrupt-parent = <&gic>;
813 #address-cells = <2>;
814 #size-cells = <2>;
815 compatible = "simple-bus";
816 dma-ranges = <0x0 0x0 0x0 0x0 0x4 0x0>;
819 gic: interrupt-controller@c000000 {
820 compatible = "arm,gic-v3";
821 #interrupt-cells = <4>;
822 #redistributor-regions = <1>;
823 interrupt-parent = <&gic>;
824 interrupt-controller;
829 ppi-partitions {
830 ppi_cluster0: interrupt-partition-0 {
834 ppi_cluster1: interrupt-partition-1 {
841 compatible = "mediatek,mt8186-mcusys", "syscon";
843 #clock-cells = <1>;
847 compatible = "mediatek,mt8186-topckgen", "syscon";
849 #clock-cells = <1>;
853 compatible = "mediatek,mt8186-infracfg_ao", "syscon";
855 #clock-cells = <1>;
856 #reset-cells = <1>;
859 pericfg: syscon@10003000 {
860 compatible = "mediatek,mt8186-pericfg", "syscon";
865 compatible = "mediatek,mt8186-pinctrl";
874 reg-names = "iocfg0", "iocfg_lt", "iocfg_lm", "iocfg_lb",
876 gpio-controller;
877 #gpio-cells = <2>;
878 gpio-ranges = <&pio 0 0 185>;
879 interrupt-controller;
881 #interrupt-cells = <2>;
885 compatible = "mediatek,mt8186-scpsys", "syscon", "simple-mfd";
889 spm: power-controller {
890 compatible = "mediatek,mt8186-power-controller";
891 #address-cells = <1>;
892 #size-cells = <0>;
893 #power-domain-cells = <1>;
896 mfg0: power-domain@MT8186_POWER_DOMAIN_MFG0 {
899 clock-names = "mfg00";
900 #address-cells = <1>;
901 #size-cells = <0>;
902 #power-domain-cells = <1>;
904 mfg1: power-domain@MT8186_POWER_DOMAIN_MFG1 {
907 #address-cells = <1>;
908 #size-cells = <0>;
909 #power-domain-cells = <1>;
911 power-domain@MT8186_POWER_DOMAIN_MFG2 {
913 #power-domain-cells = <0>;
916 power-domain@MT8186_POWER_DOMAIN_MFG3 {
918 #power-domain-cells = <0>;
923 power-domain@MT8186_POWER_DOMAIN_CSIRX_TOP {
927 clock-names = "subsys-csirx-top0",
928 "subsys-csirx-top1";
929 #power-domain-cells = <0>;
932 power-domain@MT8186_POWER_DOMAIN_SSUSB {
934 #power-domain-cells = <0>;
937 power-domain@MT8186_POWER_DOMAIN_SSUSB_P1 {
939 #power-domain-cells = <0>;
942 power-domain@MT8186_POWER_DOMAIN_ADSP_AO {
946 clock-names = "audioadsp",
947 "subsys-adsp-bus";
948 #address-cells = <1>;
949 #size-cells = <0>;
950 #power-domain-cells = <1>;
952 power-domain@MT8186_POWER_DOMAIN_ADSP_INFRA {
954 #address-cells = <1>;
955 #size-cells = <0>;
956 #power-domain-cells = <1>;
958 power-domain@MT8186_POWER_DOMAIN_ADSP_TOP {
961 #power-domain-cells = <0>;
966 power-domain@MT8186_POWER_DOMAIN_CONN_ON {
969 #power-domain-cells = <0>;
972 power-domain@MT8186_POWER_DOMAIN_DIS {
980 clock-names = "disp", "mdp",
981 "subsys-smi-infra",
982 "subsys-smi-common",
983 "subsys-smi-gals",
984 "subsys-smi-iommu";
986 #address-cells = <1>;
987 #size-cells = <0>;
988 #power-domain-cells = <1>;
990 power-domain@MT8186_POWER_DOMAIN_VDEC {
994 clock-names = "vdec0", "larb";
996 #power-domain-cells = <0>;
999 power-domain@MT8186_POWER_DOMAIN_CAM {
1008 clock-names = "cam0", "cam1", "cam2",
1010 "subsys-cam-tm",
1011 "subsys-cam-top";
1013 #address-cells = <1>;
1014 #size-cells = <0>;
1015 #power-domain-cells = <1>;
1017 power-domain@MT8186_POWER_DOMAIN_CAM_RAWB {
1019 #power-domain-cells = <0>;
1022 power-domain@MT8186_POWER_DOMAIN_CAM_RAWA {
1024 #power-domain-cells = <0>;
1028 power-domain@MT8186_POWER_DOMAIN_IMG {
1032 clock-names = "gals", "subsys-img-top";
1034 #address-cells = <1>;
1035 #size-cells = <0>;
1036 #power-domain-cells = <1>;
1038 power-domain@MT8186_POWER_DOMAIN_IMG2 {
1040 #power-domain-cells = <0>;
1044 power-domain@MT8186_POWER_DOMAIN_IPE {
1051 clock-names = "subsys-ipe-top",
1052 "subsys-ipe-larb0",
1053 "subsys-ipe-larb1",
1054 "subsys-ipe-smi",
1055 "subsys-ipe-gals";
1057 #power-domain-cells = <0>;
1060 power-domain@MT8186_POWER_DOMAIN_VENC {
1064 clock-names = "venc0", "larb";
1066 #power-domain-cells = <0>;
1069 power-domain@MT8186_POWER_DOMAIN_WPE {
1074 clock-names = "wpe0",
1075 "subsys-larb-ck",
1076 "subsys-larb-pclk";
1078 #power-domain-cells = <0>;
1085 compatible = "mediatek,mt8186-wdt";
1086 mediatek,disable-extrst;
1088 #reset-cells = <1>;
1092 compatible = "mediatek,mt8186-apmixedsys", "syscon";
1094 #clock-cells = <1>;
1098 compatible = "mediatek,mt8186-pwrap", "syscon";
1100 reg-names = "pwrap";
1104 clock-names = "spi", "wrap";
1108 compatible = "mediatek,mt8186-spmi", "mediatek,mt8195-spmi";
1110 reg-names = "pmif", "spmimst";
1114 clock-names = "pmif_sys_ck", "pmif_tmr_ck", "spmimst_clk_mux";
1115 assigned-clocks = <&topckgen CLK_TOP_SPMI_MST>;
1116 assigned-clock-parents = <&topckgen CLK_TOP_ULPOSC1_D10>;
1123 compatible = "mediatek,mt8186-timer",
1124 "mediatek,mt6765-timer";
1131 compatible = "mediatek,mt8186-gce";
1134 clock-names = "gce";
1136 #mbox-cells = <2>;
1140 compatible = "mediatek,mt8186-scp";
1143 reg-names = "sram", "cfg";
1148 compatible = "mediatek,mt8186-dsp";
1151 reg-names = "cfg", "sram", "sec", "bus";
1153 clock-names = "audiodsp", "adsp_bus";
1154 assigned-clocks = <&topckgen CLK_TOP_AUDIODSP>,
1156 assigned-clock-parents = <&clk26m>, <&topckgen CLK_TOP_MAINPLL_D2_D2>;
1157 mbox-names = "rx", "tx";
1159 power-domains = <&spm MT8186_POWER_DOMAIN_ADSP_TOP>;
1164 compatible = "mediatek,mt8186-adsp-mbox";
1165 #mbox-cells = <0>;
1171 compatible = "mediatek,mt8186-adsp-mbox";
1172 #mbox-cells = <0>;
1178 compatible = "mediatek,mt8186-nor";
1184 clock-names = "spi", "sf", "axi", "axi_s";
1185 assigned-clocks = <&topckgen CLK_TOP_SPINOR>;
1186 assigned-clock-parents = <&topckgen CLK_TOP_UNIVPLL_D3_D8>;
1192 compatible = "mediatek,mt8186-auxadc", "mediatek,mt8173-auxadc";
1194 #io-channel-cells = <1>;
1196 clock-names = "main";
1200 compatible = "mediatek,mt8186-uart",
1201 "mediatek,mt6577-uart";
1205 clock-names = "baud", "bus";
1210 compatible = "mediatek,mt8186-uart",
1211 "mediatek,mt6577-uart";
1215 clock-names = "baud", "bus";
1220 compatible = "mediatek,mt8186-i2c";
1226 clock-names = "main", "dma";
1227 clock-div = <1>;
1228 #address-cells = <1>;
1229 #size-cells = <0>;
1234 compatible = "mediatek,mt8186-i2c";
1240 clock-names = "main", "dma";
1241 clock-div = <1>;
1242 #address-cells = <1>;
1243 #size-cells = <0>;
1248 compatible = "mediatek,mt8186-i2c";
1254 clock-names = "main", "dma";
1255 clock-div = <1>;
1256 #address-cells = <1>;
1257 #size-cells = <0>;
1262 compatible = "mediatek,mt8186-i2c";
1268 clock-names = "main", "dma";
1269 clock-div = <1>;
1270 #address-cells = <1>;
1271 #size-cells = <0>;
1276 compatible = "mediatek,mt8186-i2c";
1282 clock-names = "main", "dma";
1283 clock-div = <1>;
1284 #address-cells = <1>;
1285 #size-cells = <0>;
1290 compatible = "mediatek,mt8186-i2c";
1296 clock-names = "main", "dma";
1297 clock-div = <1>;
1298 #address-cells = <1>;
1299 #size-cells = <0>;
1304 compatible = "mediatek,mt8186-i2c";
1310 clock-names = "main", "dma";
1311 clock-div = <1>;
1312 #address-cells = <1>;
1313 #size-cells = <0>;
1318 compatible = "mediatek,mt8186-i2c";
1324 clock-names = "main", "dma";
1325 clock-div = <1>;
1326 #address-cells = <1>;
1327 #size-cells = <0>;
1332 compatible = "mediatek,mt8186-i2c";
1338 clock-names = "main", "dma";
1339 clock-div = <1>;
1340 #address-cells = <1>;
1341 #size-cells = <0>;
1346 compatible = "mediatek,mt8186-spi", "mediatek,mt6765-spi";
1347 #address-cells = <1>;
1348 #size-cells = <0>;
1354 clock-names = "parent-clk", "sel-clk", "spi-clk";
1359 compatible = "mediatek,mt8186-disp-pwm", "mediatek,mt8183-disp-pwm";
1362 #pwm-cells = <2>;
1365 clock-names = "main", "mm";
1370 compatible = "mediatek,mt8186-spi", "mediatek,mt6765-spi";
1371 #address-cells = <1>;
1372 #size-cells = <0>;
1378 clock-names = "parent-clk", "sel-clk", "spi-clk";
1383 compatible = "mediatek,mt8186-spi", "mediatek,mt6765-spi";
1384 #address-cells = <1>;
1385 #size-cells = <0>;
1391 clock-names = "parent-clk", "sel-clk", "spi-clk";
1396 compatible = "mediatek,mt8186-spi", "mediatek,mt6765-spi";
1397 #address-cells = <1>;
1398 #size-cells = <0>;
1404 clock-names = "parent-clk", "sel-clk", "spi-clk";
1409 compatible = "mediatek,mt8186-spi", "mediatek,mt6765-spi";
1410 #address-cells = <1>;
1411 #size-cells = <0>;
1417 clock-names = "parent-clk", "sel-clk", "spi-clk";
1422 compatible = "mediatek,mt8186-spi", "mediatek,mt6765-spi";
1423 #address-cells = <1>;
1424 #size-cells = <0>;
1430 clock-names = "parent-clk", "sel-clk", "spi-clk";
1434 imp_iic_wrap: clock-controller@11017000 {
1435 compatible = "mediatek,mt8186-imp_iic_wrap";
1437 #clock-cells = <1>;
1441 compatible = "mediatek,mt8186-uart",
1442 "mediatek,mt6577-uart";
1446 clock-names = "baud", "bus";
1451 compatible = "mediatek,mt8186-i2c";
1457 clock-names = "main", "dma";
1458 clock-div = <1>;
1459 #address-cells = <1>;
1460 #size-cells = <0>;
1464 afe: audio-controller@11210000 {
1465 compatible = "mediatek,mt8186-sound";
1492 clock-names = "aud_infra_clk",
1522 reset-names = "audiosys";
1527 compatible = "mediatek,mt8186-mtu3", "mediatek,mtu3";
1529 reg-names = "mac", "ippc";
1534 clock-names = "sys_ck", "ref_ck", "mcu_ck", "dma_ck";
1537 power-domains = <&spm MT8186_POWER_DOMAIN_SSUSB>;
1538 #address-cells = <2>;
1539 #size-cells = <2>;
1544 compatible = "mediatek,mt8186-xhci", "mediatek,mtk-xhci";
1546 reg-names = "mac";
1552 clock-names = "sys_ck", "ref_ck", "mcu_ck", "dma_ck", "xhci_ck";
1554 mediatek,syscon-wakeup = <&pericfg 0x420 2>;
1555 wakeup-source;
1561 compatible = "mediatek,mt8186-mmc",
1562 "mediatek,mt8183-mmc";
1569 clock-names = "source", "hclk", "source_cg", "crypto";
1571 assigned-clocks = <&topckgen CLK_TOP_MSDC50_0>;
1572 assigned-clock-parents = <&apmixedsys CLK_APMIXED_MSDCPLL>;
1577 compatible = "mediatek,mt8186-mmc",
1578 "mediatek,mt8183-mmc";
1584 clock-names = "source", "hclk", "source_cg";
1586 assigned-clocks = <&topckgen CLK_TOP_MSDC30_1>;
1587 assigned-clock-parents = <&topckgen CLK_TOP_MSDCPLL_D2>;
1592 compatible = "mediatek,mt8186-mtu3", "mediatek,mtu3";
1594 reg-names = "mac", "ippc";
1599 clock-names = "sys_ck", "ref_ck", "mcu_ck", "dma_ck";
1602 power-domains = <&spm MT8186_POWER_DOMAIN_SSUSB_P1>;
1603 #address-cells = <2>;
1604 #size-cells = <2>;
1609 compatible = "mediatek,mt8186-xhci", "mediatek,mtk-xhci";
1611 reg-names = "mac";
1617 clock-names = "sys_ck", "ref_ck", "mcu_ck", "dma_ck","xhci_ck";
1619 mediatek,syscon-wakeup = <&pericfg 0x424 2>;
1620 wakeup-source;
1625 u3phy0: t-phy@11c80000 {
1626 compatible = "mediatek,mt8186-tphy",
1627 "mediatek,generic-tphy-v2";
1628 #address-cells = <1>;
1629 #size-cells = <1>;
1633 u2port1: usb-phy@0 {
1636 clock-names = "ref";
1637 #phy-cells = <1>;
1640 u3port1: usb-phy@700 {
1643 clock-names = "ref";
1644 #phy-cells = <1>;
1648 u3phy1: t-phy@11ca0000 {
1649 compatible = "mediatek,mt8186-tphy",
1650 "mediatek,generic-tphy-v2";
1651 #address-cells = <1>;
1652 #size-cells = <1>;
1656 u2port0: usb-phy@0 {
1659 clock-names = "ref";
1660 #phy-cells = <1>;
1666 compatible = "mediatek,mt8186-efuse", "mediatek,efuse";
1668 #address-cells = <1>;
1669 #size-cells = <1>;
1671 gpu_speedbin: gpu-speedbin@59c {
1677 mipi_tx0: dsi-phy@11cc0000 {
1678 compatible = "mediatek,mt8183-mipi-tx";
1681 #clock-cells = <0>;
1682 #phy-cells = <0>;
1683 clock-output-names = "mipi_tx0_pll";
1687 mfgsys: clock-controller@13000000 {
1688 compatible = "mediatek,mt8186-mfgsys";
1690 #clock-cells = <1>;
1694 compatible = "mediatek,mt8186-mali",
1695 "arm,mali-bifrost";
1702 interrupt-names = "job", "mmu", "gpu";
1703 power-domains = <&spm MT8186_POWER_DOMAIN_MFG2>,
1705 power-domain-names = "core0", "core1";
1706 #cooling-cells = <2>;
1707 nvmem-cells = <&gpu_speedbin>;
1708 nvmem-cell-names = "speed-bin";
1709 operating-points-v2 = <&gpu_opp_table>;
1710 dynamic-power-coefficient = <4687>;
1715 compatible = "mediatek,mt8186-mmsys", "syscon";
1717 #clock-cells = <1>;
1718 #reset-cells = <1>;
1721 mediatek,gce-client-reg = <&gce SUBSYS_1400XXXX 0 0x1000>;
1725 compatible = "mediatek,mt8186-disp-mutex";
1729 mediatek,gce-client-reg = <&gce SUBSYS_1401XXXX 0x1000 0x1000>;
1730 mediatek,gce-events = <CMDQ_EVENT_DISP_STREAM_DONE_ENG_EVENT_0>,
1732 power-domains = <&spm MT8186_POWER_DOMAIN_DIS>;
1736 compatible = "mediatek,mt8186-smi-common";
1740 clock-names = "apb", "smi", "gals0", "gals1";
1741 power-domains = <&spm MT8186_POWER_DOMAIN_DIS>;
1745 compatible = "mediatek,mt8186-smi-larb";
1749 clock-names = "apb", "smi";
1750 mediatek,larb-id = <0>;
1752 power-domains = <&spm MT8186_POWER_DOMAIN_DIS>;
1756 compatible = "mediatek,mt8186-smi-larb";
1760 clock-names = "apb", "smi";
1761 mediatek,larb-id = <1>;
1763 power-domains = <&spm MT8186_POWER_DOMAIN_DIS>;
1767 compatible = "mediatek,mt8186-disp-ovl", "mediatek,mt8192-disp-ovl";
1772 mediatek,gce-client-reg = <&gce SUBSYS_1400XXXX 0x5000 0x1000>;
1773 power-domains = <&spm MT8186_POWER_DOMAIN_DIS>;
1777 compatible = "mediatek,mt8186-disp-ovl-2l", "mediatek,mt8192-disp-ovl-2l";
1782 mediatek,gce-client-reg = <&gce SUBSYS_1400XXXX 0x6000 0x1000>;
1783 power-domains = <&spm MT8186_POWER_DOMAIN_DIS>;
1787 compatible = "mediatek,mt8186-disp-rdma", "mediatek,mt8183-disp-rdma";
1792 mediatek,gce-client-reg = <&gce SUBSYS_1400XXXX 0x7000 0x1000>;
1793 power-domains = <&spm MT8186_POWER_DOMAIN_DIS>;
1797 compatible = "mediatek,mt8186-disp-color", "mediatek,mt8173-disp-color";
1801 mediatek,gce-client-reg = <&gce SUBSYS_1400XXXX 0x8000 0x1000>;
1802 power-domains = <&spm MT8186_POWER_DOMAIN_DIS>;
1806 compatible = "mediatek,mt8186-dpi";
1811 clock-names = "pixel", "engine", "pll";
1812 assigned-clocks = <&topckgen CLK_TOP_DPI>;
1813 assigned-clock-parents = <&topckgen CLK_TOP_TVDPLL_D2>;
1823 compatible = "mediatek,mt8186-disp-ccorr", "mediatek,mt8192-disp-ccorr";
1827 mediatek,gce-client-reg = <&gce SUBSYS_1400XXXX 0xb000 0x1000>;
1828 power-domains = <&spm MT8186_POWER_DOMAIN_DIS>;
1832 compatible = "mediatek,mt8186-disp-aal", "mediatek,mt8183-disp-aal";
1836 mediatek,gce-client-reg = <&gce SUBSYS_1400XXXX 0xc000 0x1000>;
1837 power-domains = <&spm MT8186_POWER_DOMAIN_DIS>;
1841 compatible = "mediatek,mt8186-disp-gamma", "mediatek,mt8183-disp-gamma";
1845 mediatek,gce-client-reg = <&gce SUBSYS_1400XXXX 0xd000 0x1000>;
1846 power-domains = <&spm MT8186_POWER_DOMAIN_DIS>;
1850 compatible = "mediatek,mt8186-disp-postmask",
1851 "mediatek,mt8192-disp-postmask";
1855 mediatek,gce-client-reg = <&gce SUBSYS_1400XXXX 0xe000 0x1000>;
1856 power-domains = <&spm MT8186_POWER_DOMAIN_DIS>;
1860 compatible = "mediatek,mt8186-disp-dither", "mediatek,mt8183-disp-dither";
1864 mediatek,gce-client-reg = <&gce SUBSYS_1400XXXX 0xf000 0x1000>;
1865 power-domains = <&spm MT8186_POWER_DOMAIN_DIS>;
1869 compatible = "mediatek,mt8186-dsi";
1874 clock-names = "engine", "digital", "hs";
1876 power-domains = <&spm MT8186_POWER_DOMAIN_DIS>;
1879 phy-names = "dphy";
1888 compatible = "mediatek,mt8186-iommu-mm";
1891 clock-names = "bclk";
1897 power-domains = <&spm MT8186_POWER_DOMAIN_DIS>;
1898 #iommu-cells = <1>;
1902 compatible = "mediatek,mt8186-disp-rdma", "mediatek,mt8183-disp-rdma";
1907 mediatek,gce-client-reg = <&gce SUBSYS_1401XXXX 0xf000 0x1000>;
1908 power-domains = <&spm MT8186_POWER_DOMAIN_DIS>;
1911 wpesys: clock-controller@14020000 {
1912 compatible = "mediatek,mt8186-wpesys";
1914 #clock-cells = <1>;
1918 compatible = "mediatek,mt8186-smi-larb";
1922 clock-names = "apb", "smi";
1923 mediatek,larb-id = <8>;
1925 power-domains = <&spm MT8186_POWER_DOMAIN_WPE>;
1928 imgsys1: clock-controller@15020000 {
1929 compatible = "mediatek,mt8186-imgsys1";
1931 #clock-cells = <1>;
1935 compatible = "mediatek,mt8186-smi-larb";
1939 clock-names = "apb", "smi";
1940 mediatek,larb-id = <9>;
1942 power-domains = <&spm MT8186_POWER_DOMAIN_IMG>;
1945 imgsys2: clock-controller@15820000 {
1946 compatible = "mediatek,mt8186-imgsys2";
1948 #clock-cells = <1>;
1952 compatible = "mediatek,mt8186-smi-larb";
1956 clock-names = "apb", "smi";
1957 mediatek,larb-id = <11>;
1959 power-domains = <&spm MT8186_POWER_DOMAIN_IMG2>;
1963 compatible = "mediatek,mt8186-smi-larb";
1967 clock-names = "apb", "smi";
1968 mediatek,larb-id = <4>;
1970 power-domains = <&spm MT8186_POWER_DOMAIN_VDEC>;
1973 vdecsys: clock-controller@1602f000 {
1974 compatible = "mediatek,mt8186-vdecsys";
1976 #clock-cells = <1>;
1979 vencsys: clock-controller@17000000 {
1980 compatible = "mediatek,mt8186-vencsys";
1982 #clock-cells = <1>;
1986 compatible = "mediatek,mt8186-smi-larb";
1990 clock-names = "apb", "smi";
1991 mediatek,larb-id = <7>;
1993 power-domains = <&spm MT8186_POWER_DOMAIN_VENC>;
1996 camsys: clock-controller@1a000000 {
1997 compatible = "mediatek,mt8186-camsys";
1999 #clock-cells = <1>;
2003 compatible = "mediatek,mt8186-smi-larb";
2006 clock-names = "apb", "smi";
2007 mediatek,larb-id = <13>;
2009 power-domains = <&spm MT8186_POWER_DOMAIN_CAM>;
2013 compatible = "mediatek,mt8186-smi-larb";
2016 clock-names = "apb", "smi";
2017 mediatek,larb-id = <14>;
2019 power-domains = <&spm MT8186_POWER_DOMAIN_CAM>;
2023 compatible = "mediatek,mt8186-smi-larb";
2027 clock-names = "apb", "smi";
2028 mediatek,larb-id = <16>;
2030 power-domains = <&spm MT8186_POWER_DOMAIN_CAM_RAWA>;
2034 compatible = "mediatek,mt8186-smi-larb";
2038 clock-names = "apb", "smi";
2039 mediatek,larb-id = <17>;
2041 power-domains = <&spm MT8186_POWER_DOMAIN_CAM_RAWB>;
2044 camsys_rawa: clock-controller@1a04f000 {
2045 compatible = "mediatek,mt8186-camsys_rawa";
2047 #clock-cells = <1>;
2050 camsys_rawb: clock-controller@1a06f000 {
2051 compatible = "mediatek,mt8186-camsys_rawb";
2053 #clock-cells = <1>;
2056 mdpsys: clock-controller@1b000000 {
2057 compatible = "mediatek,mt8186-mdpsys";
2059 #clock-cells = <1>;
2063 compatible = "mediatek,mt8186-smi-larb";
2066 clock-names = "apb", "smi";
2067 mediatek,larb-id = <2>;
2069 power-domains = <&spm MT8186_POWER_DOMAIN_DIS>;
2072 ipesys: clock-controller@1c000000 {
2073 compatible = "mediatek,mt8186-ipesys";
2075 #clock-cells = <1>;
2079 compatible = "mediatek,mt8186-smi-larb";
2082 clock-names = "apb", "smi";
2083 mediatek,larb-id = <20>;
2085 power-domains = <&spm MT8186_POWER_DOMAIN_IPE>;
2089 compatible = "mediatek,mt8186-smi-larb";
2092 clock-names = "apb", "smi";
2093 mediatek,larb-id = <19>;
2095 power-domains = <&spm MT8186_POWER_DOMAIN_IPE>;