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 cache-level = <2>; 846 }; 847 848 cluster1_l2: l2-cache1 { 849 compatible = "cache"; 850 cache-level = <2>; 851 }; 852 853 cluster2_l2: l2-cache2 { 854 compatible = "cache"; 855 cache-level = <2>; 856 }; 857 858 cluster3_l2: l2-cache3 { 859 compatible = "cache"; 860 cache-level = <2>; 861 }; 862 863 cluster4_l2: l2-cache4 { 864 compatible = "cache"; 865 cache-level = <2>; 866 }; 867 868 cluster5_l2: l2-cache5 { 869 compatible = "cache"; 870 cache-level = <2>; 871 }; 872 873 cluster6_l2: l2-cache6 { 874 compatible = "cache"; 875 cache-level = <2>; 876 }; 877 878 cluster7_l2: l2-cache7 { 879 compatible = "cache"; 880 cache-level = <2>; 881 }; 882 883 cluster8_l2: l2-cache8 { 884 compatible = "cache"; 885 cache-level = <2>; 886 }; 887 888 cluster9_l2: l2-cache9 { 889 compatible = "cache"; 890 cache-level = <2>; 891 }; 892 893 cluster10_l2: l2-cache10 { 894 compatible = "cache"; 895 cache-level = <2>; 896 }; 897 898 cluster11_l2: l2-cache11 { 899 compatible = "cache"; 900 cache-level = <2>; 901 }; 902 903 cluster12_l2: l2-cache12 { 904 compatible = "cache"; 905 cache-level = <2>; 906 }; 907 908 cluster13_l2: l2-cache13 { 909 compatible = "cache"; 910 cache-level = <2>; 911 }; 912 913 cluster14_l2: l2-cache14 { 914 compatible = "cache"; 915 cache-level = <2>; 916 }; 917 918 cluster15_l2: l2-cache15 { 919 compatible = "cache"; 920 cache-level = <2>; 921 }; 922 }; 923 924 gic: interrupt-controller@4d000000 { 925 compatible = "arm,gic-v3"; 926 #interrupt-cells = <3>; 927 #address-cells = <2>; 928 #size-cells = <2>; 929 ranges; 930 interrupt-controller; 931 #redistributor-regions = <4>; 932 redistributor-stride = <0x0 0x40000>; 933 reg = <0x0 0x4d000000 0x0 0x10000>, /* GICD */ 934 <0x0 0x4d100000 0x0 0x400000>, /* p0 GICR node 0 */ 935 <0x0 0x6d100000 0x0 0x400000>, /* p0 GICR node 1 */ 936 <0x400 0x4d100000 0x0 0x400000>, /* p1 GICR node 2 */ 937 <0x400 0x6d100000 0x0 0x400000>, /* p1 GICR node 3 */ 938 <0x0 0xfe000000 0x0 0x10000>, /* GICC */ 939 <0x0 0xfe010000 0x0 0x10000>, /* GICH */ 940 <0x0 0xfe020000 0x0 0x10000>; /* GICV */ 941 interrupts = <GIC_PPI 9 IRQ_TYPE_LEVEL_HIGH>; 942 943 p0_its_peri_a: msi-controller@4c000000 { 944 compatible = "arm,gic-v3-its"; 945 msi-controller; 946 #msi-cells = <1>; 947 reg = <0x0 0x4c000000 0x0 0x40000>; 948 }; 949 950 p0_its_peri_b: msi-controller@6c000000 { 951 compatible = "arm,gic-v3-its"; 952 msi-controller; 953 #msi-cells = <1>; 954 reg = <0x0 0x6c000000 0x0 0x40000>; 955 }; 956 957 p0_its_dsa_a: msi-controller@c6000000 { 958 compatible = "arm,gic-v3-its"; 959 msi-controller; 960 #msi-cells = <1>; 961 reg = <0x0 0xc6000000 0x0 0x40000>; 962 }; 963 964 p0_its_dsa_b: msi-controller@8c6000000 { 965 compatible = "arm,gic-v3-its"; 966 msi-controller; 967 #msi-cells = <1>; 968 reg = <0x8 0xc6000000 0x0 0x40000>; 969 }; 970 971 p1_its_peri_a: msi-controller@4004c000000 { 972 compatible = "arm,gic-v3-its"; 973 msi-controller; 974 #msi-cells = <1>; 975 reg = <0x400 0x4c000000 0x0 0x40000>; 976 }; 977 978 p1_its_peri_b: msi-controller@4006c000000 { 979 compatible = "arm,gic-v3-its"; 980 msi-controller; 981 #msi-cells = <1>; 982 reg = <0x400 0x6c000000 0x0 0x40000>; 983 }; 984 985 p1_its_dsa_a: msi-controller@400c6000000 { 986 compatible = "arm,gic-v3-its"; 987 msi-controller; 988 #msi-cells = <1>; 989 reg = <0x400 0xc6000000 0x0 0x40000>; 990 }; 991 992 p1_its_dsa_b: msi-controller@408c6000000 { 993 compatible = "arm,gic-v3-its"; 994 msi-controller; 995 #msi-cells = <1>; 996 reg = <0x408 0xc6000000 0x0 0x40000>; 997 }; 998 }; 999 1000 timer { 1001 compatible = "arm,armv8-timer"; 1002 interrupts = <GIC_PPI 13 IRQ_TYPE_LEVEL_LOW>, 1003 <GIC_PPI 14 IRQ_TYPE_LEVEL_LOW>, 1004 <GIC_PPI 11 IRQ_TYPE_LEVEL_LOW>, 1005 <GIC_PPI 10 IRQ_TYPE_LEVEL_LOW>; 1006 }; 1007 1008 pmu { 1009 compatible = "arm,cortex-a72-pmu"; 1010 interrupts = <GIC_PPI 7 IRQ_TYPE_LEVEL_HIGH>; 1011 }; 1012 1013 p0_mbigen_peri_b: interrupt-controller@60080000 { 1014 compatible = "hisilicon,mbigen-v2"; 1015 reg = <0x0 0x60080000 0x0 0x10000>; 1016 1017 mbigen_uart: uart_intc { 1018 msi-parent = <&p0_its_peri_b 0x120c7>; 1019 interrupt-controller; 1020 #interrupt-cells = <2>; 1021 num-pins = <1>; 1022 }; 1023 }; 1024 1025 p0_mbigen_pcie_a: interrupt-controller@a0080000 { 1026 compatible = "hisilicon,mbigen-v2"; 1027 reg = <0x0 0xa0080000 0x0 0x10000>; 1028 1029 mbigen_pcie2_a: intc_pcie2_a { 1030 msi-parent = <&p0_its_dsa_a 0x40087>; 1031 interrupt-controller; 1032 #interrupt-cells = <2>; 1033 num-pins = <10>; 1034 }; 1035 1036 mbigen_sas1: intc_sas1 { 1037 msi-parent = <&p0_its_dsa_a 0x40000>; 1038 interrupt-controller; 1039 #interrupt-cells = <2>; 1040 num-pins = <128>; 1041 }; 1042 1043 mbigen_sas2: intc_sas2 { 1044 msi-parent = <&p0_its_dsa_a 0x40040>; 1045 interrupt-controller; 1046 #interrupt-cells = <2>; 1047 num-pins = <128>; 1048 }; 1049 1050 mbigen_smmu_pcie: intc_smmu_pcie { 1051 msi-parent = <&p0_its_dsa_a 0x40b0c>; 1052 interrupt-controller; 1053 #interrupt-cells = <2>; 1054 num-pins = <3>; 1055 }; 1056 1057 mbigen_usb: intc_usb { 1058 msi-parent = <&p0_its_dsa_a 0x40080>; 1059 interrupt-controller; 1060 #interrupt-cells = <2>; 1061 num-pins = <2>; 1062 }; 1063 }; 1064 p0_mbigen_alg_a:interrupt-controller@d0080000 { 1065 compatible = "hisilicon,mbigen-v2"; 1066 reg = <0x0 0xd0080000 0x0 0x10000>; 1067 1068 p0_mbigen_sec_a: intc_sec { 1069 msi-parent = <&p0_its_dsa_a 0x40400>; 1070 interrupt-controller; 1071 #interrupt-cells = <2>; 1072 num-pins = <33>; 1073 }; 1074 p0_mbigen_smmu_alg_a: intc_smmu_alg { 1075 msi-parent = <&p0_its_dsa_a 0x40b1b>; 1076 interrupt-controller; 1077 #interrupt-cells = <2>; 1078 num-pins = <3>; 1079 }; 1080 }; 1081 p0_mbigen_alg_b:interrupt-controller@8,d0080000 { 1082 compatible = "hisilicon,mbigen-v2"; 1083 reg = <0x8 0xd0080000 0x0 0x10000>; 1084 1085 p0_mbigen_sec_b: intc_sec { 1086 msi-parent = <&p0_its_dsa_b 0x42400>; 1087 interrupt-controller; 1088 #interrupt-cells = <2>; 1089 num-pins = <33>; 1090 }; 1091 p0_mbigen_smmu_alg_b: intc_smmu_alg { 1092 msi-parent = <&p0_its_dsa_b 0x42b1b>; 1093 interrupt-controller; 1094 #interrupt-cells = <2>; 1095 num-pins = <3>; 1096 }; 1097 }; 1098 p1_mbigen_alg_a:interrupt-controller@400,d0080000 { 1099 compatible = "hisilicon,mbigen-v2"; 1100 reg = <0x400 0xd0080000 0x0 0x10000>; 1101 1102 p1_mbigen_sec_a: intc_sec { 1103 msi-parent = <&p1_its_dsa_a 0x44400>; 1104 interrupt-controller; 1105 #interrupt-cells = <2>; 1106 num-pins = <33>; 1107 }; 1108 p1_mbigen_smmu_alg_a: intc_smmu_alg { 1109 msi-parent = <&p1_its_dsa_a 0x44b1b>; 1110 interrupt-controller; 1111 #interrupt-cells = <2>; 1112 num-pins = <3>; 1113 }; 1114 }; 1115 p1_mbigen_alg_b:interrupt-controller@408,d0080000 { 1116 compatible = "hisilicon,mbigen-v2"; 1117 reg = <0x408 0xd0080000 0x0 0x10000>; 1118 1119 p1_mbigen_sec_b: intc_sec { 1120 msi-parent = <&p1_its_dsa_b 0x46400>; 1121 interrupt-controller; 1122 #interrupt-cells = <2>; 1123 num-pins = <33>; 1124 }; 1125 p1_mbigen_smmu_alg_b: intc_smmu_alg { 1126 msi-parent = <&p1_its_dsa_b 0x46b1b>; 1127 interrupt-controller; 1128 #interrupt-cells = <2>; 1129 num-pins = <3>; 1130 }; 1131 }; 1132 p0_mbigen_dsa_a: interrupt-controller@c0080000 { 1133 compatible = "hisilicon,mbigen-v2"; 1134 reg = <0x0 0xc0080000 0x0 0x10000>; 1135 1136 mbigen_dsaf0: intc_dsaf0 { 1137 msi-parent = <&p0_its_dsa_a 0x40800>; 1138 interrupt-controller; 1139 #interrupt-cells = <2>; 1140 num-pins = <409>; 1141 }; 1142 1143 mbigen_dsa_roce: intc-roce { 1144 msi-parent = <&p0_its_dsa_a 0x40B1E>; 1145 interrupt-controller; 1146 #interrupt-cells = <2>; 1147 num-pins = <34>; 1148 }; 1149 1150 mbigen_sas0: intc-sas0 { 1151 msi-parent = <&p0_its_dsa_a 0x40900>; 1152 interrupt-controller; 1153 #interrupt-cells = <2>; 1154 num-pins = <128>; 1155 }; 1156 1157 mbigen_smmu_dsa: intc_smmu_dsa { 1158 msi-parent = <&p0_its_dsa_a 0x40b20>; 1159 interrupt-controller; 1160 #interrupt-cells = <2>; 1161 num-pins = <3>; 1162 }; 1163 }; 1164 1165 /** 1166 * HiSilicon erratum 161010801: This describes the limitation 1167 * of HiSilicon platforms hip06/hip07 to support the SMMUv3 1168 * mappings for PCIe MSI transactions. 1169 * PCIe controller on these platforms has to differentiate the 1170 * MSI payload against other DMA payload and has to modify the 1171 * MSI payload. This makes it difficult for these platforms to 1172 * have a SMMU translation for MSI. In order to workaround this, 1173 * ARM SMMUv3 driver requires a quirk to treat the MSI regions 1174 * separately. Such a quirk is currently missing for DT based 1175 * systems. Hence please make sure that the smmu pcie node on 1176 * hip07 is disabled as this will break the PCIe functionality 1177 * when iommu-map entry is used along with the PCIe node. 1178 * Refer:https://www.spinics.net/lists/arm-kernel/msg602812.html 1179 */ 1180 smmu0: iommu@a0040000 { 1181 compatible = "arm,smmu-v3"; 1182 reg = <0x0 0xa0040000 0x0 0x20000>; 1183 #iommu-cells = <1>; 1184 dma-coherent; 1185 hisilicon,broken-prefetch-cmd; 1186 status = "disabled"; 1187 }; 1188 p0_smmu_alg_a: iommu@d0040000 { 1189 compatible = "arm,smmu-v3"; 1190 reg = <0x0 0xd0040000 0x0 0x20000>; 1191 interrupt-parent = <&p0_mbigen_smmu_alg_a>; 1192 interrupts = <733 1>, 1193 <734 1>, 1194 <735 1>; 1195 interrupt-names = "eventq", "gerror", "priq"; 1196 #iommu-cells = <1>; 1197 dma-coherent; 1198 hisilicon,broken-prefetch-cmd; 1199 }; 1200 p0_smmu_alg_b: iommu@8d0040000 { 1201 compatible = "arm,smmu-v3"; 1202 reg = <0x8 0xd0040000 0x0 0x20000>; 1203 interrupt-parent = <&p0_mbigen_smmu_alg_b>; 1204 interrupts = <733 1>, 1205 <734 1>, 1206 <735 1>; 1207 interrupt-names = "eventq", "gerror", "priq"; 1208 #iommu-cells = <1>; 1209 dma-coherent; 1210 hisilicon,broken-prefetch-cmd; 1211 }; 1212 p1_smmu_alg_a: iommu@400d0040000 { 1213 compatible = "arm,smmu-v3"; 1214 reg = <0x400 0xd0040000 0x0 0x20000>; 1215 interrupt-parent = <&p1_mbigen_smmu_alg_a>; 1216 interrupts = <733 1>, 1217 <734 1>, 1218 <735 1>; 1219 interrupt-names = "eventq", "gerror", "priq"; 1220 #iommu-cells = <1>; 1221 dma-coherent; 1222 hisilicon,broken-prefetch-cmd; 1223 }; 1224 p1_smmu_alg_b: iommu@408d0040000 { 1225 compatible = "arm,smmu-v3"; 1226 reg = <0x408 0xd0040000 0x0 0x20000>; 1227 interrupt-parent = <&p1_mbigen_smmu_alg_b>; 1228 interrupts = <733 1>, 1229 <734 1>, 1230 <735 1>; 1231 interrupt-names = "eventq", "gerror", "priq"; 1232 #iommu-cells = <1>; 1233 dma-coherent; 1234 hisilicon,broken-prefetch-cmd; 1235 }; 1236 1237 soc { 1238 compatible = "simple-bus"; 1239 #address-cells = <2>; 1240 #size-cells = <2>; 1241 ranges; 1242 1243 isa@a01b0000 { 1244 compatible = "hisilicon,hip07-lpc"; 1245 #size-cells = <1>; 1246 #address-cells = <2>; 1247 reg = <0x0 0xa01b0000 0x0 0x1000>; 1248 1249 ipmi0: bt@e4 { 1250 compatible = "ipmi-bt"; 1251 device_type = "ipmi"; 1252 reg = <0x01 0xe4 0x04>; 1253 status = "disabled"; 1254 }; 1255 }; 1256 1257 uart0: uart@602b0000 { 1258 compatible = "arm,sbsa-uart"; 1259 reg = <0x0 0x602b0000 0x0 0x1000>; 1260 interrupt-parent = <&mbigen_uart>; 1261 interrupts = <807 4>; 1262 current-speed = <115200>; 1263 reg-io-width = <4>; 1264 status = "disabled"; 1265 }; 1266 1267 usb_ohci: usb@a7030000 { 1268 compatible = "generic-ohci"; 1269 reg = <0x0 0xa7030000 0x0 0x10000>; 1270 interrupt-parent = <&mbigen_usb>; 1271 interrupts = <640 4>; 1272 dma-coherent; 1273 status = "disabled"; 1274 }; 1275 1276 usb_ehci: usb@a7020000 { 1277 compatible = "generic-ehci"; 1278 reg = <0x0 0xa7020000 0x0 0x10000>; 1279 interrupt-parent = <&mbigen_usb>; 1280 interrupts = <641 4>; 1281 dma-coherent; 1282 status = "disabled"; 1283 }; 1284 1285 peri_c_subctrl: sub_ctrl_c@60000000 { 1286 compatible = "hisilicon,peri-subctrl","syscon"; 1287 reg = <0 0x60000000 0x0 0x10000>; 1288 }; 1289 1290 dsa_subctrl: dsa_subctrl@c0000000 { 1291 compatible = "hisilicon,dsa-subctrl", "syscon"; 1292 reg = <0x0 0xc0000000 0x0 0x10000>; 1293 }; 1294 1295 dsa_cpld: dsa_cpld@78000010 { 1296 compatible = "syscon"; 1297 reg = <0x0 0x78000010 0x0 0x100>; 1298 reg-io-width = <2>; 1299 }; 1300 1301 pcie_subctl: pcie_subctl@a0000000 { 1302 compatible = "hisilicon,pcie-sas-subctrl", "syscon"; 1303 reg = <0x0 0xa0000000 0x0 0x10000>; 1304 }; 1305 1306 serdes_ctrl: sds_ctrl@c2200000 { 1307 compatible = "syscon"; 1308 reg = <0 0xc2200000 0x0 0x80000>; 1309 }; 1310 1311 mdio@603c0000 { 1312 compatible = "hisilicon,hns-mdio"; 1313 reg = <0x0 0x603c0000 0x0 0x1000>; 1314 subctrl-vbase = <&peri_c_subctrl 0x338 0xa38 1315 0x531c 0x5a1c>; 1316 #address-cells = <1>; 1317 #size-cells = <0>; 1318 1319 phy0: ethernet-phy@0 { 1320 compatible = "ethernet-phy-ieee802.3-c22"; 1321 reg = <0>; 1322 }; 1323 1324 phy1: ethernet-phy@1 { 1325 compatible = "ethernet-phy-ieee802.3-c22"; 1326 reg = <1>; 1327 }; 1328 }; 1329 1330 dsaf0: dsa@c7000000 { 1331 #address-cells = <1>; 1332 #size-cells = <0>; 1333 compatible = "hisilicon,hns-dsaf-v2"; 1334 mode = "6port-16rss"; 1335 reg = <0x0 0xc5000000 0x0 0x890000>, 1336 <0x0 0xc7000000 0x0 0x600000>; 1337 reg-names = "ppe-base", "dsaf-base"; 1338 interrupt-parent = <&mbigen_dsaf0>; 1339 subctrl-syscon = <&dsa_subctrl>; 1340 reset-field-offset = <0>; 1341 interrupts = 1342 <576 1>, <577 1>, <578 1>, <579 1>, <580 1>, 1343 <581 1>, <582 1>, <583 1>, <584 1>, <585 1>, 1344 <586 1>, <587 1>, <588 1>, <589 1>, <590 1>, 1345 <591 1>, <592 1>, <593 1>, <594 1>, <595 1>, 1346 <596 1>, <597 1>, <598 1>, <599 1>, <600 1>, 1347 <960 1>, <961 1>, <962 1>, <963 1>, <964 1>, 1348 <965 1>, <966 1>, <967 1>, <968 1>, <969 1>, 1349 <970 1>, <971 1>, <972 1>, <973 1>, <974 1>, 1350 <975 1>, <976 1>, <977 1>, <978 1>, <979 1>, 1351 <980 1>, <981 1>, <982 1>, <983 1>, <984 1>, 1352 <985 1>, <986 1>, <987 1>, <988 1>, <989 1>, 1353 <990 1>, <991 1>, <992 1>, <993 1>, <994 1>, 1354 <995 1>, <996 1>, <997 1>, <998 1>, <999 1>, 1355 <1000 1>, <1001 1>, <1002 1>, <1003 1>, <1004 1>, 1356 <1005 1>, <1006 1>, <1007 1>, <1008 1>, <1009 1>, 1357 <1010 1>, <1011 1>, <1012 1>, <1013 1>, <1014 1>, 1358 <1015 1>, <1016 1>, <1017 1>, <1018 1>, <1019 1>, 1359 <1020 1>, <1021 1>, <1022 1>, <1023 1>, <1024 1>, 1360 <1025 1>, <1026 1>, <1027 1>, <1028 1>, <1029 1>, 1361 <1030 1>, <1031 1>, <1032 1>, <1033 1>, <1034 1>, 1362 <1035 1>, <1036 1>, <1037 1>, <1038 1>, <1039 1>, 1363 <1040 1>, <1041 1>, <1042 1>, <1043 1>, <1044 1>, 1364 <1045 1>, <1046 1>, <1047 1>, <1048 1>, <1049 1>, 1365 <1050 1>, <1051 1>, <1052 1>, <1053 1>, <1054 1>, 1366 <1055 1>, <1056 1>, <1057 1>, <1058 1>, <1059 1>, 1367 <1060 1>, <1061 1>, <1062 1>, <1063 1>, <1064 1>, 1368 <1065 1>, <1066 1>, <1067 1>, <1068 1>, <1069 1>, 1369 <1070 1>, <1071 1>, <1072 1>, <1073 1>, <1074 1>, 1370 <1075 1>, <1076 1>, <1077 1>, <1078 1>, <1079 1>, 1371 <1080 1>, <1081 1>, <1082 1>, <1083 1>, <1084 1>, 1372 <1085 1>, <1086 1>, <1087 1>, <1088 1>, <1089 1>, 1373 <1090 1>, <1091 1>, <1092 1>, <1093 1>, <1094 1>, 1374 <1095 1>, <1096 1>, <1097 1>, <1098 1>, <1099 1>, 1375 <1100 1>, <1101 1>, <1102 1>, <1103 1>, <1104 1>, 1376 <1105 1>, <1106 1>, <1107 1>, <1108 1>, <1109 1>, 1377 <1110 1>, <1111 1>, <1112 1>, <1113 1>, <1114 1>, 1378 <1115 1>, <1116 1>, <1117 1>, <1118 1>, <1119 1>, 1379 <1120 1>, <1121 1>, <1122 1>, <1123 1>, <1124 1>, 1380 <1125 1>, <1126 1>, <1127 1>, <1128 1>, <1129 1>, 1381 <1130 1>, <1131 1>, <1132 1>, <1133 1>, <1134 1>, 1382 <1135 1>, <1136 1>, <1137 1>, <1138 1>, <1139 1>, 1383 <1140 1>, <1141 1>, <1142 1>, <1143 1>, <1144 1>, 1384 <1145 1>, <1146 1>, <1147 1>, <1148 1>, <1149 1>, 1385 <1150 1>, <1151 1>, <1152 1>, <1153 1>, <1154 1>, 1386 <1155 1>, <1156 1>, <1157 1>, <1158 1>, <1159 1>, 1387 <1160 1>, <1161 1>, <1162 1>, <1163 1>, <1164 1>, 1388 <1165 1>, <1166 1>, <1167 1>, <1168 1>, <1169 1>, 1389 <1170 1>, <1171 1>, <1172 1>, <1173 1>, <1174 1>, 1390 <1175 1>, <1176 1>, <1177 1>, <1178 1>, <1179 1>, 1391 <1180 1>, <1181 1>, <1182 1>, <1183 1>, <1184 1>, 1392 <1185 1>, <1186 1>, <1187 1>, <1188 1>, <1189 1>, 1393 <1190 1>, <1191 1>, <1192 1>, <1193 1>, <1194 1>, 1394 <1195 1>, <1196 1>, <1197 1>, <1198 1>, <1199 1>, 1395 <1200 1>, <1201 1>, <1202 1>, <1203 1>, <1204 1>, 1396 <1205 1>, <1206 1>, <1207 1>, <1208 1>, <1209 1>, 1397 <1210 1>, <1211 1>, <1212 1>, <1213 1>, <1214 1>, 1398 <1215 1>, <1216 1>, <1217 1>, <1218 1>, <1219 1>, 1399 <1220 1>, <1221 1>, <1222 1>, <1223 1>, <1224 1>, 1400 <1225 1>, <1226 1>, <1227 1>, <1228 1>, <1229 1>, 1401 <1230 1>, <1231 1>, <1232 1>, <1233 1>, <1234 1>, 1402 <1235 1>, <1236 1>, <1237 1>, <1238 1>, <1239 1>, 1403 <1240 1>, <1241 1>, <1242 1>, <1243 1>, <1244 1>, 1404 <1245 1>, <1246 1>, <1247 1>, <1248 1>, <1249 1>, 1405 <1250 1>, <1251 1>, <1252 1>, <1253 1>, <1254 1>, 1406 <1255 1>, <1256 1>, <1257 1>, <1258 1>, <1259 1>, 1407 <1260 1>, <1261 1>, <1262 1>, <1263 1>, <1264 1>, 1408 <1265 1>, <1266 1>, <1267 1>, <1268 1>, <1269 1>, 1409 <1270 1>, <1271 1>, <1272 1>, <1273 1>, <1274 1>, 1410 <1275 1>, <1276 1>, <1277 1>, <1278 1>, <1279 1>, 1411 <1280 1>, <1281 1>, <1282 1>, <1283 1>, <1284 1>, 1412 <1285 1>, <1286 1>, <1287 1>, <1288 1>, <1289 1>, 1413 <1290 1>, <1291 1>, <1292 1>, <1293 1>, <1294 1>, 1414 <1295 1>, <1296 1>, <1297 1>, <1298 1>, <1299 1>, 1415 <1300 1>, <1301 1>, <1302 1>, <1303 1>, <1304 1>, 1416 <1305 1>, <1306 1>, <1307 1>, <1308 1>, <1309 1>, 1417 <1310 1>, <1311 1>, <1312 1>, <1313 1>, <1314 1>, 1418 <1315 1>, <1316 1>, <1317 1>, <1318 1>, <1319 1>, 1419 <1320 1>, <1321 1>, <1322 1>, <1323 1>, <1324 1>, 1420 <1325 1>, <1326 1>, <1327 1>, <1328 1>, <1329 1>, 1421 <1330 1>, <1331 1>, <1332 1>, <1333 1>, <1334 1>, 1422 <1335 1>, <1336 1>, <1337 1>, <1338 1>, <1339 1>, 1423 <1340 1>, <1341 1>, <1342 1>, <1343 1>; 1424 1425 desc-num = <0x400>; 1426 buf-size = <0x1000>; 1427 dma-coherent; 1428 1429 port@0 { 1430 reg = <0>; 1431 serdes-syscon = <&serdes_ctrl>; 1432 cpld-syscon = <&dsa_cpld 0x0>; 1433 port-rst-offset = <0>; 1434 port-mode-offset = <0>; 1435 mc-mac-mask = [ff f0 00 00 00 00]; 1436 media-type = "fiber"; 1437 }; 1438 1439 port@1 { 1440 reg = <1>; 1441 serdes-syscon = <&serdes_ctrl>; 1442 cpld-syscon = <&dsa_cpld 0x4>; 1443 port-rst-offset = <1>; 1444 port-mode-offset = <1>; 1445 mc-mac-mask = [ff f0 00 00 00 00]; 1446 media-type = "fiber"; 1447 }; 1448 1449 port@4 { 1450 reg = <4>; 1451 phy-handle = <&phy0>; 1452 serdes-syscon = <&serdes_ctrl>; 1453 port-rst-offset = <4>; 1454 port-mode-offset = <2>; 1455 mc-mac-mask = [ff f0 00 00 00 00]; 1456 media-type = "copper"; 1457 }; 1458 1459 port@5 { 1460 reg = <5>; 1461 phy-handle = <&phy1>; 1462 serdes-syscon = <&serdes_ctrl>; 1463 port-rst-offset = <5>; 1464 port-mode-offset = <3>; 1465 mc-mac-mask = [ff f0 00 00 00 00]; 1466 media-type = "copper"; 1467 }; 1468 }; 1469 1470 eth0: ethernet@4{ 1471 compatible = "hisilicon,hns-nic-v2"; 1472 ae-handle = <&dsaf0>; 1473 port-idx-in-ae = <4>; 1474 local-mac-address = [00 00 00 00 00 00]; 1475 status = "disabled"; 1476 dma-coherent; 1477 }; 1478 1479 eth1: ethernet@5{ 1480 compatible = "hisilicon,hns-nic-v2"; 1481 ae-handle = <&dsaf0>; 1482 port-idx-in-ae = <5>; 1483 local-mac-address = [00 00 00 00 00 00]; 1484 status = "disabled"; 1485 dma-coherent; 1486 }; 1487 1488 eth2: ethernet@0{ 1489 compatible = "hisilicon,hns-nic-v2"; 1490 ae-handle = <&dsaf0>; 1491 port-idx-in-ae = <0>; 1492 local-mac-address = [00 00 00 00 00 00]; 1493 status = "disabled"; 1494 dma-coherent; 1495 }; 1496 1497 eth3: ethernet@1{ 1498 compatible = "hisilicon,hns-nic-v2"; 1499 ae-handle = <&dsaf0>; 1500 port-idx-in-ae = <1>; 1501 local-mac-address = [00 00 00 00 00 00]; 1502 status = "disabled"; 1503 dma-coherent; 1504 }; 1505 1506 infiniband@c4000000 { 1507 compatible = "hisilicon,hns-roce-v1"; 1508 reg = <0x0 0xc4000000 0x0 0x100000>; 1509 dma-coherent; 1510 eth-handle = <ð2 ð3 0 0 ð0 ð1>; 1511 dsaf-handle = <&dsaf0>; 1512 node-guid = [00 9A CD 00 00 01 02 03]; 1513 #address-cells = <2>; 1514 #size-cells = <2>; 1515 interrupt-parent = <&mbigen_dsa_roce>; 1516 interrupts = <722 1>, 1517 <723 1>, 1518 <724 1>, 1519 <725 1>, 1520 <726 1>, 1521 <727 1>, 1522 <728 1>, 1523 <729 1>, 1524 <730 1>, 1525 <731 1>, 1526 <732 1>, 1527 <733 1>, 1528 <734 1>, 1529 <735 1>, 1530 <736 1>, 1531 <737 1>, 1532 <738 1>, 1533 <739 1>, 1534 <740 1>, 1535 <741 1>, 1536 <742 1>, 1537 <743 1>, 1538 <744 1>, 1539 <745 1>, 1540 <746 1>, 1541 <747 1>, 1542 <748 1>, 1543 <749 1>, 1544 <750 1>, 1545 <751 1>, 1546 <752 1>, 1547 <753 1>, 1548 <785 1>, 1549 <754 4>; 1550 1551 interrupt-names = "hns-roce-comp-0", 1552 "hns-roce-comp-1", 1553 "hns-roce-comp-2", 1554 "hns-roce-comp-3", 1555 "hns-roce-comp-4", 1556 "hns-roce-comp-5", 1557 "hns-roce-comp-6", 1558 "hns-roce-comp-7", 1559 "hns-roce-comp-8", 1560 "hns-roce-comp-9", 1561 "hns-roce-comp-10", 1562 "hns-roce-comp-11", 1563 "hns-roce-comp-12", 1564 "hns-roce-comp-13", 1565 "hns-roce-comp-14", 1566 "hns-roce-comp-15", 1567 "hns-roce-comp-16", 1568 "hns-roce-comp-17", 1569 "hns-roce-comp-18", 1570 "hns-roce-comp-19", 1571 "hns-roce-comp-20", 1572 "hns-roce-comp-21", 1573 "hns-roce-comp-22", 1574 "hns-roce-comp-23", 1575 "hns-roce-comp-24", 1576 "hns-roce-comp-25", 1577 "hns-roce-comp-26", 1578 "hns-roce-comp-27", 1579 "hns-roce-comp-28", 1580 "hns-roce-comp-29", 1581 "hns-roce-comp-30", 1582 "hns-roce-comp-31", 1583 "hns-roce-async", 1584 "hns-roce-common"; 1585 }; 1586 1587 sas0: sas@c3000000 { 1588 compatible = "hisilicon,hip07-sas-v2"; 1589 reg = <0 0xc3000000 0 0x10000>; 1590 sas-addr = [50 01 88 20 16 00 00 00]; 1591 hisilicon,sas-syscon = <&dsa_subctrl>; 1592 ctrl-reset-reg = <0xa60>; 1593 ctrl-reset-sts-reg = <0x5a30>; 1594 ctrl-clock-ena-reg = <0x338>; 1595 queue-count = <16>; 1596 phy-count = <8>; 1597 dma-coherent; 1598 interrupt-parent = <&mbigen_sas0>; 1599 interrupts = <64 4>,<65 4>,<66 4>,<67 4>,<68 4>, 1600 <69 4>,<70 4>,<71 4>,<72 4>,<73 4>, 1601 <74 4>,<75 4>,<76 4>,<77 4>,<78 4>, 1602 <79 4>,<80 4>,<81 4>,<82 4>,<83 4>, 1603 <84 4>,<85 4>,<86 4>,<87 4>,<88 4>, 1604 <89 4>,<90 4>,<91 4>,<92 4>,<93 4>, 1605 <94 4>,<95 4>,<96 4>,<97 4>,<98 4>, 1606 <99 4>,<100 4>,<101 4>,<102 4>,<103 4>, 1607 <104 4>,<105 4>,<106 4>,<107 4>,<108 4>, 1608 <109 4>,<110 4>,<111 4>,<112 4>,<113 4>, 1609 <114 4>,<115 4>,<116 4>,<117 4>,<118 4>, 1610 <119 4>,<120 4>,<121 4>,<122 4>,<123 4>, 1611 <124 4>,<125 4>,<126 4>,<127 4>,<128 4>, 1612 <129 4>,<130 4>,<131 4>,<132 4>,<133 4>, 1613 <134 4>,<135 4>,<136 4>,<137 4>,<138 4>, 1614 <139 4>,<140 4>,<141 4>,<142 4>,<143 4>, 1615 <144 4>,<145 4>,<146 4>,<147 4>,<148 4>, 1616 <149 4>,<150 4>,<151 4>,<152 4>,<153 4>, 1617 <154 4>,<155 4>,<156 4>,<157 4>,<158 4>, 1618 <159 4>,<601 1>,<602 1>,<603 1>,<604 1>, 1619 <605 1>,<606 1>,<607 1>,<608 1>,<609 1>, 1620 <610 1>,<611 1>,<612 1>,<613 1>,<614 1>, 1621 <615 1>,<616 1>,<617 1>,<618 1>,<619 1>, 1622 <620 1>,<621 1>,<622 1>,<623 1>,<624 1>, 1623 <625 1>,<626 1>,<627 1>,<628 1>,<629 1>, 1624 <630 1>,<631 1>,<632 1>; 1625 status = "disabled"; 1626 }; 1627 1628 sas1: sas@a2000000 { 1629 compatible = "hisilicon,hip07-sas-v2"; 1630 reg = <0 0xa2000000 0 0x10000>; 1631 sas-addr = [50 01 88 20 16 00 00 00]; 1632 hisilicon,sas-syscon = <&pcie_subctl>; 1633 hip06-sas-v2-quirk-amt; 1634 ctrl-reset-reg = <0xa18>; 1635 ctrl-reset-sts-reg = <0x5a0c>; 1636 ctrl-clock-ena-reg = <0x318>; 1637 queue-count = <16>; 1638 phy-count = <8>; 1639 dma-coherent; 1640 interrupt-parent = <&mbigen_sas1>; 1641 interrupts = <64 4>,<65 4>,<66 4>,<67 4>,<68 4>, 1642 <69 4>,<70 4>,<71 4>,<72 4>,<73 4>, 1643 <74 4>,<75 4>,<76 4>,<77 4>,<78 4>, 1644 <79 4>,<80 4>,<81 4>,<82 4>,<83 4>, 1645 <84 4>,<85 4>,<86 4>,<87 4>,<88 4>, 1646 <89 4>,<90 4>,<91 4>,<92 4>,<93 4>, 1647 <94 4>,<95 4>,<96 4>,<97 4>,<98 4>, 1648 <99 4>,<100 4>,<101 4>,<102 4>,<103 4>, 1649 <104 4>,<105 4>,<106 4>,<107 4>,<108 4>, 1650 <109 4>,<110 4>,<111 4>,<112 4>,<113 4>, 1651 <114 4>,<115 4>,<116 4>,<117 4>,<118 4>, 1652 <119 4>,<120 4>,<121 4>,<122 4>,<123 4>, 1653 <124 4>,<125 4>,<126 4>,<127 4>,<128 4>, 1654 <129 4>,<130 4>,<131 4>,<132 4>,<133 4>, 1655 <134 4>,<135 4>,<136 4>,<137 4>,<138 4>, 1656 <139 4>,<140 4>,<141 4>,<142 4>,<143 4>, 1657 <144 4>,<145 4>,<146 4>,<147 4>,<148 4>, 1658 <149 4>,<150 4>,<151 4>,<152 4>,<153 4>, 1659 <154 4>,<155 4>,<156 4>,<157 4>,<158 4>, 1660 <159 4>,<576 1>,<577 1>,<578 1>,<579 1>, 1661 <580 1>,<581 1>,<582 1>,<583 1>,<584 1>, 1662 <585 1>,<586 1>,<587 1>,<588 1>,<589 1>, 1663 <590 1>,<591 1>,<592 1>,<593 1>,<594 1>, 1664 <595 1>,<596 1>,<597 1>,<598 1>,<599 1>, 1665 <600 1>,<601 1>,<602 1>,<603 1>,<604 1>, 1666 <605 1>,<606 1>,<607 1>; 1667 status = "disabled"; 1668 }; 1669 1670 sas2: sas@a3000000 { 1671 compatible = "hisilicon,hip07-sas-v2"; 1672 reg = <0 0xa3000000 0 0x10000>; 1673 sas-addr = [50 01 88 20 16 00 00 00]; 1674 hisilicon,sas-syscon = <&pcie_subctl>; 1675 ctrl-reset-reg = <0xae0>; 1676 ctrl-reset-sts-reg = <0x5a70>; 1677 ctrl-clock-ena-reg = <0x3a8>; 1678 queue-count = <16>; 1679 phy-count = <9>; 1680 dma-coherent; 1681 interrupt-parent = <&mbigen_sas2>; 1682 interrupts = <192 4>,<193 4>,<194 4>,<195 4>,<196 4>, 1683 <197 4>,<198 4>,<199 4>,<200 4>,<201 4>, 1684 <202 4>,<203 4>,<204 4>,<205 4>,<206 4>, 1685 <207 4>,<208 4>,<209 4>,<210 4>,<211 4>, 1686 <212 4>,<213 4>,<214 4>,<215 4>,<216 4>, 1687 <217 4>,<218 4>,<219 4>,<220 4>,<221 4>, 1688 <222 4>,<223 4>,<224 4>,<225 4>,<226 4>, 1689 <227 4>,<228 4>,<229 4>,<230 4>,<231 4>, 1690 <232 4>,<233 4>,<234 4>,<235 4>,<236 4>, 1691 <237 4>,<238 4>,<239 4>,<240 4>,<241 4>, 1692 <242 4>,<243 4>,<244 4>,<245 4>,<246 4>, 1693 <247 4>,<248 4>,<249 4>,<250 4>,<251 4>, 1694 <252 4>,<253 4>,<254 4>,<255 4>,<256 4>, 1695 <257 4>,<258 4>,<259 4>,<260 4>,<261 4>, 1696 <262 4>,<263 4>,<264 4>,<265 4>,<266 4>, 1697 <267 4>,<268 4>,<269 4>,<270 4>,<271 4>, 1698 <272 4>,<273 4>,<274 4>,<275 4>,<276 4>, 1699 <277 4>,<278 4>,<279 4>,<280 4>,<281 4>, 1700 <282 4>,<283 4>,<284 4>,<285 4>,<286 4>, 1701 <287 4>,<608 1>,<609 1>,<610 1>,<611 1>, 1702 <612 1>,<613 1>,<614 1>,<615 1>,<616 1>, 1703 <617 1>,<618 1>,<619 1>,<620 1>,<621 1>, 1704 <622 1>,<623 1>,<624 1>,<625 1>,<626 1>, 1705 <627 1>,<628 1>,<629 1>,<630 1>,<631 1>, 1706 <632 1>,<633 1>,<634 1>,<635 1>,<636 1>, 1707 <637 1>,<638 1>,<639 1>; 1708 status = "disabled"; 1709 }; 1710 1711 p0_pcie2_a: pcie@a00a0000 { 1712 compatible = "hisilicon,hip07-pcie-ecam"; 1713 reg = <0 0xaf800000 0 0x800000>, 1714 <0 0xa00a0000 0 0x10000>; 1715 bus-range = <0xf8 0xff>; 1716 msi-map = <0xf800 &p0_its_dsa_a 0xf800 0x800>; 1717 msi-map-mask = <0xffff>; 1718 #address-cells = <3>; 1719 #size-cells = <2>; 1720 device_type = "pci"; 1721 dma-coherent; 1722 ranges = <0x02000000 0 0xa8000000 0 0xa8000000 0 0x77f0000>, 1723 <0x01000000 0 0 0 0xaf7f0000 0 0x10000>; 1724 #interrupt-cells = <1>; 1725 interrupt-map-mask = <0xf800 0 0 7>; 1726 interrupt-map = <0x0 0 0 1 &mbigen_pcie2_a 671 4 1727 0x0 0 0 2 &mbigen_pcie2_a 671 4 1728 0x0 0 0 3 &mbigen_pcie2_a 671 4 1729 0x0 0 0 4 &mbigen_pcie2_a 671 4>; 1730 status = "disabled"; 1731 }; 1732 p0_sec_a: crypto@d2000000 { 1733 compatible = "hisilicon,hip07-sec"; 1734 reg = <0x0 0xd0000000 0x0 0x10000>, 1735 <0x0 0xd2000000 0x0 0x10000>, 1736 <0x0 0xd2010000 0x0 0x10000>, 1737 <0x0 0xd2020000 0x0 0x10000>, 1738 <0x0 0xd2030000 0x0 0x10000>, 1739 <0x0 0xd2040000 0x0 0x10000>, 1740 <0x0 0xd2050000 0x0 0x10000>, 1741 <0x0 0xd2060000 0x0 0x10000>, 1742 <0x0 0xd2070000 0x0 0x10000>, 1743 <0x0 0xd2080000 0x0 0x10000>, 1744 <0x0 0xd2090000 0x0 0x10000>, 1745 <0x0 0xd20a0000 0x0 0x10000>, 1746 <0x0 0xd20b0000 0x0 0x10000>, 1747 <0x0 0xd20c0000 0x0 0x10000>, 1748 <0x0 0xd20d0000 0x0 0x10000>, 1749 <0x0 0xd20e0000 0x0 0x10000>, 1750 <0x0 0xd20f0000 0x0 0x10000>, 1751 <0x0 0xd2100000 0x0 0x10000>; 1752 interrupt-parent = <&p0_mbigen_sec_a>; 1753 iommus = <&p0_smmu_alg_a 0x600>; 1754 dma-coherent; 1755 interrupts = <576 4>, 1756 <577 1>, <578 4>, 1757 <579 1>, <580 4>, 1758 <581 1>, <582 4>, 1759 <583 1>, <584 4>, 1760 <585 1>, <586 4>, 1761 <587 1>, <588 4>, 1762 <589 1>, <590 4>, 1763 <591 1>, <592 4>, 1764 <593 1>, <594 4>, 1765 <595 1>, <596 4>, 1766 <597 1>, <598 4>, 1767 <599 1>, <600 4>, 1768 <601 1>, <602 4>, 1769 <603 1>, <604 4>, 1770 <605 1>, <606 4>, 1771 <607 1>, <608 4>; 1772 }; 1773 p0_sec_b: crypto@8,d2000000 { 1774 compatible = "hisilicon,hip07-sec"; 1775 reg = <0x8 0xd0000000 0x0 0x10000>, 1776 <0x8 0xd2000000 0x0 0x10000>, 1777 <0x8 0xd2010000 0x0 0x10000>, 1778 <0x8 0xd2020000 0x0 0x10000>, 1779 <0x8 0xd2030000 0x0 0x10000>, 1780 <0x8 0xd2040000 0x0 0x10000>, 1781 <0x8 0xd2050000 0x0 0x10000>, 1782 <0x8 0xd2060000 0x0 0x10000>, 1783 <0x8 0xd2070000 0x0 0x10000>, 1784 <0x8 0xd2080000 0x0 0x10000>, 1785 <0x8 0xd2090000 0x0 0x10000>, 1786 <0x8 0xd20a0000 0x0 0x10000>, 1787 <0x8 0xd20b0000 0x0 0x10000>, 1788 <0x8 0xd20c0000 0x0 0x10000>, 1789 <0x8 0xd20d0000 0x0 0x10000>, 1790 <0x8 0xd20e0000 0x0 0x10000>, 1791 <0x8 0xd20f0000 0x0 0x10000>, 1792 <0x8 0xd2100000 0x0 0x10000>; 1793 interrupt-parent = <&p0_mbigen_sec_b>; 1794 iommus = <&p0_smmu_alg_b 0x600>; 1795 dma-coherent; 1796 interrupts = <576 4>, 1797 <577 1>, <578 4>, 1798 <579 1>, <580 4>, 1799 <581 1>, <582 4>, 1800 <583 1>, <584 4>, 1801 <585 1>, <586 4>, 1802 <587 1>, <588 4>, 1803 <589 1>, <590 4>, 1804 <591 1>, <592 4>, 1805 <593 1>, <594 4>, 1806 <595 1>, <596 4>, 1807 <597 1>, <598 4>, 1808 <599 1>, <600 4>, 1809 <601 1>, <602 4>, 1810 <603 1>, <604 4>, 1811 <605 1>, <606 4>, 1812 <607 1>, <608 4>; 1813 }; 1814 p1_sec_a: crypto@400,d2000000 { 1815 compatible = "hisilicon,hip07-sec"; 1816 reg = <0x400 0xd0000000 0x0 0x10000>, 1817 <0x400 0xd2000000 0x0 0x10000>, 1818 <0x400 0xd2010000 0x0 0x10000>, 1819 <0x400 0xd2020000 0x0 0x10000>, 1820 <0x400 0xd2030000 0x0 0x10000>, 1821 <0x400 0xd2040000 0x0 0x10000>, 1822 <0x400 0xd2050000 0x0 0x10000>, 1823 <0x400 0xd2060000 0x0 0x10000>, 1824 <0x400 0xd2070000 0x0 0x10000>, 1825 <0x400 0xd2080000 0x0 0x10000>, 1826 <0x400 0xd2090000 0x0 0x10000>, 1827 <0x400 0xd20a0000 0x0 0x10000>, 1828 <0x400 0xd20b0000 0x0 0x10000>, 1829 <0x400 0xd20c0000 0x0 0x10000>, 1830 <0x400 0xd20d0000 0x0 0x10000>, 1831 <0x400 0xd20e0000 0x0 0x10000>, 1832 <0x400 0xd20f0000 0x0 0x10000>, 1833 <0x400 0xd2100000 0x0 0x10000>; 1834 interrupt-parent = <&p1_mbigen_sec_a>; 1835 iommus = <&p1_smmu_alg_a 0x600>; 1836 dma-coherent; 1837 interrupts = <576 4>, 1838 <577 1>, <578 4>, 1839 <579 1>, <580 4>, 1840 <581 1>, <582 4>, 1841 <583 1>, <584 4>, 1842 <585 1>, <586 4>, 1843 <587 1>, <588 4>, 1844 <589 1>, <590 4>, 1845 <591 1>, <592 4>, 1846 <593 1>, <594 4>, 1847 <595 1>, <596 4>, 1848 <597 1>, <598 4>, 1849 <599 1>, <600 4>, 1850 <601 1>, <602 4>, 1851 <603 1>, <604 4>, 1852 <605 1>, <606 4>, 1853 <607 1>, <608 4>; 1854 }; 1855 p1_sec_b: crypto@408,d2000000 { 1856 compatible = "hisilicon,hip07-sec"; 1857 reg = <0x408 0xd0000000 0x0 0x10000>, 1858 <0x408 0xd2000000 0x0 0x10000>, 1859 <0x408 0xd2010000 0x0 0x10000>, 1860 <0x408 0xd2020000 0x0 0x10000>, 1861 <0x408 0xd2030000 0x0 0x10000>, 1862 <0x408 0xd2040000 0x0 0x10000>, 1863 <0x408 0xd2050000 0x0 0x10000>, 1864 <0x408 0xd2060000 0x0 0x10000>, 1865 <0x408 0xd2070000 0x0 0x10000>, 1866 <0x408 0xd2080000 0x0 0x10000>, 1867 <0x408 0xd2090000 0x0 0x10000>, 1868 <0x408 0xd20a0000 0x0 0x10000>, 1869 <0x408 0xd20b0000 0x0 0x10000>, 1870 <0x408 0xd20c0000 0x0 0x10000>, 1871 <0x408 0xd20d0000 0x0 0x10000>, 1872 <0x408 0xd20e0000 0x0 0x10000>, 1873 <0x408 0xd20f0000 0x0 0x10000>, 1874 <0x408 0xd2100000 0x0 0x10000>; 1875 interrupt-parent = <&p1_mbigen_sec_b>; 1876 iommus = <&p1_smmu_alg_b 0x600>; 1877 dma-coherent; 1878 interrupts = <576 4>, 1879 <577 1>, <578 4>, 1880 <579 1>, <580 4>, 1881 <581 1>, <582 4>, 1882 <583 1>, <584 4>, 1883 <585 1>, <586 4>, 1884 <587 1>, <588 4>, 1885 <589 1>, <590 4>, 1886 <591 1>, <592 4>, 1887 <593 1>, <594 4>, 1888 <595 1>, <596 4>, 1889 <597 1>, <598 4>, 1890 <599 1>, <600 4>, 1891 <601 1>, <602 4>, 1892 <603 1>, <604 4>, 1893 <605 1>, <606 4>, 1894 <607 1>, <608 4>; 1895 }; 1896 1897 }; 1898}; 1899