1 // SPDX-License-Identifier: GPL-2.0-only
2 /**
3 * dts file for Hisilicon D05 Development Board
4 *
5 * Copyright (C) 2016 HiSilicon Ltd.
6 */
7
8 #include <dt-bindings/interrupt-controller/arm-gic.h>
9
10 / {
11 compatible = "hisilicon,hip07-d05";
12 interrupt-parent = <&gic>;
13 #address-cells = <2>;
14 #size-cells = <2>;
15
16 psci {
17 compatible = "arm,psci-0.2";
18 method = "smc";
19 };
20
21 cpus {
22 #address-cells = <1>;
23 #size-cells = <0>;
24
25 cpu-map {
26 cluster0 {
27 core0 {
28 cpu = <&cpu0>;
29 };
30 core1 {
31 cpu = <&cpu1>;
32 };
33 core2 {
34 cpu = <&cpu2>;
35 };
36 core3 {
37 cpu = <&cpu3>;
38 };
39 };
40
41 cluster1 {
42 core0 {
43 cpu = <&cpu4>;
44 };
45 core1 {
46 cpu = <&cpu5>;
47 };
48 core2 {
49 cpu = <&cpu6>;
50 };
51 core3 {
52 cpu = <&cpu7>;
53 };
54 };
55
56 cluster2 {
57 core0 {
58 cpu = <&cpu8>;
59 };
60 core1 {
61 cpu = <&cpu9>;
62 };
63 core2 {
64 cpu = <&cpu10>;
65 };
66 core3 {
67 cpu = <&cpu11>;
68 };
69 };
70
71 cluster3 {
72 core0 {
73 cpu = <&cpu12>;
74 };
75 core1 {
76 cpu = <&cpu13>;
77 };
78 core2 {
79 cpu = <&cpu14>;
80 };
81 core3 {
82 cpu = <&cpu15>;
83 };
84 };
85
86 cluster4 {
87 core0 {
88 cpu = <&cpu16>;
89 };
90 core1 {
91 cpu = <&cpu17>;
92 };
93 core2 {
94 cpu = <&cpu18>;
95 };
96 core3 {
97 cpu = <&cpu19>;
98 };
99 };
100
101 cluster5 {
102 core0 {
103 cpu = <&cpu20>;
104 };
105 core1 {
106 cpu = <&cpu21>;
107 };
108 core2 {
109 cpu = <&cpu22>;
110 };
111 core3 {
112 cpu = <&cpu23>;
113 };
114 };
115
116 cluster6 {
117 core0 {
118 cpu = <&cpu24>;
119 };
120 core1 {
121 cpu = <&cpu25>;
122 };
123 core2 {
124 cpu = <&cpu26>;
125 };
126 core3 {
127 cpu = <&cpu27>;
128 };
129 };
130
131 cluster7 {
132 core0 {
133 cpu = <&cpu28>;
134 };
135 core1 {
136 cpu = <&cpu29>;
137 };
138 core2 {
139 cpu = <&cpu30>;
140 };
141 core3 {
142 cpu = <&cpu31>;
143 };
144 };
145
146 cluster8 {
147 core0 {
148 cpu = <&cpu32>;
149 };
150 core1 {
151 cpu = <&cpu33>;
152 };
153 core2 {
154 cpu = <&cpu34>;
155 };
156 core3 {
157 cpu = <&cpu35>;
158 };
159 };
160
161 cluster9 {
162 core0 {
163 cpu = <&cpu36>;
164 };
165 core1 {
166 cpu = <&cpu37>;
167 };
168 core2 {
169 cpu = <&cpu38>;
170 };
171 core3 {
172 cpu = <&cpu39>;
173 };
174 };
175
176 cluster10 {
177 core0 {
178 cpu = <&cpu40>;
179 };
180 core1 {
181 cpu = <&cpu41>;
182 };
183 core2 {
184 cpu = <&cpu42>;
185 };
186 core3 {
187 cpu = <&cpu43>;
188 };
189 };
190
191 cluster11 {
192 core0 {
193 cpu = <&cpu44>;
194 };
195 core1 {
196 cpu = <&cpu45>;
197 };
198 core2 {
199 cpu = <&cpu46>;
200 };
201 core3 {
202 cpu = <&cpu47>;
203 };
204 };
205
206 cluster12 {
207 core0 {
208 cpu = <&cpu48>;
209 };
210 core1 {
211 cpu = <&cpu49>;
212 };
213 core2 {
214 cpu = <&cpu50>;
215 };
216 core3 {
217 cpu = <&cpu51>;
218 };
219 };
220
221 cluster13 {
222 core0 {
223 cpu = <&cpu52>;
224 };
225 core1 {
226 cpu = <&cpu53>;
227 };
228 core2 {
229 cpu = <&cpu54>;
230 };
231 core3 {
232 cpu = <&cpu55>;
233 };
234 };
235
236 cluster14 {
237 core0 {
238 cpu = <&cpu56>;
239 };
240 core1 {
241 cpu = <&cpu57>;
242 };
243 core2 {
244 cpu = <&cpu58>;
245 };
246 core3 {
247 cpu = <&cpu59>;
248 };
249 };
250
251 cluster15 {
252 core0 {
253 cpu = <&cpu60>;
254 };
255 core1 {
256 cpu = <&cpu61>;
257 };
258 core2 {
259 cpu = <&cpu62>;
260 };
261 core3 {
262 cpu = <&cpu63>;
263 };
264 };
265 };
266
267 cpu0: cpu@10000 {
268 device_type = "cpu";
269 compatible = "arm,cortex-a72";
270 reg = <0x10000>;
271 enable-method = "psci";
272 next-level-cache = <&cluster0_l2>;
273 numa-node-id = <0>;
274 };
275
276 cpu1: cpu@10001 {
277 device_type = "cpu";
278 compatible = "arm,cortex-a72";
279 reg = <0x10001>;
280 enable-method = "psci";
281 next-level-cache = <&cluster0_l2>;
282 numa-node-id = <0>;
283 };
284
285 cpu2: cpu@10002 {
286 device_type = "cpu";
287 compatible = "arm,cortex-a72";
288 reg = <0x10002>;
289 enable-method = "psci";
290 next-level-cache = <&cluster0_l2>;
291 numa-node-id = <0>;
292 };
293
294 cpu3: cpu@10003 {
295 device_type = "cpu";
296 compatible = "arm,cortex-a72";
297 reg = <0x10003>;
298 enable-method = "psci";
299 next-level-cache = <&cluster0_l2>;
300 numa-node-id = <0>;
301 };
302
303 cpu4: cpu@10100 {
304 device_type = "cpu";
305 compatible = "arm,cortex-a72";
306 reg = <0x10100>;
307 enable-method = "psci";
308 next-level-cache = <&cluster1_l2>;
309 numa-node-id = <0>;
310 };
311
312 cpu5: cpu@10101 {
313 device_type = "cpu";
314 compatible = "arm,cortex-a72";
315 reg = <0x10101>;
316 enable-method = "psci";
317 next-level-cache = <&cluster1_l2>;
318 numa-node-id = <0>;
319 };
320
321 cpu6: cpu@10102 {
322 device_type = "cpu";
323 compatible = "arm,cortex-a72";
324 reg = <0x10102>;
325 enable-method = "psci";
326 next-level-cache = <&cluster1_l2>;
327 numa-node-id = <0>;
328 };
329
330 cpu7: cpu@10103 {
331 device_type = "cpu";
332 compatible = "arm,cortex-a72";
333 reg = <0x10103>;
334 enable-method = "psci";
335 next-level-cache = <&cluster1_l2>;
336 numa-node-id = <0>;
337 };
338
339 cpu8: cpu@10200 {
340 device_type = "cpu";
341 compatible = "arm,cortex-a72";
342 reg = <0x10200>;
343 enable-method = "psci";
344 next-level-cache = <&cluster2_l2>;
345 numa-node-id = <0>;
346 };
347
348 cpu9: cpu@10201 {
349 device_type = "cpu";
350 compatible = "arm,cortex-a72";
351 reg = <0x10201>;
352 enable-method = "psci";
353 next-level-cache = <&cluster2_l2>;
354 numa-node-id = <0>;
355 };
356
357 cpu10: cpu@10202 {
358 device_type = "cpu";
359 compatible = "arm,cortex-a72";
360 reg = <0x10202>;
361 enable-method = "psci";
362 next-level-cache = <&cluster2_l2>;
363 numa-node-id = <0>;
364 };
365
366 cpu11: cpu@10203 {
367 device_type = "cpu";
368 compatible = "arm,cortex-a72";
369 reg = <0x10203>;
370 enable-method = "psci";
371 next-level-cache = <&cluster2_l2>;
372 numa-node-id = <0>;
373 };
374
375 cpu12: cpu@10300 {
376 device_type = "cpu";
377 compatible = "arm,cortex-a72";
378 reg = <0x10300>;
379 enable-method = "psci";
380 next-level-cache = <&cluster3_l2>;
381 numa-node-id = <0>;
382 };
383
384 cpu13: cpu@10301 {
385 device_type = "cpu";
386 compatible = "arm,cortex-a72";
387 reg = <0x10301>;
388 enable-method = "psci";
389 next-level-cache = <&cluster3_l2>;
390 numa-node-id = <0>;
391 };
392
393 cpu14: cpu@10302 {
394 device_type = "cpu";
395 compatible = "arm,cortex-a72";
396 reg = <0x10302>;
397 enable-method = "psci";
398 next-level-cache = <&cluster3_l2>;
399 numa-node-id = <0>;
400 };
401
402 cpu15: cpu@10303 {
403 device_type = "cpu";
404 compatible = "arm,cortex-a72";
405 reg = <0x10303>;
406 enable-method = "psci";
407 next-level-cache = <&cluster3_l2>;
408 numa-node-id = <0>;
409 };
410
411 cpu16: cpu@30000 {
412 device_type = "cpu";
413 compatible = "arm,cortex-a72";
414 reg = <0x30000>;
415 enable-method = "psci";
416 next-level-cache = <&cluster4_l2>;
417 numa-node-id = <1>;
418 };
419
420 cpu17: cpu@30001 {
421 device_type = "cpu";
422 compatible = "arm,cortex-a72";
423 reg = <0x30001>;
424 enable-method = "psci";
425 next-level-cache = <&cluster4_l2>;
426 numa-node-id = <1>;
427 };
428
429 cpu18: cpu@30002 {
430 device_type = "cpu";
431 compatible = "arm,cortex-a72";
432 reg = <0x30002>;
433 enable-method = "psci";
434 next-level-cache = <&cluster4_l2>;
435 numa-node-id = <1>;
436 };
437
438 cpu19: cpu@30003 {
439 device_type = "cpu";
440 compatible = "arm,cortex-a72";
441 reg = <0x30003>;
442 enable-method = "psci";
443 next-level-cache = <&cluster4_l2>;
444 numa-node-id = <1>;
445 };
446
447 cpu20: cpu@30100 {
448 device_type = "cpu";
449 compatible = "arm,cortex-a72";
450 reg = <0x30100>;
451 enable-method = "psci";
452 next-level-cache = <&cluster5_l2>;
453 numa-node-id = <1>;
454 };
455
456 cpu21: cpu@30101 {
457 device_type = "cpu";
458 compatible = "arm,cortex-a72";
459 reg = <0x30101>;
460 enable-method = "psci";
461 next-level-cache = <&cluster5_l2>;
462 numa-node-id = <1>;
463 };
464
465 cpu22: cpu@30102 {
466 device_type = "cpu";
467 compatible = "arm,cortex-a72";
468 reg = <0x30102>;
469 enable-method = "psci";
470 next-level-cache = <&cluster5_l2>;
471 numa-node-id = <1>;
472 };
473
474 cpu23: cpu@30103 {
475 device_type = "cpu";
476 compatible = "arm,cortex-a72";
477 reg = <0x30103>;
478 enable-method = "psci";
479 next-level-cache = <&cluster5_l2>;
480 numa-node-id = <1>;
481 };
482
483 cpu24: cpu@30200 {
484 device_type = "cpu";
485 compatible = "arm,cortex-a72";
486 reg = <0x30200>;
487 enable-method = "psci";
488 next-level-cache = <&cluster6_l2>;
489 numa-node-id = <1>;
490 };
491
492 cpu25: cpu@30201 {
493 device_type = "cpu";
494 compatible = "arm,cortex-a72";
495 reg = <0x30201>;
496 enable-method = "psci";
497 next-level-cache = <&cluster6_l2>;
498 numa-node-id = <1>;
499 };
500
501 cpu26: cpu@30202 {
502 device_type = "cpu";
503 compatible = "arm,cortex-a72";
504 reg = <0x30202>;
505 enable-method = "psci";
506 next-level-cache = <&cluster6_l2>;
507 numa-node-id = <1>;
508 };
509
510 cpu27: cpu@30203 {
511 device_type = "cpu";
512 compatible = "arm,cortex-a72";
513 reg = <0x30203>;
514 enable-method = "psci";
515 next-level-cache = <&cluster6_l2>;
516 numa-node-id = <1>;
517 };
518
519 cpu28: cpu@30300 {
520 device_type = "cpu";
521 compatible = "arm,cortex-a72";
522 reg = <0x30300>;
523 enable-method = "psci";
524 next-level-cache = <&cluster7_l2>;
525 numa-node-id = <1>;
526 };
527
528 cpu29: cpu@30301 {
529 device_type = "cpu";
530 compatible = "arm,cortex-a72";
531 reg = <0x30301>;
532 enable-method = "psci";
533 next-level-cache = <&cluster7_l2>;
534 numa-node-id = <1>;
535 };
536
537 cpu30: cpu@30302 {
538 device_type = "cpu";
539 compatible = "arm,cortex-a72";
540 reg = <0x30302>;
541 enable-method = "psci";
542 next-level-cache = <&cluster7_l2>;
543 numa-node-id = <1>;
544 };
545
546 cpu31: cpu@30303 {
547 device_type = "cpu";
548 compatible = "arm,cortex-a72";
549 reg = <0x30303>;
550 enable-method = "psci";
551 next-level-cache = <&cluster7_l2>;
552 numa-node-id = <1>;
553 };
554
555 cpu32: cpu@50000 {
556 device_type = "cpu";
557 compatible = "arm,cortex-a72";
558 reg = <0x50000>;
559 enable-method = "psci";
560 next-level-cache = <&cluster8_l2>;
561 numa-node-id = <2>;
562 };
563
564 cpu33: cpu@50001 {
565 device_type = "cpu";
566 compatible = "arm,cortex-a72";
567 reg = <0x50001>;
568 enable-method = "psci";
569 next-level-cache = <&cluster8_l2>;
570 numa-node-id = <2>;
571 };
572
573 cpu34: cpu@50002 {
574 device_type = "cpu";
575 compatible = "arm,cortex-a72";
576 reg = <0x50002>;
577 enable-method = "psci";
578 next-level-cache = <&cluster8_l2>;
579 numa-node-id = <2>;
580 };
581
582 cpu35: cpu@50003 {
583 device_type = "cpu";
584 compatible = "arm,cortex-a72";
585 reg = <0x50003>;
586 enable-method = "psci";
587 next-level-cache = <&cluster8_l2>;
588 numa-node-id = <2>;
589 };
590
591 cpu36: cpu@50100 {
592 device_type = "cpu";
593 compatible = "arm,cortex-a72";
594 reg = <0x50100>;
595 enable-method = "psci";
596 next-level-cache = <&cluster9_l2>;
597 numa-node-id = <2>;
598 };
599
600 cpu37: cpu@50101 {
601 device_type = "cpu";
602 compatible = "arm,cortex-a72";
603 reg = <0x50101>;
604 enable-method = "psci";
605 next-level-cache = <&cluster9_l2>;
606 numa-node-id = <2>;
607 };
608
609 cpu38: cpu@50102 {
610 device_type = "cpu";
611 compatible = "arm,cortex-a72";
612 reg = <0x50102>;
613 enable-method = "psci";
614 next-level-cache = <&cluster9_l2>;
615 numa-node-id = <2>;
616 };
617
618 cpu39: cpu@50103 {
619 device_type = "cpu";
620 compatible = "arm,cortex-a72";
621 reg = <0x50103>;
622 enable-method = "psci";
623 next-level-cache = <&cluster9_l2>;
624 numa-node-id = <2>;
625 };
626
627 cpu40: cpu@50200 {
628 device_type = "cpu";
629 compatible = "arm,cortex-a72";
630 reg = <0x50200>;
631 enable-method = "psci";
632 next-level-cache = <&cluster10_l2>;
633 numa-node-id = <2>;
634 };
635
636 cpu41: cpu@50201 {
637 device_type = "cpu";
638 compatible = "arm,cortex-a72";
639 reg = <0x50201>;
640 enable-method = "psci";
641 next-level-cache = <&cluster10_l2>;
642 numa-node-id = <2>;
643 };
644
645 cpu42: cpu@50202 {
646 device_type = "cpu";
647 compatible = "arm,cortex-a72";
648 reg = <0x50202>;
649 enable-method = "psci";
650 next-level-cache = <&cluster10_l2>;
651 numa-node-id = <2>;
652 };
653
654 cpu43: cpu@50203 {
655 device_type = "cpu";
656 compatible = "arm,cortex-a72";
657 reg = <0x50203>;
658 enable-method = "psci";
659 next-level-cache = <&cluster10_l2>;
660 numa-node-id = <2>;
661 };
662
663 cpu44: cpu@50300 {
664 device_type = "cpu";
665 compatible = "arm,cortex-a72";
666 reg = <0x50300>;
667 enable-method = "psci";
668 next-level-cache = <&cluster11_l2>;
669 numa-node-id = <2>;
670 };
671
672 cpu45: cpu@50301 {
673 device_type = "cpu";
674 compatible = "arm,cortex-a72";
675 reg = <0x50301>;
676 enable-method = "psci";
677 next-level-cache = <&cluster11_l2>;
678 numa-node-id = <2>;
679 };
680
681 cpu46: cpu@50302 {
682 device_type = "cpu";
683 compatible = "arm,cortex-a72";
684 reg = <0x50302>;
685 enable-method = "psci";
686 next-level-cache = <&cluster11_l2>;
687 numa-node-id = <2>;
688 };
689
690 cpu47: cpu@50303 {
691 device_type = "cpu";
692 compatible = "arm,cortex-a72";
693 reg = <0x50303>;
694 enable-method = "psci";
695 next-level-cache = <&cluster11_l2>;
696 numa-node-id = <2>;
697 };
698
699 cpu48: cpu@70000 {
700 device_type = "cpu";
701 compatible = "arm,cortex-a72";
702 reg = <0x70000>;
703 enable-method = "psci";
704 next-level-cache = <&cluster12_l2>;
705 numa-node-id = <3>;
706 };
707
708 cpu49: cpu@70001 {
709 device_type = "cpu";
710 compatible = "arm,cortex-a72";
711 reg = <0x70001>;
712 enable-method = "psci";
713 next-level-cache = <&cluster12_l2>;
714 numa-node-id = <3>;
715 };
716
717 cpu50: cpu@70002 {
718 device_type = "cpu";
719 compatible = "arm,cortex-a72";
720 reg = <0x70002>;
721 enable-method = "psci";
722 next-level-cache = <&cluster12_l2>;
723 numa-node-id = <3>;
724 };
725
726 cpu51: cpu@70003 {
727 device_type = "cpu";
728 compatible = "arm,cortex-a72";
729 reg = <0x70003>;
730 enable-method = "psci";
731 next-level-cache = <&cluster12_l2>;
732 numa-node-id = <3>;
733 };
734
735 cpu52: cpu@70100 {
736 device_type = "cpu";
737 compatible = "arm,cortex-a72";
738 reg = <0x70100>;
739 enable-method = "psci";
740 next-level-cache = <&cluster13_l2>;
741 numa-node-id = <3>;
742 };
743
744 cpu53: cpu@70101 {
745 device_type = "cpu";
746 compatible = "arm,cortex-a72";
747 reg = <0x70101>;
748 enable-method = "psci";
749 next-level-cache = <&cluster13_l2>;
750 numa-node-id = <3>;
751 };
752
753 cpu54: cpu@70102 {
754 device_type = "cpu";
755 compatible = "arm,cortex-a72";
756 reg = <0x70102>;
757 enable-method = "psci";
758 next-level-cache = <&cluster13_l2>;
759 numa-node-id = <3>;
760 };
761
762 cpu55: cpu@70103 {
763 device_type = "cpu";
764 compatible = "arm,cortex-a72";
765 reg = <0x70103>;
766 enable-method = "psci";
767 next-level-cache = <&cluster13_l2>;
768 numa-node-id = <3>;
769 };
770
771 cpu56: cpu@70200 {
772 device_type = "cpu";
773 compatible = "arm,cortex-a72";
774 reg = <0x70200>;
775 enable-method = "psci";
776 next-level-cache = <&cluster14_l2>;
777 numa-node-id = <3>;
778 };
779
780 cpu57: cpu@70201 {
781 device_type = "cpu";
782 compatible = "arm,cortex-a72";
783 reg = <0x70201>;
784 enable-method = "psci";
785 next-level-cache = <&cluster14_l2>;
786 numa-node-id = <3>;
787 };
788
789 cpu58: cpu@70202 {
790 device_type = "cpu";
791 compatible = "arm,cortex-a72";
792 reg = <0x70202>;
793 enable-method = "psci";
794 next-level-cache = <&cluster14_l2>;
795 numa-node-id = <3>;
796 };
797
798 cpu59: cpu@70203 {
799 device_type = "cpu";
800 compatible = "arm,cortex-a72";
801 reg = <0x70203>;
802 enable-method = "psci";
803 next-level-cache = <&cluster14_l2>;
804 numa-node-id = <3>;
805 };
806
807 cpu60: cpu@70300 {
808 device_type = "cpu";
809 compatible = "arm,cortex-a72";
810 reg = <0x70300>;
811 enable-method = "psci";
812 next-level-cache = <&cluster15_l2>;
813 numa-node-id = <3>;
814 };
815
816 cpu61: cpu@70301 {
817 device_type = "cpu";
818 compatible = "arm,cortex-a72";
819 reg = <0x70301>;
820 enable-method = "psci";
821 next-level-cache = <&cluster15_l2>;
822 numa-node-id = <3>;
823 };
824
825 cpu62: cpu@70302 {
826 device_type = "cpu";
827 compatible = "arm,cortex-a72";
828 reg = <0x70302>;
829 enable-method = "psci";
830 next-level-cache = <&cluster15_l2>;
831 numa-node-id = <3>;
832 };
833
834 cpu63: cpu@70303 {
835 device_type = "cpu";
836 compatible = "arm,cortex-a72";
837 reg = <0x70303>;
838 enable-method = "psci";
839 next-level-cache = <&cluster15_l2>;
840 numa-node-id = <3>;
841 };
842
843 cluster0_l2: l2-cache0 {
844 compatible = "cache";
845 };
846
847 cluster1_l2: l2-cache1 {
848 compatible = "cache";
849 };
850
851 cluster2_l2: l2-cache2 {
852 compatible = "cache";
853 };
854
855 cluster3_l2: l2-cache3 {
856 compatible = "cache";
857 };
858
859 cluster4_l2: l2-cache4 {
860 compatible = "cache";
861 };
862
863 cluster5_l2: l2-cache5 {
864 compatible = "cache";
865 };
866
867 cluster6_l2: l2-cache6 {
868 compatible = "cache";
869 };
870
871 cluster7_l2: l2-cache7 {
872 compatible = "cache";
873 };
874
875 cluster8_l2: l2-cache8 {
876 compatible = "cache";
877 };
878
879 cluster9_l2: l2-cache9 {
880 compatible = "cache";
881 };
882
883 cluster10_l2: l2-cache10 {
884 compatible = "cache";
885 };
886
887 cluster11_l2: l2-cache11 {
888 compatible = "cache";
889 };
890
891 cluster12_l2: l2-cache12 {
892 compatible = "cache";
893 };
894
895 cluster13_l2: l2-cache13 {
896 compatible = "cache";
897 };
898
899 cluster14_l2: l2-cache14 {
900 compatible = "cache";
901 };
902
903 cluster15_l2: l2-cache15 {
904 compatible = "cache";
905 };
906 };
907
908 gic: interrupt-controller@4d000000 {
909 compatible = "arm,gic-v3";
910 #interrupt-cells = <3>;
911 #address-cells = <2>;
912 #size-cells = <2>;
913 ranges;
914 interrupt-controller;
915 #redistributor-regions = <4>;
916 redistributor-stride = <0x0 0x40000>;
917 reg = <0x0 0x4d000000 0x0 0x10000>, /* GICD */
918 <0x0 0x4d100000 0x0 0x400000>, /* p0 GICR node 0 */
919 <0x0 0x6d100000 0x0 0x400000>, /* p0 GICR node 1 */
920 <0x400 0x4d100000 0x0 0x400000>, /* p1 GICR node 2 */
921 <0x400 0x6d100000 0x0 0x400000>, /* p1 GICR node 3 */
922 <0x0 0xfe000000 0x0 0x10000>, /* GICC */
923 <0x0 0xfe010000 0x0 0x10000>, /* GICH */
924 <0x0 0xfe020000 0x0 0x10000>; /* GICV */
925 interrupts = <GIC_PPI 9 IRQ_TYPE_LEVEL_HIGH>;
926
927 p0_its_peri_a: msi-controller@4c000000 {
928 compatible = "arm,gic-v3-its";
929 msi-controller;
930 #msi-cells = <1>;
931 reg = <0x0 0x4c000000 0x0 0x40000>;
932 };
933
934 p0_its_peri_b: msi-controller@6c000000 {
935 compatible = "arm,gic-v3-its";
936 msi-controller;
937 #msi-cells = <1>;
938 reg = <0x0 0x6c000000 0x0 0x40000>;
939 };
940
941 p0_its_dsa_a: msi-controller@c6000000 {
942 compatible = "arm,gic-v3-its";
943 msi-controller;
944 #msi-cells = <1>;
945 reg = <0x0 0xc6000000 0x0 0x40000>;
946 };
947
948 p0_its_dsa_b: msi-controller@8c6000000 {
949 compatible = "arm,gic-v3-its";
950 msi-controller;
951 #msi-cells = <1>;
952 reg = <0x8 0xc6000000 0x0 0x40000>;
953 };
954
955 p1_its_peri_a: msi-controller@4004c000000 {
956 compatible = "arm,gic-v3-its";
957 msi-controller;
958 #msi-cells = <1>;
959 reg = <0x400 0x4c000000 0x0 0x40000>;
960 };
961
962 p1_its_peri_b: msi-controller@4006c000000 {
963 compatible = "arm,gic-v3-its";
964 msi-controller;
965 #msi-cells = <1>;
966 reg = <0x400 0x6c000000 0x0 0x40000>;
967 };
968
969 p1_its_dsa_a: msi-controller@400c6000000 {
970 compatible = "arm,gic-v3-its";
971 msi-controller;
972 #msi-cells = <1>;
973 reg = <0x400 0xc6000000 0x0 0x40000>;
974 };
975
976 p1_its_dsa_b: msi-controller@408c6000000 {
977 compatible = "arm,gic-v3-its";
978 msi-controller;
979 #msi-cells = <1>;
980 reg = <0x408 0xc6000000 0x0 0x40000>;
981 };
982 };
983
984 timer {
985 compatible = "arm,armv8-timer";
986 interrupts = <GIC_PPI 13 IRQ_TYPE_LEVEL_LOW>,
987 <GIC_PPI 14 IRQ_TYPE_LEVEL_LOW>,
988 <GIC_PPI 11 IRQ_TYPE_LEVEL_LOW>,
989 <GIC_PPI 10 IRQ_TYPE_LEVEL_LOW>;
990 };
991
992 pmu {
993 compatible = "arm,cortex-a72-pmu";
994 interrupts = <GIC_PPI 7 IRQ_TYPE_LEVEL_HIGH>;
995 };
996
997 p0_mbigen_peri_b: interrupt-controller@60080000 {
998 compatible = "hisilicon,mbigen-v2";
999 reg = <0x0 0x60080000 0x0 0x10000>;
1000
1001 mbigen_uart: uart_intc {
1002 msi-parent = <&p0_its_peri_b 0x120c7>;
1003 interrupt-controller;
1004 #interrupt-cells = <2>;
1005 num-pins = <1>;
1006 };
1007 };
1008
1009 p0_mbigen_pcie_a: interrupt-controller@a0080000 {
1010 compatible = "hisilicon,mbigen-v2";
1011 reg = <0x0 0xa0080000 0x0 0x10000>;
1012
1013 mbigen_pcie2_a: intc_pcie2_a {
1014 msi-parent = <&p0_its_dsa_a 0x40087>;
1015 interrupt-controller;
1016 #interrupt-cells = <2>;
1017 num-pins = <10>;
1018 };
1019
1020 mbigen_sas1: intc_sas1 {
1021 msi-parent = <&p0_its_dsa_a 0x40000>;
1022 interrupt-controller;
1023 #interrupt-cells = <2>;
1024 num-pins = <128>;
1025 };
1026
1027 mbigen_sas2: intc_sas2 {
1028 msi-parent = <&p0_its_dsa_a 0x40040>;
1029 interrupt-controller;
1030 #interrupt-cells = <2>;
1031 num-pins = <128>;
1032 };
1033
1034 mbigen_smmu_pcie: intc_smmu_pcie {
1035 msi-parent = <&p0_its_dsa_a 0x40b0c>;
1036 interrupt-controller;
1037 #interrupt-cells = <2>;
1038 num-pins = <3>;
1039 };
1040
1041 mbigen_usb: intc_usb {
1042 msi-parent = <&p0_its_dsa_a 0x40080>;
1043 interrupt-controller;
1044 #interrupt-cells = <2>;
1045 num-pins = <2>;
1046 };
1047 };
1048 p0_mbigen_alg_a:interrupt-controller@d0080000 {
1049 compatible = "hisilicon,mbigen-v2";
1050 reg = <0x0 0xd0080000 0x0 0x10000>;
1051
1052 p0_mbigen_sec_a: intc_sec {
1053 msi-parent = <&p0_its_dsa_a 0x40400>;
1054 interrupt-controller;
1055 #interrupt-cells = <2>;
1056 num-pins = <33>;
1057 };
1058 p0_mbigen_smmu_alg_a: intc_smmu_alg {
1059 msi-parent = <&p0_its_dsa_a 0x40b1b>;
1060 interrupt-controller;
1061 #interrupt-cells = <2>;
1062 num-pins = <3>;
1063 };
1064 };
1065 p0_mbigen_alg_b:interrupt-controller@8,d0080000 {
1066 compatible = "hisilicon,mbigen-v2";
1067 reg = <0x8 0xd0080000 0x0 0x10000>;
1068
1069 p0_mbigen_sec_b: intc_sec {
1070 msi-parent = <&p0_its_dsa_b 0x42400>;
1071 interrupt-controller;
1072 #interrupt-cells = <2>;
1073 num-pins = <33>;
1074 };
1075 p0_mbigen_smmu_alg_b: intc_smmu_alg {
1076 msi-parent = <&p0_its_dsa_b 0x42b1b>;
1077 interrupt-controller;
1078 #interrupt-cells = <2>;
1079 num-pins = <3>;
1080 };
1081 };
1082 p1_mbigen_alg_a:interrupt-controller@400,d0080000 {
1083 compatible = "hisilicon,mbigen-v2";
1084 reg = <0x400 0xd0080000 0x0 0x10000>;
1085
1086 p1_mbigen_sec_a: intc_sec {
1087 msi-parent = <&p1_its_dsa_a 0x44400>;
1088 interrupt-controller;
1089 #interrupt-cells = <2>;
1090 num-pins = <33>;
1091 };
1092 p1_mbigen_smmu_alg_a: intc_smmu_alg {
1093 msi-parent = <&p1_its_dsa_a 0x44b1b>;
1094 interrupt-controller;
1095 #interrupt-cells = <2>;
1096 num-pins = <3>;
1097 };
1098 };
1099 p1_mbigen_alg_b:interrupt-controller@408,d0080000 {
1100 compatible = "hisilicon,mbigen-v2";
1101 reg = <0x408 0xd0080000 0x0 0x10000>;
1102
1103 p1_mbigen_sec_b: intc_sec {
1104 msi-parent = <&p1_its_dsa_b 0x46400>;
1105 interrupt-controller;
1106 #interrupt-cells = <2>;
1107 num-pins = <33>;
1108 };
1109 p1_mbigen_smmu_alg_b: intc_smmu_alg {
1110 msi-parent = <&p1_its_dsa_b 0x46b1b>;
1111 interrupt-controller;
1112 #interrupt-cells = <2>;
1113 num-pins = <3>;
1114 };
1115 };
1116 p0_mbigen_dsa_a: interrupt-controller@c0080000 {
1117 compatible = "hisilicon,mbigen-v2";
1118 reg = <0x0 0xc0080000 0x0 0x10000>;
1119
1120 mbigen_dsaf0: intc_dsaf0 {
1121 msi-parent = <&p0_its_dsa_a 0x40800>;
1122 interrupt-controller;
1123 #interrupt-cells = <2>;
1124 num-pins = <409>;
1125 };
1126
1127 mbigen_dsa_roce: intc-roce {
1128 msi-parent = <&p0_its_dsa_a 0x40B1E>;
1129 interrupt-controller;
1130 #interrupt-cells = <2>;
1131 num-pins = <34>;
1132 };
1133
1134 mbigen_sas0: intc-sas0 {
1135 msi-parent = <&p0_its_dsa_a 0x40900>;
1136 interrupt-controller;
1137 #interrupt-cells = <2>;
1138 num-pins = <128>;
1139 };
1140
1141 mbigen_smmu_dsa: intc_smmu_dsa {
1142 msi-parent = <&p0_its_dsa_a 0x40b20>;
1143 interrupt-controller;
1144 #interrupt-cells = <2>;
1145 num-pins = <3>;
1146 };
1147 };
1148
1149 /**
1150 * HiSilicon erratum 161010801: This describes the limitation
1151 * of HiSilicon platforms hip06/hip07 to support the SMMUv3
1152 * mappings for PCIe MSI transactions.
1153 * PCIe controller on these platforms has to differentiate the
1154 * MSI payload against other DMA payload and has to modify the
1155 * MSI payload. This makes it difficult for these platforms to
1156 * have a SMMU translation for MSI. In order to workaround this,
1157 * ARM SMMUv3 driver requires a quirk to treat the MSI regions
1158 * separately. Such a quirk is currently missing for DT based
1159 * systems. Hence please make sure that the smmu pcie node on
1160 * hip07 is disabled as this will break the PCIe functionality
1161 * when iommu-map entry is used along with the PCIe node.
1162 * Refer:https://www.spinics.net/lists/arm-kernel/msg602812.html
1163 */
1164 smmu0: iommu@a0040000 {
1165 compatible = "arm,smmu-v3";
1166 reg = <0x0 0xa0040000 0x0 0x20000>;
1167 #iommu-cells = <1>;
1168 dma-coherent;
1169 hisilicon,broken-prefetch-cmd;
1170 status = "disabled";
1171 };
1172 p0_smmu_alg_a: iommu@d0040000 {
1173 compatible = "arm,smmu-v3";
1174 reg = <0x0 0xd0040000 0x0 0x20000>;
1175 interrupt-parent = <&p0_mbigen_smmu_alg_a>;
1176 interrupts = <733 1>,
1177 <734 1>,
1178 <735 1>;
1179 interrupt-names = "eventq", "gerror", "priq";
1180 #iommu-cells = <1>;
1181 dma-coherent;
1182 hisilicon,broken-prefetch-cmd;
1183 };
1184 p0_smmu_alg_b: iommu@8d0040000 {
1185 compatible = "arm,smmu-v3";
1186 reg = <0x8 0xd0040000 0x0 0x20000>;
1187 interrupt-parent = <&p0_mbigen_smmu_alg_b>;
1188 interrupts = <733 1>,
1189 <734 1>,
1190 <735 1>;
1191 interrupt-names = "eventq", "gerror", "priq";
1192 #iommu-cells = <1>;
1193 dma-coherent;
1194 hisilicon,broken-prefetch-cmd;
1195 };
1196 p1_smmu_alg_a: iommu@400d0040000 {
1197 compatible = "arm,smmu-v3";
1198 reg = <0x400 0xd0040000 0x0 0x20000>;
1199 interrupt-parent = <&p1_mbigen_smmu_alg_a>;
1200 interrupts = <733 1>,
1201 <734 1>,
1202 <735 1>;
1203 interrupt-names = "eventq", "gerror", "priq";
1204 #iommu-cells = <1>;
1205 dma-coherent;
1206 hisilicon,broken-prefetch-cmd;
1207 };
1208 p1_smmu_alg_b: iommu@408d0040000 {
1209 compatible = "arm,smmu-v3";
1210 reg = <0x408 0xd0040000 0x0 0x20000>;
1211 interrupt-parent = <&p1_mbigen_smmu_alg_b>;
1212 interrupts = <733 1>,
1213 <734 1>,
1214 <735 1>;
1215 interrupt-names = "eventq", "gerror", "priq";
1216 #iommu-cells = <1>;
1217 dma-coherent;
1218 hisilicon,broken-prefetch-cmd;
1219 };
1220
1221 soc {
1222 compatible = "simple-bus";
1223 #address-cells = <2>;
1224 #size-cells = <2>;
1225 ranges;
1226
1227 isa@a01b0000 {
1228 compatible = "hisilicon,hip07-lpc";
1229 #size-cells = <1>;
1230 #address-cells = <2>;
1231 reg = <0x0 0xa01b0000 0x0 0x1000>;
1232
1233 ipmi0: bt@e4 {
1234 compatible = "ipmi-bt";
1235 device_type = "ipmi";
1236 reg = <0x01 0xe4 0x04>;
1237 status = "disabled";
1238 };
1239 };
1240
1241 uart0: uart@602b0000 {
1242 compatible = "arm,sbsa-uart";
1243 reg = <0x0 0x602b0000 0x0 0x1000>;
1244 interrupt-parent = <&mbigen_uart>;
1245 interrupts = <807 4>;
1246 current-speed = <115200>;
1247 reg-io-width = <4>;
1248 status = "disabled";
1249 };
1250
1251 usb_ohci: usb@a7030000 {
1252 compatible = "generic-ohci";
1253 reg = <0x0 0xa7030000 0x0 0x10000>;
1254 interrupt-parent = <&mbigen_usb>;
1255 interrupts = <640 4>;
1256 dma-coherent;
1257 status = "disabled";
1258 };
1259
1260 usb_ehci: usb@a7020000 {
1261 compatible = "generic-ehci";
1262 reg = <0x0 0xa7020000 0x0 0x10000>;
1263 interrupt-parent = <&mbigen_usb>;
1264 interrupts = <641 4>;
1265 dma-coherent;
1266 status = "disabled";
1267 };
1268
1269 peri_c_subctrl: sub_ctrl_c@60000000 {
1270 compatible = "hisilicon,peri-subctrl","syscon";
1271 reg = <0 0x60000000 0x0 0x10000>;
1272 };
1273
1274 dsa_subctrl: dsa_subctrl@c0000000 {
1275 compatible = "hisilicon,dsa-subctrl", "syscon";
1276 reg = <0x0 0xc0000000 0x0 0x10000>;
1277 };
1278
1279 dsa_cpld: dsa_cpld@78000010 {
1280 compatible = "syscon";
1281 reg = <0x0 0x78000010 0x0 0x100>;
1282 reg-io-width = <2>;
1283 };
1284
1285 pcie_subctl: pcie_subctl@a0000000 {
1286 compatible = "hisilicon,pcie-sas-subctrl", "syscon";
1287 reg = <0x0 0xa0000000 0x0 0x10000>;
1288 };
1289
1290 serdes_ctrl: sds_ctrl@c2200000 {
1291 compatible = "syscon";
1292 reg = <0 0xc2200000 0x0 0x80000>;
1293 };
1294
1295 mdio@603c0000 {
1296 compatible = "hisilicon,hns-mdio";
1297 reg = <0x0 0x603c0000 0x0 0x1000>;
1298 subctrl-vbase = <&peri_c_subctrl 0x338 0xa38
1299 0x531c 0x5a1c>;
1300 #address-cells = <1>;
1301 #size-cells = <0>;
1302
1303 phy0: ethernet-phy@0 {
1304 compatible = "ethernet-phy-ieee802.3-c22";
1305 reg = <0>;
1306 };
1307
1308 phy1: ethernet-phy@1 {
1309 compatible = "ethernet-phy-ieee802.3-c22";
1310 reg = <1>;
1311 };
1312 };
1313
1314 dsaf0: dsa@c7000000 {
1315 #address-cells = <1>;
1316 #size-cells = <0>;
1317 compatible = "hisilicon,hns-dsaf-v2";
1318 mode = "6port-16rss";
1319 reg = <0x0 0xc5000000 0x0 0x890000>,
1320 <0x0 0xc7000000 0x0 0x600000>;
1321 reg-names = "ppe-base", "dsaf-base";
1322 interrupt-parent = <&mbigen_dsaf0>;
1323 subctrl-syscon = <&dsa_subctrl>;
1324 reset-field-offset = <0>;
1325 interrupts =
1326 <576 1>, <577 1>, <578 1>, <579 1>, <580 1>,
1327 <581 1>, <582 1>, <583 1>, <584 1>, <585 1>,
1328 <586 1>, <587 1>, <588 1>, <589 1>, <590 1>,
1329 <591 1>, <592 1>, <593 1>, <594 1>, <595 1>,
1330 <596 1>, <597 1>, <598 1>, <599 1>, <600 1>,
1331 <960 1>, <961 1>, <962 1>, <963 1>, <964 1>,
1332 <965 1>, <966 1>, <967 1>, <968 1>, <969 1>,
1333 <970 1>, <971 1>, <972 1>, <973 1>, <974 1>,
1334 <975 1>, <976 1>, <977 1>, <978 1>, <979 1>,
1335 <980 1>, <981 1>, <982 1>, <983 1>, <984 1>,
1336 <985 1>, <986 1>, <987 1>, <988 1>, <989 1>,
1337 <990 1>, <991 1>, <992 1>, <993 1>, <994 1>,
1338 <995 1>, <996 1>, <997 1>, <998 1>, <999 1>,
1339 <1000 1>, <1001 1>, <1002 1>, <1003 1>, <1004 1>,
1340 <1005 1>, <1006 1>, <1007 1>, <1008 1>, <1009 1>,
1341 <1010 1>, <1011 1>, <1012 1>, <1013 1>, <1014 1>,
1342 <1015 1>, <1016 1>, <1017 1>, <1018 1>, <1019 1>,
1343 <1020 1>, <1021 1>, <1022 1>, <1023 1>, <1024 1>,
1344 <1025 1>, <1026 1>, <1027 1>, <1028 1>, <1029 1>,
1345 <1030 1>, <1031 1>, <1032 1>, <1033 1>, <1034 1>,
1346 <1035 1>, <1036 1>, <1037 1>, <1038 1>, <1039 1>,
1347 <1040 1>, <1041 1>, <1042 1>, <1043 1>, <1044 1>,
1348 <1045 1>, <1046 1>, <1047 1>, <1048 1>, <1049 1>,
1349 <1050 1>, <1051 1>, <1052 1>, <1053 1>, <1054 1>,
1350 <1055 1>, <1056 1>, <1057 1>, <1058 1>, <1059 1>,
1351 <1060 1>, <1061 1>, <1062 1>, <1063 1>, <1064 1>,
1352 <1065 1>, <1066 1>, <1067 1>, <1068 1>, <1069 1>,
1353 <1070 1>, <1071 1>, <1072 1>, <1073 1>, <1074 1>,
1354 <1075 1>, <1076 1>, <1077 1>, <1078 1>, <1079 1>,
1355 <1080 1>, <1081 1>, <1082 1>, <1083 1>, <1084 1>,
1356 <1085 1>, <1086 1>, <1087 1>, <1088 1>, <1089 1>,
1357 <1090 1>, <1091 1>, <1092 1>, <1093 1>, <1094 1>,
1358 <1095 1>, <1096 1>, <1097 1>, <1098 1>, <1099 1>,
1359 <1100 1>, <1101 1>, <1102 1>, <1103 1>, <1104 1>,
1360 <1105 1>, <1106 1>, <1107 1>, <1108 1>, <1109 1>,
1361 <1110 1>, <1111 1>, <1112 1>, <1113 1>, <1114 1>,
1362 <1115 1>, <1116 1>, <1117 1>, <1118 1>, <1119 1>,
1363 <1120 1>, <1121 1>, <1122 1>, <1123 1>, <1124 1>,
1364 <1125 1>, <1126 1>, <1127 1>, <1128 1>, <1129 1>,
1365 <1130 1>, <1131 1>, <1132 1>, <1133 1>, <1134 1>,
1366 <1135 1>, <1136 1>, <1137 1>, <1138 1>, <1139 1>,
1367 <1140 1>, <1141 1>, <1142 1>, <1143 1>, <1144 1>,
1368 <1145 1>, <1146 1>, <1147 1>, <1148 1>, <1149 1>,
1369 <1150 1>, <1151 1>, <1152 1>, <1153 1>, <1154 1>,
1370 <1155 1>, <1156 1>, <1157 1>, <1158 1>, <1159 1>,
1371 <1160 1>, <1161 1>, <1162 1>, <1163 1>, <1164 1>,
1372 <1165 1>, <1166 1>, <1167 1>, <1168 1>, <1169 1>,
1373 <1170 1>, <1171 1>, <1172 1>, <1173 1>, <1174 1>,
1374 <1175 1>, <1176 1>, <1177 1>, <1178 1>, <1179 1>,
1375 <1180 1>, <1181 1>, <1182 1>, <1183 1>, <1184 1>,
1376 <1185 1>, <1186 1>, <1187 1>, <1188 1>, <1189 1>,
1377 <1190 1>, <1191 1>, <1192 1>, <1193 1>, <1194 1>,
1378 <1195 1>, <1196 1>, <1197 1>, <1198 1>, <1199 1>,
1379 <1200 1>, <1201 1>, <1202 1>, <1203 1>, <1204 1>,
1380 <1205 1>, <1206 1>, <1207 1>, <1208 1>, <1209 1>,
1381 <1210 1>, <1211 1>, <1212 1>, <1213 1>, <1214 1>,
1382 <1215 1>, <1216 1>, <1217 1>, <1218 1>, <1219 1>,
1383 <1220 1>, <1221 1>, <1222 1>, <1223 1>, <1224 1>,
1384 <1225 1>, <1226 1>, <1227 1>, <1228 1>, <1229 1>,
1385 <1230 1>, <1231 1>, <1232 1>, <1233 1>, <1234 1>,
1386 <1235 1>, <1236 1>, <1237 1>, <1238 1>, <1239 1>,
1387 <1240 1>, <1241 1>, <1242 1>, <1243 1>, <1244 1>,
1388 <1245 1>, <1246 1>, <1247 1>, <1248 1>, <1249 1>,
1389 <1250 1>, <1251 1>, <1252 1>, <1253 1>, <1254 1>,
1390 <1255 1>, <1256 1>, <1257 1>, <1258 1>, <1259 1>,
1391 <1260 1>, <1261 1>, <1262 1>, <1263 1>, <1264 1>,
1392 <1265 1>, <1266 1>, <1267 1>, <1268 1>, <1269 1>,
1393 <1270 1>, <1271 1>, <1272 1>, <1273 1>, <1274 1>,
1394 <1275 1>, <1276 1>, <1277 1>, <1278 1>, <1279 1>,
1395 <1280 1>, <1281 1>, <1282 1>, <1283 1>, <1284 1>,
1396 <1285 1>, <1286 1>, <1287 1>, <1288 1>, <1289 1>,
1397 <1290 1>, <1291 1>, <1292 1>, <1293 1>, <1294 1>,
1398 <1295 1>, <1296 1>, <1297 1>, <1298 1>, <1299 1>,
1399 <1300 1>, <1301 1>, <1302 1>, <1303 1>, <1304 1>,
1400 <1305 1>, <1306 1>, <1307 1>, <1308 1>, <1309 1>,
1401 <1310 1>, <1311 1>, <1312 1>, <1313 1>, <1314 1>,
1402 <1315 1>, <1316 1>, <1317 1>, <1318 1>, <1319 1>,
1403 <1320 1>, <1321 1>, <1322 1>, <1323 1>, <1324 1>,
1404 <1325 1>, <1326 1>, <1327 1>, <1328 1>, <1329 1>,
1405 <1330 1>, <1331 1>, <1332 1>, <1333 1>, <1334 1>,
1406 <1335 1>, <1336 1>, <1337 1>, <1338 1>, <1339 1>,
1407 <1340 1>, <1341 1>, <1342 1>, <1343 1>;
1408
1409 desc-num = <0x400>;
1410 buf-size = <0x1000>;
1411 dma-coherent;
1412
1413 port@0 {
1414 reg = <0>;
1415 serdes-syscon = <&serdes_ctrl>;
1416 cpld-syscon = <&dsa_cpld 0x0>;
1417 port-rst-offset = <0>;
1418 port-mode-offset = <0>;
1419 mc-mac-mask = [ff f0 00 00 00 00];
1420 media-type = "fiber";
1421 };
1422
1423 port@1 {
1424 reg = <1>;
1425 serdes-syscon = <&serdes_ctrl>;
1426 cpld-syscon = <&dsa_cpld 0x4>;
1427 port-rst-offset = <1>;
1428 port-mode-offset = <1>;
1429 mc-mac-mask = [ff f0 00 00 00 00];
1430 media-type = "fiber";
1431 };
1432
1433 port@4 {
1434 reg = <4>;
1435 phy-handle = <&phy0>;
1436 serdes-syscon = <&serdes_ctrl>;
1437 port-rst-offset = <4>;
1438 port-mode-offset = <2>;
1439 mc-mac-mask = [ff f0 00 00 00 00];
1440 media-type = "copper";
1441 };
1442
1443 port@5 {
1444 reg = <5>;
1445 phy-handle = <&phy1>;
1446 serdes-syscon = <&serdes_ctrl>;
1447 port-rst-offset = <5>;
1448 port-mode-offset = <3>;
1449 mc-mac-mask = [ff f0 00 00 00 00];
1450 media-type = "copper";
1451 };
1452 };
1453
1454 eth0: ethernet@4{
1455 compatible = "hisilicon,hns-nic-v2";
1456 ae-handle = <&dsaf0>;
1457 port-idx-in-ae = <4>;
1458 local-mac-address = [00 00 00 00 00 00];
1459 status = "disabled";
1460 dma-coherent;
1461 };
1462
1463 eth1: ethernet@5{
1464 compatible = "hisilicon,hns-nic-v2";
1465 ae-handle = <&dsaf0>;
1466 port-idx-in-ae = <5>;
1467 local-mac-address = [00 00 00 00 00 00];
1468 status = "disabled";
1469 dma-coherent;
1470 };
1471
1472 eth2: ethernet@0{
1473 compatible = "hisilicon,hns-nic-v2";
1474 ae-handle = <&dsaf0>;
1475 port-idx-in-ae = <0>;
1476 local-mac-address = [00 00 00 00 00 00];
1477 status = "disabled";
1478 dma-coherent;
1479 };
1480
1481 eth3: ethernet@1{
1482 compatible = "hisilicon,hns-nic-v2";
1483 ae-handle = <&dsaf0>;
1484 port-idx-in-ae = <1>;
1485 local-mac-address = [00 00 00 00 00 00];
1486 status = "disabled";
1487 dma-coherent;
1488 };
1489
1490 infiniband@c4000000 {
1491 compatible = "hisilicon,hns-roce-v1";
1492 reg = <0x0 0xc4000000 0x0 0x100000>;
1493 dma-coherent;
1494 eth-handle = <ð2 ð3 0 0 ð0 ð1>;
1495 dsaf-handle = <&dsaf0>;
1496 node-guid = [00 9A CD 00 00 01 02 03];
1497 #address-cells = <2>;
1498 #size-cells = <2>;
1499 interrupt-parent = <&mbigen_dsa_roce>;
1500 interrupts = <722 1>,
1501 <723 1>,
1502 <724 1>,
1503 <725 1>,
1504 <726 1>,
1505 <727 1>,
1506 <728 1>,
1507 <729 1>,
1508 <730 1>,
1509 <731 1>,
1510 <732 1>,
1511 <733 1>,
1512 <734 1>,
1513 <735 1>,
1514 <736 1>,
1515 <737 1>,
1516 <738 1>,
1517 <739 1>,
1518 <740 1>,
1519 <741 1>,
1520 <742 1>,
1521 <743 1>,
1522 <744 1>,
1523 <745 1>,
1524 <746 1>,
1525 <747 1>,
1526 <748 1>,
1527 <749 1>,
1528 <750 1>,
1529 <751 1>,
1530 <752 1>,
1531 <753 1>,
1532 <785 1>,
1533 <754 4>;
1534
1535 interrupt-names = "hns-roce-comp-0",
1536 "hns-roce-comp-1",
1537 "hns-roce-comp-2",
1538 "hns-roce-comp-3",
1539 "hns-roce-comp-4",
1540 "hns-roce-comp-5",
1541 "hns-roce-comp-6",
1542 "hns-roce-comp-7",
1543 "hns-roce-comp-8",
1544 "hns-roce-comp-9",
1545 "hns-roce-comp-10",
1546 "hns-roce-comp-11",
1547 "hns-roce-comp-12",
1548 "hns-roce-comp-13",
1549 "hns-roce-comp-14",
1550 "hns-roce-comp-15",
1551 "hns-roce-comp-16",
1552 "hns-roce-comp-17",
1553 "hns-roce-comp-18",
1554 "hns-roce-comp-19",
1555 "hns-roce-comp-20",
1556 "hns-roce-comp-21",
1557 "hns-roce-comp-22",
1558 "hns-roce-comp-23",
1559 "hns-roce-comp-24",
1560 "hns-roce-comp-25",
1561 "hns-roce-comp-26",
1562 "hns-roce-comp-27",
1563 "hns-roce-comp-28",
1564 "hns-roce-comp-29",
1565 "hns-roce-comp-30",
1566 "hns-roce-comp-31",
1567 "hns-roce-async",
1568 "hns-roce-common";
1569 };
1570
1571 sas0: sas@c3000000 {
1572 compatible = "hisilicon,hip07-sas-v2";
1573 reg = <0 0xc3000000 0 0x10000>;
1574 sas-addr = [50 01 88 20 16 00 00 00];
1575 hisilicon,sas-syscon = <&dsa_subctrl>;
1576 ctrl-reset-reg = <0xa60>;
1577 ctrl-reset-sts-reg = <0x5a30>;
1578 ctrl-clock-ena-reg = <0x338>;
1579 queue-count = <16>;
1580 phy-count = <8>;
1581 dma-coherent;
1582 interrupt-parent = <&mbigen_sas0>;
1583 interrupts = <64 4>,<65 4>,<66 4>,<67 4>,<68 4>,
1584 <69 4>,<70 4>,<71 4>,<72 4>,<73 4>,
1585 <74 4>,<75 4>,<76 4>,<77 4>,<78 4>,
1586 <79 4>,<80 4>,<81 4>,<82 4>,<83 4>,
1587 <84 4>,<85 4>,<86 4>,<87 4>,<88 4>,
1588 <89 4>,<90 4>,<91 4>,<92 4>,<93 4>,
1589 <94 4>,<95 4>,<96 4>,<97 4>,<98 4>,
1590 <99 4>,<100 4>,<101 4>,<102 4>,<103 4>,
1591 <104 4>,<105 4>,<106 4>,<107 4>,<108 4>,
1592 <109 4>,<110 4>,<111 4>,<112 4>,<113 4>,
1593 <114 4>,<115 4>,<116 4>,<117 4>,<118 4>,
1594 <119 4>,<120 4>,<121 4>,<122 4>,<123 4>,
1595 <124 4>,<125 4>,<126 4>,<127 4>,<128 4>,
1596 <129 4>,<130 4>,<131 4>,<132 4>,<133 4>,
1597 <134 4>,<135 4>,<136 4>,<137 4>,<138 4>,
1598 <139 4>,<140 4>,<141 4>,<142 4>,<143 4>,
1599 <144 4>,<145 4>,<146 4>,<147 4>,<148 4>,
1600 <149 4>,<150 4>,<151 4>,<152 4>,<153 4>,
1601 <154 4>,<155 4>,<156 4>,<157 4>,<158 4>,
1602 <159 4>,<601 1>,<602 1>,<603 1>,<604 1>,
1603 <605 1>,<606 1>,<607 1>,<608 1>,<609 1>,
1604 <610 1>,<611 1>,<612 1>,<613 1>,<614 1>,
1605 <615 1>,<616 1>,<617 1>,<618 1>,<619 1>,
1606 <620 1>,<621 1>,<622 1>,<623 1>,<624 1>,
1607 <625 1>,<626 1>,<627 1>,<628 1>,<629 1>,
1608 <630 1>,<631 1>,<632 1>;
1609 status = "disabled";
1610 };
1611
1612 sas1: sas@a2000000 {
1613 compatible = "hisilicon,hip07-sas-v2";
1614 reg = <0 0xa2000000 0 0x10000>;
1615 sas-addr = [50 01 88 20 16 00 00 00];
1616 hisilicon,sas-syscon = <&pcie_subctl>;
1617 hip06-sas-v2-quirk-amt;
1618 ctrl-reset-reg = <0xa18>;
1619 ctrl-reset-sts-reg = <0x5a0c>;
1620 ctrl-clock-ena-reg = <0x318>;
1621 queue-count = <16>;
1622 phy-count = <8>;
1623 dma-coherent;
1624 interrupt-parent = <&mbigen_sas1>;
1625 interrupts = <64 4>,<65 4>,<66 4>,<67 4>,<68 4>,
1626 <69 4>,<70 4>,<71 4>,<72 4>,<73 4>,
1627 <74 4>,<75 4>,<76 4>,<77 4>,<78 4>,
1628 <79 4>,<80 4>,<81 4>,<82 4>,<83 4>,
1629 <84 4>,<85 4>,<86 4>,<87 4>,<88 4>,
1630 <89 4>,<90 4>,<91 4>,<92 4>,<93 4>,
1631 <94 4>,<95 4>,<96 4>,<97 4>,<98 4>,
1632 <99 4>,<100 4>,<101 4>,<102 4>,<103 4>,
1633 <104 4>,<105 4>,<106 4>,<107 4>,<108 4>,
1634 <109 4>,<110 4>,<111 4>,<112 4>,<113 4>,
1635 <114 4>,<115 4>,<116 4>,<117 4>,<118 4>,
1636 <119 4>,<120 4>,<121 4>,<122 4>,<123 4>,
1637 <124 4>,<125 4>,<126 4>,<127 4>,<128 4>,
1638 <129 4>,<130 4>,<131 4>,<132 4>,<133 4>,
1639 <134 4>,<135 4>,<136 4>,<137 4>,<138 4>,
1640 <139 4>,<140 4>,<141 4>,<142 4>,<143 4>,
1641 <144 4>,<145 4>,<146 4>,<147 4>,<148 4>,
1642 <149 4>,<150 4>,<151 4>,<152 4>,<153 4>,
1643 <154 4>,<155 4>,<156 4>,<157 4>,<158 4>,
1644 <159 4>,<576 1>,<577 1>,<578 1>,<579 1>,
1645 <580 1>,<581 1>,<582 1>,<583 1>,<584 1>,
1646 <585 1>,<586 1>,<587 1>,<588 1>,<589 1>,
1647 <590 1>,<591 1>,<592 1>,<593 1>,<594 1>,
1648 <595 1>,<596 1>,<597 1>,<598 1>,<599 1>,
1649 <600 1>,<601 1>,<602 1>,<603 1>,<604 1>,
1650 <605 1>,<606 1>,<607 1>;
1651 status = "disabled";
1652 };
1653
1654 sas2: sas@a3000000 {
1655 compatible = "hisilicon,hip07-sas-v2";
1656 reg = <0 0xa3000000 0 0x10000>;
1657 sas-addr = [50 01 88 20 16 00 00 00];
1658 hisilicon,sas-syscon = <&pcie_subctl>;
1659 ctrl-reset-reg = <0xae0>;
1660 ctrl-reset-sts-reg = <0x5a70>;
1661 ctrl-clock-ena-reg = <0x3a8>;
1662 queue-count = <16>;
1663 phy-count = <9>;
1664 dma-coherent;
1665 interrupt-parent = <&mbigen_sas2>;
1666 interrupts = <192 4>,<193 4>,<194 4>,<195 4>,<196 4>,
1667 <197 4>,<198 4>,<199 4>,<200 4>,<201 4>,
1668 <202 4>,<203 4>,<204 4>,<205 4>,<206 4>,
1669 <207 4>,<208 4>,<209 4>,<210 4>,<211 4>,
1670 <212 4>,<213 4>,<214 4>,<215 4>,<216 4>,
1671 <217 4>,<218 4>,<219 4>,<220 4>,<221 4>,
1672 <222 4>,<223 4>,<224 4>,<225 4>,<226 4>,
1673 <227 4>,<228 4>,<229 4>,<230 4>,<231 4>,
1674 <232 4>,<233 4>,<234 4>,<235 4>,<236 4>,
1675 <237 4>,<238 4>,<239 4>,<240 4>,<241 4>,
1676 <242 4>,<243 4>,<244 4>,<245 4>,<246 4>,
1677 <247 4>,<248 4>,<249 4>,<250 4>,<251 4>,
1678 <252 4>,<253 4>,<254 4>,<255 4>,<256 4>,
1679 <257 4>,<258 4>,<259 4>,<260 4>,<261 4>,
1680 <262 4>,<263 4>,<264 4>,<265 4>,<266 4>,
1681 <267 4>,<268 4>,<269 4>,<270 4>,<271 4>,
1682 <272 4>,<273 4>,<274 4>,<275 4>,<276 4>,
1683 <277 4>,<278 4>,<279 4>,<280 4>,<281 4>,
1684 <282 4>,<283 4>,<284 4>,<285 4>,<286 4>,
1685 <287 4>,<608 1>,<609 1>,<610 1>,<611 1>,
1686 <612 1>,<613 1>,<614 1>,<615 1>,<616 1>,
1687 <617 1>,<618 1>,<619 1>,<620 1>,<621 1>,
1688 <622 1>,<623 1>,<624 1>,<625 1>,<626 1>,
1689 <627 1>,<628 1>,<629 1>,<630 1>,<631 1>,
1690 <632 1>,<633 1>,<634 1>,<635 1>,<636 1>,
1691 <637 1>,<638 1>,<639 1>;
1692 status = "disabled";
1693 };
1694
1695 p0_pcie2_a: pcie@a00a0000 {
1696 compatible = "hisilicon,hip07-pcie-ecam";
1697 reg = <0 0xaf800000 0 0x800000>,
1698 <0 0xa00a0000 0 0x10000>;
1699 bus-range = <0xf8 0xff>;
1700 msi-map = <0xf800 &p0_its_dsa_a 0xf800 0x800>;
1701 msi-map-mask = <0xffff>;
1702 #address-cells = <3>;
1703 #size-cells = <2>;
1704 device_type = "pci";
1705 dma-coherent;
1706 ranges = <0x02000000 0 0xa8000000 0 0xa8000000 0 0x77f0000>,
1707 <0x01000000 0 0 0 0xaf7f0000 0 0x10000>;
1708 #interrupt-cells = <1>;
1709 interrupt-map-mask = <0xf800 0 0 7>;
1710 interrupt-map = <0x0 0 0 1 &mbigen_pcie2_a 671 4
1711 0x0 0 0 2 &mbigen_pcie2_a 671 4
1712 0x0 0 0 3 &mbigen_pcie2_a 671 4
1713 0x0 0 0 4 &mbigen_pcie2_a 671 4>;
1714 status = "disabled";
1715 };
1716 p0_sec_a: crypto@d2000000 {
1717 compatible = "hisilicon,hip07-sec";
1718 reg = <0x0 0xd0000000 0x0 0x10000>,
1719 <0x0 0xd2000000 0x0 0x10000>,
1720 <0x0 0xd2010000 0x0 0x10000>,
1721 <0x0 0xd2020000 0x0 0x10000>,
1722 <0x0 0xd2030000 0x0 0x10000>,
1723 <0x0 0xd2040000 0x0 0x10000>,
1724 <0x0 0xd2050000 0x0 0x10000>,
1725 <0x0 0xd2060000 0x0 0x10000>,
1726 <0x0 0xd2070000 0x0 0x10000>,
1727 <0x0 0xd2080000 0x0 0x10000>,
1728 <0x0 0xd2090000 0x0 0x10000>,
1729 <0x0 0xd20a0000 0x0 0x10000>,
1730 <0x0 0xd20b0000 0x0 0x10000>,
1731 <0x0 0xd20c0000 0x0 0x10000>,
1732 <0x0 0xd20d0000 0x0 0x10000>,
1733 <0x0 0xd20e0000 0x0 0x10000>,
1734 <0x0 0xd20f0000 0x0 0x10000>,
1735 <0x0 0xd2100000 0x0 0x10000>;
1736 interrupt-parent = <&p0_mbigen_sec_a>;
1737 iommus = <&p0_smmu_alg_a 0x600>;
1738 dma-coherent;
1739 interrupts = <576 4>,
1740 <577 1>, <578 4>,
1741 <579 1>, <580 4>,
1742 <581 1>, <582 4>,
1743 <583 1>, <584 4>,
1744 <585 1>, <586 4>,
1745 <587 1>, <588 4>,
1746 <589 1>, <590 4>,
1747 <591 1>, <592 4>,
1748 <593 1>, <594 4>,
1749 <595 1>, <596 4>,
1750 <597 1>, <598 4>,
1751 <599 1>, <600 4>,
1752 <601 1>, <602 4>,
1753 <603 1>, <604 4>,
1754 <605 1>, <606 4>,
1755 <607 1>, <608 4>;
1756 };
1757 p0_sec_b: crypto@8,d2000000 {
1758 compatible = "hisilicon,hip07-sec";
1759 reg = <0x8 0xd0000000 0x0 0x10000>,
1760 <0x8 0xd2000000 0x0 0x10000>,
1761 <0x8 0xd2010000 0x0 0x10000>,
1762 <0x8 0xd2020000 0x0 0x10000>,
1763 <0x8 0xd2030000 0x0 0x10000>,
1764 <0x8 0xd2040000 0x0 0x10000>,
1765 <0x8 0xd2050000 0x0 0x10000>,
1766 <0x8 0xd2060000 0x0 0x10000>,
1767 <0x8 0xd2070000 0x0 0x10000>,
1768 <0x8 0xd2080000 0x0 0x10000>,
1769 <0x8 0xd2090000 0x0 0x10000>,
1770 <0x8 0xd20a0000 0x0 0x10000>,
1771 <0x8 0xd20b0000 0x0 0x10000>,
1772 <0x8 0xd20c0000 0x0 0x10000>,
1773 <0x8 0xd20d0000 0x0 0x10000>,
1774 <0x8 0xd20e0000 0x0 0x10000>,
1775 <0x8 0xd20f0000 0x0 0x10000>,
1776 <0x8 0xd2100000 0x0 0x10000>;
1777 interrupt-parent = <&p0_mbigen_sec_b>;
1778 iommus = <&p0_smmu_alg_b 0x600>;
1779 dma-coherent;
1780 interrupts = <576 4>,
1781 <577 1>, <578 4>,
1782 <579 1>, <580 4>,
1783 <581 1>, <582 4>,
1784 <583 1>, <584 4>,
1785 <585 1>, <586 4>,
1786 <587 1>, <588 4>,
1787 <589 1>, <590 4>,
1788 <591 1>, <592 4>,
1789 <593 1>, <594 4>,
1790 <595 1>, <596 4>,
1791 <597 1>, <598 4>,
1792 <599 1>, <600 4>,
1793 <601 1>, <602 4>,
1794 <603 1>, <604 4>,
1795 <605 1>, <606 4>,
1796 <607 1>, <608 4>;
1797 };
1798 p1_sec_a: crypto@400,d2000000 {
1799 compatible = "hisilicon,hip07-sec";
1800 reg = <0x400 0xd0000000 0x0 0x10000>,
1801 <0x400 0xd2000000 0x0 0x10000>,
1802 <0x400 0xd2010000 0x0 0x10000>,
1803 <0x400 0xd2020000 0x0 0x10000>,
1804 <0x400 0xd2030000 0x0 0x10000>,
1805 <0x400 0xd2040000 0x0 0x10000>,
1806 <0x400 0xd2050000 0x0 0x10000>,
1807 <0x400 0xd2060000 0x0 0x10000>,
1808 <0x400 0xd2070000 0x0 0x10000>,
1809 <0x400 0xd2080000 0x0 0x10000>,
1810 <0x400 0xd2090000 0x0 0x10000>,
1811 <0x400 0xd20a0000 0x0 0x10000>,
1812 <0x400 0xd20b0000 0x0 0x10000>,
1813 <0x400 0xd20c0000 0x0 0x10000>,
1814 <0x400 0xd20d0000 0x0 0x10000>,
1815 <0x400 0xd20e0000 0x0 0x10000>,
1816 <0x400 0xd20f0000 0x0 0x10000>,
1817 <0x400 0xd2100000 0x0 0x10000>;
1818 interrupt-parent = <&p1_mbigen_sec_a>;
1819 iommus = <&p1_smmu_alg_a 0x600>;
1820 dma-coherent;
1821 interrupts = <576 4>,
1822 <577 1>, <578 4>,
1823 <579 1>, <580 4>,
1824 <581 1>, <582 4>,
1825 <583 1>, <584 4>,
1826 <585 1>, <586 4>,
1827 <587 1>, <588 4>,
1828 <589 1>, <590 4>,
1829 <591 1>, <592 4>,
1830 <593 1>, <594 4>,
1831 <595 1>, <596 4>,
1832 <597 1>, <598 4>,
1833 <599 1>, <600 4>,
1834 <601 1>, <602 4>,
1835 <603 1>, <604 4>,
1836 <605 1>, <606 4>,
1837 <607 1>, <608 4>;
1838 };
1839 p1_sec_b: crypto@408,d2000000 {
1840 compatible = "hisilicon,hip07-sec";
1841 reg = <0x408 0xd0000000 0x0 0x10000>,
1842 <0x408 0xd2000000 0x0 0x10000>,
1843 <0x408 0xd2010000 0x0 0x10000>,
1844 <0x408 0xd2020000 0x0 0x10000>,
1845 <0x408 0xd2030000 0x0 0x10000>,
1846 <0x408 0xd2040000 0x0 0x10000>,
1847 <0x408 0xd2050000 0x0 0x10000>,
1848 <0x408 0xd2060000 0x0 0x10000>,
1849 <0x408 0xd2070000 0x0 0x10000>,
1850 <0x408 0xd2080000 0x0 0x10000>,
1851 <0x408 0xd2090000 0x0 0x10000>,
1852 <0x408 0xd20a0000 0x0 0x10000>,
1853 <0x408 0xd20b0000 0x0 0x10000>,
1854 <0x408 0xd20c0000 0x0 0x10000>,
1855 <0x408 0xd20d0000 0x0 0x10000>,
1856 <0x408 0xd20e0000 0x0 0x10000>,
1857 <0x408 0xd20f0000 0x0 0x10000>,
1858 <0x408 0xd2100000 0x0 0x10000>;
1859 interrupt-parent = <&p1_mbigen_sec_b>;
1860 iommus = <&p1_smmu_alg_b 0x600>;
1861 dma-coherent;
1862 interrupts = <576 4>,
1863 <577 1>, <578 4>,
1864 <579 1>, <580 4>,
1865 <581 1>, <582 4>,
1866 <583 1>, <584 4>,
1867 <585 1>, <586 4>,
1868 <587 1>, <588 4>,
1869 <589 1>, <590 4>,
1870 <591 1>, <592 4>,
1871 <593 1>, <594 4>,
1872 <595 1>, <596 4>,
1873 <597 1>, <598 4>,
1874 <599 1>, <600 4>,
1875 <601 1>, <602 4>,
1876 <603 1>, <604 4>,
1877 <605 1>, <606 4>,
1878 <607 1>, <608 4>;
1879 };
1880
1881 };
1882 };
Cache object: 5f1d6706b65e4cdda2e0ca2d8f44064e
|