162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0+ OR MIT 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * Apple T6002 "M1 Ultra" SoC 462306a36Sopenharmony_ci * 562306a36Sopenharmony_ci * Other names: H13J, "Jade 2C" 662306a36Sopenharmony_ci * 762306a36Sopenharmony_ci * Copyright The Asahi Linux Contributors 862306a36Sopenharmony_ci */ 962306a36Sopenharmony_ci 1062306a36Sopenharmony_ci#include <dt-bindings/gpio/gpio.h> 1162306a36Sopenharmony_ci#include <dt-bindings/interrupt-controller/apple-aic.h> 1262306a36Sopenharmony_ci#include <dt-bindings/interrupt-controller/irq.h> 1362306a36Sopenharmony_ci#include <dt-bindings/pinctrl/apple.h> 1462306a36Sopenharmony_ci 1562306a36Sopenharmony_ci#include "multi-die-cpp.h" 1662306a36Sopenharmony_ci 1762306a36Sopenharmony_ci#include "t600x-common.dtsi" 1862306a36Sopenharmony_ci 1962306a36Sopenharmony_ci/ { 2062306a36Sopenharmony_ci compatible = "apple,t6002", "apple,arm-platform"; 2162306a36Sopenharmony_ci 2262306a36Sopenharmony_ci #address-cells = <2>; 2362306a36Sopenharmony_ci #size-cells = <2>; 2462306a36Sopenharmony_ci 2562306a36Sopenharmony_ci cpus { 2662306a36Sopenharmony_ci cpu-map { 2762306a36Sopenharmony_ci cluster3 { 2862306a36Sopenharmony_ci core0 { 2962306a36Sopenharmony_ci cpu = <&cpu_e10>; 3062306a36Sopenharmony_ci }; 3162306a36Sopenharmony_ci core1 { 3262306a36Sopenharmony_ci cpu = <&cpu_e11>; 3362306a36Sopenharmony_ci }; 3462306a36Sopenharmony_ci }; 3562306a36Sopenharmony_ci 3662306a36Sopenharmony_ci cluster4 { 3762306a36Sopenharmony_ci core0 { 3862306a36Sopenharmony_ci cpu = <&cpu_p20>; 3962306a36Sopenharmony_ci }; 4062306a36Sopenharmony_ci core1 { 4162306a36Sopenharmony_ci cpu = <&cpu_p21>; 4262306a36Sopenharmony_ci }; 4362306a36Sopenharmony_ci core2 { 4462306a36Sopenharmony_ci cpu = <&cpu_p22>; 4562306a36Sopenharmony_ci }; 4662306a36Sopenharmony_ci core3 { 4762306a36Sopenharmony_ci cpu = <&cpu_p23>; 4862306a36Sopenharmony_ci }; 4962306a36Sopenharmony_ci }; 5062306a36Sopenharmony_ci 5162306a36Sopenharmony_ci cluster5 { 5262306a36Sopenharmony_ci core0 { 5362306a36Sopenharmony_ci cpu = <&cpu_p30>; 5462306a36Sopenharmony_ci }; 5562306a36Sopenharmony_ci core1 { 5662306a36Sopenharmony_ci cpu = <&cpu_p31>; 5762306a36Sopenharmony_ci }; 5862306a36Sopenharmony_ci core2 { 5962306a36Sopenharmony_ci cpu = <&cpu_p32>; 6062306a36Sopenharmony_ci }; 6162306a36Sopenharmony_ci core3 { 6262306a36Sopenharmony_ci cpu = <&cpu_p33>; 6362306a36Sopenharmony_ci }; 6462306a36Sopenharmony_ci }; 6562306a36Sopenharmony_ci }; 6662306a36Sopenharmony_ci 6762306a36Sopenharmony_ci cpu_e10: cpu@800 { 6862306a36Sopenharmony_ci compatible = "apple,icestorm"; 6962306a36Sopenharmony_ci device_type = "cpu"; 7062306a36Sopenharmony_ci reg = <0x0 0x800>; 7162306a36Sopenharmony_ci enable-method = "spin-table"; 7262306a36Sopenharmony_ci cpu-release-addr = <0 0>; /* To be filled by loader */ 7362306a36Sopenharmony_ci next-level-cache = <&l2_cache_3>; 7462306a36Sopenharmony_ci i-cache-size = <0x20000>; 7562306a36Sopenharmony_ci d-cache-size = <0x10000>; 7662306a36Sopenharmony_ci operating-points-v2 = <&icestorm_opp>; 7762306a36Sopenharmony_ci capacity-dmips-mhz = <714>; 7862306a36Sopenharmony_ci performance-domains = <&cpufreq_e_die1>; 7962306a36Sopenharmony_ci }; 8062306a36Sopenharmony_ci 8162306a36Sopenharmony_ci cpu_e11: cpu@801 { 8262306a36Sopenharmony_ci compatible = "apple,icestorm"; 8362306a36Sopenharmony_ci device_type = "cpu"; 8462306a36Sopenharmony_ci reg = <0x0 0x801>; 8562306a36Sopenharmony_ci enable-method = "spin-table"; 8662306a36Sopenharmony_ci cpu-release-addr = <0 0>; /* To be filled by loader */ 8762306a36Sopenharmony_ci next-level-cache = <&l2_cache_3>; 8862306a36Sopenharmony_ci i-cache-size = <0x20000>; 8962306a36Sopenharmony_ci d-cache-size = <0x10000>; 9062306a36Sopenharmony_ci operating-points-v2 = <&icestorm_opp>; 9162306a36Sopenharmony_ci capacity-dmips-mhz = <714>; 9262306a36Sopenharmony_ci performance-domains = <&cpufreq_e_die1>; 9362306a36Sopenharmony_ci }; 9462306a36Sopenharmony_ci 9562306a36Sopenharmony_ci cpu_p20: cpu@10900 { 9662306a36Sopenharmony_ci compatible = "apple,firestorm"; 9762306a36Sopenharmony_ci device_type = "cpu"; 9862306a36Sopenharmony_ci reg = <0x0 0x10900>; 9962306a36Sopenharmony_ci enable-method = "spin-table"; 10062306a36Sopenharmony_ci cpu-release-addr = <0 0>; /* To be filled by loader */ 10162306a36Sopenharmony_ci next-level-cache = <&l2_cache_4>; 10262306a36Sopenharmony_ci i-cache-size = <0x30000>; 10362306a36Sopenharmony_ci d-cache-size = <0x20000>; 10462306a36Sopenharmony_ci operating-points-v2 = <&firestorm_opp>; 10562306a36Sopenharmony_ci capacity-dmips-mhz = <1024>; 10662306a36Sopenharmony_ci performance-domains = <&cpufreq_p0_die1>; 10762306a36Sopenharmony_ci }; 10862306a36Sopenharmony_ci 10962306a36Sopenharmony_ci cpu_p21: cpu@10901 { 11062306a36Sopenharmony_ci compatible = "apple,firestorm"; 11162306a36Sopenharmony_ci device_type = "cpu"; 11262306a36Sopenharmony_ci reg = <0x0 0x10901>; 11362306a36Sopenharmony_ci enable-method = "spin-table"; 11462306a36Sopenharmony_ci cpu-release-addr = <0 0>; /* To be filled by loader */ 11562306a36Sopenharmony_ci next-level-cache = <&l2_cache_4>; 11662306a36Sopenharmony_ci i-cache-size = <0x30000>; 11762306a36Sopenharmony_ci d-cache-size = <0x20000>; 11862306a36Sopenharmony_ci operating-points-v2 = <&firestorm_opp>; 11962306a36Sopenharmony_ci capacity-dmips-mhz = <1024>; 12062306a36Sopenharmony_ci performance-domains = <&cpufreq_p0_die1>; 12162306a36Sopenharmony_ci }; 12262306a36Sopenharmony_ci 12362306a36Sopenharmony_ci cpu_p22: cpu@10902 { 12462306a36Sopenharmony_ci compatible = "apple,firestorm"; 12562306a36Sopenharmony_ci device_type = "cpu"; 12662306a36Sopenharmony_ci reg = <0x0 0x10902>; 12762306a36Sopenharmony_ci enable-method = "spin-table"; 12862306a36Sopenharmony_ci cpu-release-addr = <0 0>; /* To be filled by loader */ 12962306a36Sopenharmony_ci next-level-cache = <&l2_cache_4>; 13062306a36Sopenharmony_ci i-cache-size = <0x30000>; 13162306a36Sopenharmony_ci d-cache-size = <0x20000>; 13262306a36Sopenharmony_ci operating-points-v2 = <&firestorm_opp>; 13362306a36Sopenharmony_ci capacity-dmips-mhz = <1024>; 13462306a36Sopenharmony_ci performance-domains = <&cpufreq_p0_die1>; 13562306a36Sopenharmony_ci }; 13662306a36Sopenharmony_ci 13762306a36Sopenharmony_ci cpu_p23: cpu@10903 { 13862306a36Sopenharmony_ci compatible = "apple,firestorm"; 13962306a36Sopenharmony_ci device_type = "cpu"; 14062306a36Sopenharmony_ci reg = <0x0 0x10903>; 14162306a36Sopenharmony_ci enable-method = "spin-table"; 14262306a36Sopenharmony_ci cpu-release-addr = <0 0>; /* To be filled by loader */ 14362306a36Sopenharmony_ci next-level-cache = <&l2_cache_4>; 14462306a36Sopenharmony_ci i-cache-size = <0x30000>; 14562306a36Sopenharmony_ci d-cache-size = <0x20000>; 14662306a36Sopenharmony_ci operating-points-v2 = <&firestorm_opp>; 14762306a36Sopenharmony_ci capacity-dmips-mhz = <1024>; 14862306a36Sopenharmony_ci performance-domains = <&cpufreq_p0_die1>; 14962306a36Sopenharmony_ci }; 15062306a36Sopenharmony_ci 15162306a36Sopenharmony_ci cpu_p30: cpu@10a00 { 15262306a36Sopenharmony_ci compatible = "apple,firestorm"; 15362306a36Sopenharmony_ci device_type = "cpu"; 15462306a36Sopenharmony_ci reg = <0x0 0x10a00>; 15562306a36Sopenharmony_ci enable-method = "spin-table"; 15662306a36Sopenharmony_ci cpu-release-addr = <0 0>; /* To be filled by loader */ 15762306a36Sopenharmony_ci next-level-cache = <&l2_cache_5>; 15862306a36Sopenharmony_ci i-cache-size = <0x30000>; 15962306a36Sopenharmony_ci d-cache-size = <0x20000>; 16062306a36Sopenharmony_ci operating-points-v2 = <&firestorm_opp>; 16162306a36Sopenharmony_ci capacity-dmips-mhz = <1024>; 16262306a36Sopenharmony_ci performance-domains = <&cpufreq_p1_die1>; 16362306a36Sopenharmony_ci }; 16462306a36Sopenharmony_ci 16562306a36Sopenharmony_ci cpu_p31: cpu@10a01 { 16662306a36Sopenharmony_ci compatible = "apple,firestorm"; 16762306a36Sopenharmony_ci device_type = "cpu"; 16862306a36Sopenharmony_ci reg = <0x0 0x10a01>; 16962306a36Sopenharmony_ci enable-method = "spin-table"; 17062306a36Sopenharmony_ci cpu-release-addr = <0 0>; /* To be filled by loader */ 17162306a36Sopenharmony_ci next-level-cache = <&l2_cache_5>; 17262306a36Sopenharmony_ci i-cache-size = <0x30000>; 17362306a36Sopenharmony_ci d-cache-size = <0x20000>; 17462306a36Sopenharmony_ci operating-points-v2 = <&firestorm_opp>; 17562306a36Sopenharmony_ci capacity-dmips-mhz = <1024>; 17662306a36Sopenharmony_ci performance-domains = <&cpufreq_p1_die1>; 17762306a36Sopenharmony_ci }; 17862306a36Sopenharmony_ci 17962306a36Sopenharmony_ci cpu_p32: cpu@10a02 { 18062306a36Sopenharmony_ci compatible = "apple,firestorm"; 18162306a36Sopenharmony_ci device_type = "cpu"; 18262306a36Sopenharmony_ci reg = <0x0 0x10a02>; 18362306a36Sopenharmony_ci enable-method = "spin-table"; 18462306a36Sopenharmony_ci cpu-release-addr = <0 0>; /* To be filled by loader */ 18562306a36Sopenharmony_ci next-level-cache = <&l2_cache_5>; 18662306a36Sopenharmony_ci i-cache-size = <0x30000>; 18762306a36Sopenharmony_ci d-cache-size = <0x20000>; 18862306a36Sopenharmony_ci operating-points-v2 = <&firestorm_opp>; 18962306a36Sopenharmony_ci capacity-dmips-mhz = <1024>; 19062306a36Sopenharmony_ci performance-domains = <&cpufreq_p1_die1>; 19162306a36Sopenharmony_ci }; 19262306a36Sopenharmony_ci 19362306a36Sopenharmony_ci cpu_p33: cpu@10a03 { 19462306a36Sopenharmony_ci compatible = "apple,firestorm"; 19562306a36Sopenharmony_ci device_type = "cpu"; 19662306a36Sopenharmony_ci reg = <0x0 0x10a03>; 19762306a36Sopenharmony_ci enable-method = "spin-table"; 19862306a36Sopenharmony_ci cpu-release-addr = <0 0>; /* To be filled by loader */ 19962306a36Sopenharmony_ci next-level-cache = <&l2_cache_5>; 20062306a36Sopenharmony_ci i-cache-size = <0x30000>; 20162306a36Sopenharmony_ci d-cache-size = <0x20000>; 20262306a36Sopenharmony_ci operating-points-v2 = <&firestorm_opp>; 20362306a36Sopenharmony_ci capacity-dmips-mhz = <1024>; 20462306a36Sopenharmony_ci performance-domains = <&cpufreq_p1_die1>; 20562306a36Sopenharmony_ci }; 20662306a36Sopenharmony_ci 20762306a36Sopenharmony_ci l2_cache_3: l2-cache-3 { 20862306a36Sopenharmony_ci compatible = "cache"; 20962306a36Sopenharmony_ci cache-level = <2>; 21062306a36Sopenharmony_ci cache-unified; 21162306a36Sopenharmony_ci cache-size = <0x400000>; 21262306a36Sopenharmony_ci }; 21362306a36Sopenharmony_ci 21462306a36Sopenharmony_ci l2_cache_4: l2-cache-4 { 21562306a36Sopenharmony_ci compatible = "cache"; 21662306a36Sopenharmony_ci cache-level = <2>; 21762306a36Sopenharmony_ci cache-unified; 21862306a36Sopenharmony_ci cache-size = <0xc00000>; 21962306a36Sopenharmony_ci }; 22062306a36Sopenharmony_ci 22162306a36Sopenharmony_ci l2_cache_5: l2-cache-5 { 22262306a36Sopenharmony_ci compatible = "cache"; 22362306a36Sopenharmony_ci cache-level = <2>; 22462306a36Sopenharmony_ci cache-unified; 22562306a36Sopenharmony_ci cache-size = <0xc00000>; 22662306a36Sopenharmony_ci }; 22762306a36Sopenharmony_ci }; 22862306a36Sopenharmony_ci 22962306a36Sopenharmony_ci die0: soc@200000000 { 23062306a36Sopenharmony_ci compatible = "simple-bus"; 23162306a36Sopenharmony_ci #address-cells = <2>; 23262306a36Sopenharmony_ci #size-cells = <2>; 23362306a36Sopenharmony_ci ranges = <0x2 0x0 0x2 0x0 0x4 0x0>, 23462306a36Sopenharmony_ci <0x5 0x80000000 0x5 0x80000000 0x1 0x80000000>, 23562306a36Sopenharmony_ci <0x7 0x0 0x7 0x0 0xf 0x80000000>; 23662306a36Sopenharmony_ci nonposted-mmio; 23762306a36Sopenharmony_ci 23862306a36Sopenharmony_ci // filled via templated includes at the end of the file 23962306a36Sopenharmony_ci }; 24062306a36Sopenharmony_ci 24162306a36Sopenharmony_ci die1: soc@2200000000 { 24262306a36Sopenharmony_ci compatible = "simple-bus"; 24362306a36Sopenharmony_ci #address-cells = <2>; 24462306a36Sopenharmony_ci #size-cells = <2>; 24562306a36Sopenharmony_ci ranges = <0x2 0x0 0x22 0x0 0x4 0x0>, 24662306a36Sopenharmony_ci <0x7 0x0 0x27 0x0 0xf 0x80000000>; 24762306a36Sopenharmony_ci nonposted-mmio; 24862306a36Sopenharmony_ci 24962306a36Sopenharmony_ci // filled via templated includes at the end of the file 25062306a36Sopenharmony_ci }; 25162306a36Sopenharmony_ci}; 25262306a36Sopenharmony_ci 25362306a36Sopenharmony_ci#define DIE 25462306a36Sopenharmony_ci#define DIE_NO 0 25562306a36Sopenharmony_ci 25662306a36Sopenharmony_ci&die0 { 25762306a36Sopenharmony_ci #include "t600x-die0.dtsi" 25862306a36Sopenharmony_ci #include "t600x-dieX.dtsi" 25962306a36Sopenharmony_ci}; 26062306a36Sopenharmony_ci 26162306a36Sopenharmony_ci#include "t600x-pmgr.dtsi" 26262306a36Sopenharmony_ci#include "t600x-gpio-pins.dtsi" 26362306a36Sopenharmony_ci 26462306a36Sopenharmony_ci#undef DIE 26562306a36Sopenharmony_ci#undef DIE_NO 26662306a36Sopenharmony_ci 26762306a36Sopenharmony_ci#define DIE _die1 26862306a36Sopenharmony_ci#define DIE_NO 1 26962306a36Sopenharmony_ci 27062306a36Sopenharmony_ci&die1 { 27162306a36Sopenharmony_ci #include "t600x-dieX.dtsi" 27262306a36Sopenharmony_ci #include "t600x-nvme.dtsi" 27362306a36Sopenharmony_ci}; 27462306a36Sopenharmony_ci 27562306a36Sopenharmony_ci#include "t600x-pmgr.dtsi" 27662306a36Sopenharmony_ci 27762306a36Sopenharmony_ci#undef DIE 27862306a36Sopenharmony_ci#undef DIE_NO 27962306a36Sopenharmony_ci 28062306a36Sopenharmony_ci&aic { 28162306a36Sopenharmony_ci affinities { 28262306a36Sopenharmony_ci e-core-pmu-affinity { 28362306a36Sopenharmony_ci apple,fiq-index = <AIC_CPU_PMU_E>; 28462306a36Sopenharmony_ci cpus = <&cpu_e00 &cpu_e01 28562306a36Sopenharmony_ci &cpu_e10 &cpu_e11>; 28662306a36Sopenharmony_ci }; 28762306a36Sopenharmony_ci 28862306a36Sopenharmony_ci p-core-pmu-affinity { 28962306a36Sopenharmony_ci apple,fiq-index = <AIC_CPU_PMU_P>; 29062306a36Sopenharmony_ci cpus = <&cpu_p00 &cpu_p01 &cpu_p02 &cpu_p03 29162306a36Sopenharmony_ci &cpu_p10 &cpu_p11 &cpu_p12 &cpu_p13 29262306a36Sopenharmony_ci &cpu_p20 &cpu_p21 &cpu_p22 &cpu_p23 29362306a36Sopenharmony_ci &cpu_p30 &cpu_p31 &cpu_p32 &cpu_p33>; 29462306a36Sopenharmony_ci }; 29562306a36Sopenharmony_ci }; 29662306a36Sopenharmony_ci}; 29762306a36Sopenharmony_ci 29862306a36Sopenharmony_ci&ps_gfx { 29962306a36Sopenharmony_ci // On t6002, the die0 GPU power domain needs both AFR power domains 30062306a36Sopenharmony_ci power-domains = <&ps_afr>, <&ps_afr_die1>; 30162306a36Sopenharmony_ci}; 302