162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * Device Tree Source for J784S4 SoC Family 462306a36Sopenharmony_ci * 562306a36Sopenharmony_ci * TRM (SPRUJ43 JULY 2022): https://www.ti.com/lit/zip/spruj52 662306a36Sopenharmony_ci * 762306a36Sopenharmony_ci * Copyright (C) 2022 Texas Instruments Incorporated - https://www.ti.com/ 862306a36Sopenharmony_ci * 962306a36Sopenharmony_ci */ 1062306a36Sopenharmony_ci 1162306a36Sopenharmony_ci#include <dt-bindings/interrupt-controller/irq.h> 1262306a36Sopenharmony_ci#include <dt-bindings/interrupt-controller/arm-gic.h> 1362306a36Sopenharmony_ci#include <dt-bindings/soc/ti,sci_pm_domain.h> 1462306a36Sopenharmony_ci 1562306a36Sopenharmony_ci#include "k3-pinctrl.h" 1662306a36Sopenharmony_ci 1762306a36Sopenharmony_ci/ { 1862306a36Sopenharmony_ci model = "Texas Instruments K3 J784S4 SoC"; 1962306a36Sopenharmony_ci compatible = "ti,j784s4"; 2062306a36Sopenharmony_ci interrupt-parent = <&gic500>; 2162306a36Sopenharmony_ci #address-cells = <2>; 2262306a36Sopenharmony_ci #size-cells = <2>; 2362306a36Sopenharmony_ci 2462306a36Sopenharmony_ci cpus { 2562306a36Sopenharmony_ci #address-cells = <1>; 2662306a36Sopenharmony_ci #size-cells = <0>; 2762306a36Sopenharmony_ci cpu-map { 2862306a36Sopenharmony_ci cluster0: cluster0 { 2962306a36Sopenharmony_ci core0 { 3062306a36Sopenharmony_ci cpu = <&cpu0>; 3162306a36Sopenharmony_ci }; 3262306a36Sopenharmony_ci 3362306a36Sopenharmony_ci core1 { 3462306a36Sopenharmony_ci cpu = <&cpu1>; 3562306a36Sopenharmony_ci }; 3662306a36Sopenharmony_ci 3762306a36Sopenharmony_ci core2 { 3862306a36Sopenharmony_ci cpu = <&cpu2>; 3962306a36Sopenharmony_ci }; 4062306a36Sopenharmony_ci 4162306a36Sopenharmony_ci core3 { 4262306a36Sopenharmony_ci cpu = <&cpu3>; 4362306a36Sopenharmony_ci }; 4462306a36Sopenharmony_ci }; 4562306a36Sopenharmony_ci 4662306a36Sopenharmony_ci cluster1: cluster1 { 4762306a36Sopenharmony_ci core0 { 4862306a36Sopenharmony_ci cpu = <&cpu4>; 4962306a36Sopenharmony_ci }; 5062306a36Sopenharmony_ci 5162306a36Sopenharmony_ci core1 { 5262306a36Sopenharmony_ci cpu = <&cpu5>; 5362306a36Sopenharmony_ci }; 5462306a36Sopenharmony_ci 5562306a36Sopenharmony_ci core2 { 5662306a36Sopenharmony_ci cpu = <&cpu6>; 5762306a36Sopenharmony_ci }; 5862306a36Sopenharmony_ci 5962306a36Sopenharmony_ci core3 { 6062306a36Sopenharmony_ci cpu = <&cpu7>; 6162306a36Sopenharmony_ci }; 6262306a36Sopenharmony_ci }; 6362306a36Sopenharmony_ci }; 6462306a36Sopenharmony_ci 6562306a36Sopenharmony_ci cpu0: cpu@0 { 6662306a36Sopenharmony_ci compatible = "arm,cortex-a72"; 6762306a36Sopenharmony_ci reg = <0x000>; 6862306a36Sopenharmony_ci device_type = "cpu"; 6962306a36Sopenharmony_ci enable-method = "psci"; 7062306a36Sopenharmony_ci i-cache-size = <0xc000>; 7162306a36Sopenharmony_ci i-cache-line-size = <64>; 7262306a36Sopenharmony_ci i-cache-sets = <256>; 7362306a36Sopenharmony_ci d-cache-size = <0x8000>; 7462306a36Sopenharmony_ci d-cache-line-size = <64>; 7562306a36Sopenharmony_ci d-cache-sets = <256>; 7662306a36Sopenharmony_ci next-level-cache = <&L2_0>; 7762306a36Sopenharmony_ci }; 7862306a36Sopenharmony_ci 7962306a36Sopenharmony_ci cpu1: cpu@1 { 8062306a36Sopenharmony_ci compatible = "arm,cortex-a72"; 8162306a36Sopenharmony_ci reg = <0x001>; 8262306a36Sopenharmony_ci device_type = "cpu"; 8362306a36Sopenharmony_ci enable-method = "psci"; 8462306a36Sopenharmony_ci i-cache-size = <0xc000>; 8562306a36Sopenharmony_ci i-cache-line-size = <64>; 8662306a36Sopenharmony_ci i-cache-sets = <256>; 8762306a36Sopenharmony_ci d-cache-size = <0x8000>; 8862306a36Sopenharmony_ci d-cache-line-size = <64>; 8962306a36Sopenharmony_ci d-cache-sets = <256>; 9062306a36Sopenharmony_ci next-level-cache = <&L2_0>; 9162306a36Sopenharmony_ci }; 9262306a36Sopenharmony_ci 9362306a36Sopenharmony_ci cpu2: cpu@2 { 9462306a36Sopenharmony_ci compatible = "arm,cortex-a72"; 9562306a36Sopenharmony_ci reg = <0x002>; 9662306a36Sopenharmony_ci device_type = "cpu"; 9762306a36Sopenharmony_ci enable-method = "psci"; 9862306a36Sopenharmony_ci i-cache-size = <0xc000>; 9962306a36Sopenharmony_ci i-cache-line-size = <64>; 10062306a36Sopenharmony_ci i-cache-sets = <256>; 10162306a36Sopenharmony_ci d-cache-size = <0x8000>; 10262306a36Sopenharmony_ci d-cache-line-size = <64>; 10362306a36Sopenharmony_ci d-cache-sets = <256>; 10462306a36Sopenharmony_ci next-level-cache = <&L2_0>; 10562306a36Sopenharmony_ci }; 10662306a36Sopenharmony_ci 10762306a36Sopenharmony_ci cpu3: cpu@3 { 10862306a36Sopenharmony_ci compatible = "arm,cortex-a72"; 10962306a36Sopenharmony_ci reg = <0x003>; 11062306a36Sopenharmony_ci device_type = "cpu"; 11162306a36Sopenharmony_ci enable-method = "psci"; 11262306a36Sopenharmony_ci i-cache-size = <0xc000>; 11362306a36Sopenharmony_ci i-cache-line-size = <64>; 11462306a36Sopenharmony_ci i-cache-sets = <256>; 11562306a36Sopenharmony_ci d-cache-size = <0x8000>; 11662306a36Sopenharmony_ci d-cache-line-size = <64>; 11762306a36Sopenharmony_ci d-cache-sets = <256>; 11862306a36Sopenharmony_ci next-level-cache = <&L2_0>; 11962306a36Sopenharmony_ci }; 12062306a36Sopenharmony_ci 12162306a36Sopenharmony_ci cpu4: cpu@100 { 12262306a36Sopenharmony_ci compatible = "arm,cortex-a72"; 12362306a36Sopenharmony_ci reg = <0x100>; 12462306a36Sopenharmony_ci device_type = "cpu"; 12562306a36Sopenharmony_ci enable-method = "psci"; 12662306a36Sopenharmony_ci i-cache-size = <0xc000>; 12762306a36Sopenharmony_ci i-cache-line-size = <64>; 12862306a36Sopenharmony_ci i-cache-sets = <256>; 12962306a36Sopenharmony_ci d-cache-size = <0x8000>; 13062306a36Sopenharmony_ci d-cache-line-size = <64>; 13162306a36Sopenharmony_ci d-cache-sets = <256>; 13262306a36Sopenharmony_ci next-level-cache = <&L2_1>; 13362306a36Sopenharmony_ci }; 13462306a36Sopenharmony_ci 13562306a36Sopenharmony_ci cpu5: cpu@101 { 13662306a36Sopenharmony_ci compatible = "arm,cortex-a72"; 13762306a36Sopenharmony_ci reg = <0x101>; 13862306a36Sopenharmony_ci device_type = "cpu"; 13962306a36Sopenharmony_ci enable-method = "psci"; 14062306a36Sopenharmony_ci i-cache-size = <0xc000>; 14162306a36Sopenharmony_ci i-cache-line-size = <64>; 14262306a36Sopenharmony_ci i-cache-sets = <256>; 14362306a36Sopenharmony_ci d-cache-size = <0x8000>; 14462306a36Sopenharmony_ci d-cache-line-size = <64>; 14562306a36Sopenharmony_ci d-cache-sets = <256>; 14662306a36Sopenharmony_ci next-level-cache = <&L2_1>; 14762306a36Sopenharmony_ci }; 14862306a36Sopenharmony_ci 14962306a36Sopenharmony_ci cpu6: cpu@102 { 15062306a36Sopenharmony_ci compatible = "arm,cortex-a72"; 15162306a36Sopenharmony_ci reg = <0x102>; 15262306a36Sopenharmony_ci device_type = "cpu"; 15362306a36Sopenharmony_ci enable-method = "psci"; 15462306a36Sopenharmony_ci i-cache-size = <0xc000>; 15562306a36Sopenharmony_ci i-cache-line-size = <64>; 15662306a36Sopenharmony_ci i-cache-sets = <256>; 15762306a36Sopenharmony_ci d-cache-size = <0x8000>; 15862306a36Sopenharmony_ci d-cache-line-size = <64>; 15962306a36Sopenharmony_ci d-cache-sets = <256>; 16062306a36Sopenharmony_ci next-level-cache = <&L2_1>; 16162306a36Sopenharmony_ci }; 16262306a36Sopenharmony_ci 16362306a36Sopenharmony_ci cpu7: cpu@103 { 16462306a36Sopenharmony_ci compatible = "arm,cortex-a72"; 16562306a36Sopenharmony_ci reg = <0x103>; 16662306a36Sopenharmony_ci device_type = "cpu"; 16762306a36Sopenharmony_ci enable-method = "psci"; 16862306a36Sopenharmony_ci i-cache-size = <0xc000>; 16962306a36Sopenharmony_ci i-cache-line-size = <64>; 17062306a36Sopenharmony_ci i-cache-sets = <256>; 17162306a36Sopenharmony_ci d-cache-size = <0x8000>; 17262306a36Sopenharmony_ci d-cache-line-size = <64>; 17362306a36Sopenharmony_ci d-cache-sets = <256>; 17462306a36Sopenharmony_ci next-level-cache = <&L2_1>; 17562306a36Sopenharmony_ci }; 17662306a36Sopenharmony_ci }; 17762306a36Sopenharmony_ci 17862306a36Sopenharmony_ci L2_0: l2-cache0 { 17962306a36Sopenharmony_ci compatible = "cache"; 18062306a36Sopenharmony_ci cache-level = <2>; 18162306a36Sopenharmony_ci cache-unified; 18262306a36Sopenharmony_ci cache-size = <0x200000>; 18362306a36Sopenharmony_ci cache-line-size = <64>; 18462306a36Sopenharmony_ci cache-sets = <1024>; 18562306a36Sopenharmony_ci next-level-cache = <&msmc_l3>; 18662306a36Sopenharmony_ci }; 18762306a36Sopenharmony_ci 18862306a36Sopenharmony_ci L2_1: l2-cache1 { 18962306a36Sopenharmony_ci compatible = "cache"; 19062306a36Sopenharmony_ci cache-level = <2>; 19162306a36Sopenharmony_ci cache-unified; 19262306a36Sopenharmony_ci cache-size = <0x200000>; 19362306a36Sopenharmony_ci cache-line-size = <64>; 19462306a36Sopenharmony_ci cache-sets = <1024>; 19562306a36Sopenharmony_ci next-level-cache = <&msmc_l3>; 19662306a36Sopenharmony_ci }; 19762306a36Sopenharmony_ci 19862306a36Sopenharmony_ci msmc_l3: l3-cache0 { 19962306a36Sopenharmony_ci compatible = "cache"; 20062306a36Sopenharmony_ci cache-level = <3>; 20162306a36Sopenharmony_ci cache-unified; 20262306a36Sopenharmony_ci }; 20362306a36Sopenharmony_ci 20462306a36Sopenharmony_ci firmware { 20562306a36Sopenharmony_ci optee { 20662306a36Sopenharmony_ci compatible = "linaro,optee-tz"; 20762306a36Sopenharmony_ci method = "smc"; 20862306a36Sopenharmony_ci }; 20962306a36Sopenharmony_ci 21062306a36Sopenharmony_ci psci: psci { 21162306a36Sopenharmony_ci compatible = "arm,psci-1.0"; 21262306a36Sopenharmony_ci method = "smc"; 21362306a36Sopenharmony_ci }; 21462306a36Sopenharmony_ci }; 21562306a36Sopenharmony_ci 21662306a36Sopenharmony_ci a72_timer0: timer-cl0-cpu0 { 21762306a36Sopenharmony_ci compatible = "arm,armv8-timer"; 21862306a36Sopenharmony_ci interrupts = <GIC_PPI 13 IRQ_TYPE_LEVEL_LOW>, /* cntpsirq */ 21962306a36Sopenharmony_ci <GIC_PPI 14 IRQ_TYPE_LEVEL_LOW>, /* cntpnsirq */ 22062306a36Sopenharmony_ci <GIC_PPI 11 IRQ_TYPE_LEVEL_LOW>, /* cntvirq */ 22162306a36Sopenharmony_ci <GIC_PPI 10 IRQ_TYPE_LEVEL_LOW>; /* cnthpirq */ 22262306a36Sopenharmony_ci }; 22362306a36Sopenharmony_ci 22462306a36Sopenharmony_ci pmu: pmu { 22562306a36Sopenharmony_ci compatible = "arm,cortex-a72-pmu"; 22662306a36Sopenharmony_ci /* Recommendation from GIC500 TRM Table A.3 */ 22762306a36Sopenharmony_ci interrupts = <GIC_PPI 7 IRQ_TYPE_LEVEL_HIGH>; 22862306a36Sopenharmony_ci }; 22962306a36Sopenharmony_ci 23062306a36Sopenharmony_ci cbass_main: bus@100000 { 23162306a36Sopenharmony_ci bootph-all; 23262306a36Sopenharmony_ci compatible = "simple-bus"; 23362306a36Sopenharmony_ci #address-cells = <2>; 23462306a36Sopenharmony_ci #size-cells = <2>; 23562306a36Sopenharmony_ci ranges = <0x00 0x00100000 0x00 0x00100000 0x00 0x00020000>, /* ctrl mmr */ 23662306a36Sopenharmony_ci <0x00 0x00600000 0x00 0x00600000 0x00 0x00031100>, /* GPIO */ 23762306a36Sopenharmony_ci <0x00 0x01000000 0x00 0x01000000 0x00 0x0d000000>, /* Most peripherals */ 23862306a36Sopenharmony_ci <0x00 0x0d000000 0x00 0x0d000000 0x00 0x01000000>, /* PCIe Core*/ 23962306a36Sopenharmony_ci <0x00 0x10000000 0x00 0x10000000 0x00 0x08000000>, /* PCIe0 DAT0 */ 24062306a36Sopenharmony_ci <0x00 0x18000000 0x00 0x18000000 0x00 0x08000000>, /* PCIe1 DAT0 */ 24162306a36Sopenharmony_ci <0x00 0x64800000 0x00 0x64800000 0x00 0x0070c000>, /* C71_1 */ 24262306a36Sopenharmony_ci <0x00 0x65800000 0x00 0x65800000 0x00 0x0070c000>, /* C71_2 */ 24362306a36Sopenharmony_ci <0x00 0x66800000 0x00 0x66800000 0x00 0x0070c000>, /* C71_3 */ 24462306a36Sopenharmony_ci <0x00 0x67800000 0x00 0x67800000 0x00 0x0070c000>, /* C71_4 */ 24562306a36Sopenharmony_ci <0x00 0x6f000000 0x00 0x6f000000 0x00 0x00310000>, /* A72 PERIPHBASE */ 24662306a36Sopenharmony_ci <0x00 0x70000000 0x00 0x70000000 0x00 0x00400000>, /* MSMC RAM */ 24762306a36Sopenharmony_ci <0x00 0x30000000 0x00 0x30000000 0x00 0x0c400000>, /* MAIN NAVSS */ 24862306a36Sopenharmony_ci <0x41 0x00000000 0x41 0x00000000 0x01 0x00000000>, /* PCIe1 DAT1 */ 24962306a36Sopenharmony_ci <0x4e 0x20000000 0x4e 0x20000000 0x00 0x00080000>, /* GPU */ 25062306a36Sopenharmony_ci 25162306a36Sopenharmony_ci /* MCUSS_WKUP Range */ 25262306a36Sopenharmony_ci <0x00 0x28380000 0x00 0x28380000 0x00 0x03880000>, 25362306a36Sopenharmony_ci <0x00 0x40200000 0x00 0x40200000 0x00 0x00998400>, 25462306a36Sopenharmony_ci <0x00 0x40f00000 0x00 0x40f00000 0x00 0x00020000>, 25562306a36Sopenharmony_ci <0x00 0x41000000 0x00 0x41000000 0x00 0x00020000>, 25662306a36Sopenharmony_ci <0x00 0x41400000 0x00 0x41400000 0x00 0x00020000>, 25762306a36Sopenharmony_ci <0x00 0x41c00000 0x00 0x41c00000 0x00 0x00100000>, 25862306a36Sopenharmony_ci <0x00 0x42040000 0x00 0x42040000 0x00 0x03ac2400>, 25962306a36Sopenharmony_ci <0x00 0x45100000 0x00 0x45100000 0x00 0x00c24000>, 26062306a36Sopenharmony_ci <0x00 0x46000000 0x00 0x46000000 0x00 0x00200000>, 26162306a36Sopenharmony_ci <0x00 0x47000000 0x00 0x47000000 0x00 0x00068400>, 26262306a36Sopenharmony_ci <0x00 0x50000000 0x00 0x50000000 0x00 0x10000000>, 26362306a36Sopenharmony_ci <0x05 0x00000000 0x05 0x00000000 0x01 0x00000000>, 26462306a36Sopenharmony_ci <0x07 0x00000000 0x07 0x00000000 0x01 0x00000000>; 26562306a36Sopenharmony_ci 26662306a36Sopenharmony_ci cbass_mcu_wakeup: bus@28380000 { 26762306a36Sopenharmony_ci bootph-all; 26862306a36Sopenharmony_ci compatible = "simple-bus"; 26962306a36Sopenharmony_ci #address-cells = <2>; 27062306a36Sopenharmony_ci #size-cells = <2>; 27162306a36Sopenharmony_ci ranges = <0x00 0x28380000 0x00 0x28380000 0x00 0x03880000>, /* MCU NAVSS*/ 27262306a36Sopenharmony_ci <0x00 0x40200000 0x00 0x40200000 0x00 0x00998400>, /* First peripheral window */ 27362306a36Sopenharmony_ci <0x00 0x40f00000 0x00 0x40f00000 0x00 0x00020000>, /* CTRL_MMR0 */ 27462306a36Sopenharmony_ci <0x00 0x41000000 0x00 0x41000000 0x00 0x00020000>, /* MCU R5F Core0 */ 27562306a36Sopenharmony_ci <0x00 0x41400000 0x00 0x41400000 0x00 0x00020000>, /* MCU R5F Core1 */ 27662306a36Sopenharmony_ci <0x00 0x41c00000 0x00 0x41c00000 0x00 0x00100000>, /* MCU SRAM */ 27762306a36Sopenharmony_ci <0x00 0x42040000 0x00 0x42040000 0x00 0x03ac2400>, /* WKUP peripheral window */ 27862306a36Sopenharmony_ci <0x00 0x45100000 0x00 0x45100000 0x00 0x00c24000>, /* MMRs, remaining NAVSS */ 27962306a36Sopenharmony_ci <0x00 0x46000000 0x00 0x46000000 0x00 0x00200000>, /* CPSW */ 28062306a36Sopenharmony_ci <0x00 0x47000000 0x00 0x47000000 0x00 0x00068400>, /* OSPI register space */ 28162306a36Sopenharmony_ci <0x00 0x50000000 0x00 0x50000000 0x00 0x10000000>, /* FSS OSPI0/1 data region 0 */ 28262306a36Sopenharmony_ci <0x05 0x00000000 0x05 0x00000000 0x01 0x00000000>, /* FSS OSPI0 data region 3 */ 28362306a36Sopenharmony_ci <0x07 0x00000000 0x07 0x00000000 0x01 0x00000000>; /* FSS OSPI1 data region 3*/ 28462306a36Sopenharmony_ci }; 28562306a36Sopenharmony_ci }; 28662306a36Sopenharmony_ci 28762306a36Sopenharmony_ci thermal_zones: thermal-zones { 28862306a36Sopenharmony_ci #include "k3-j784s4-thermal.dtsi" 28962306a36Sopenharmony_ci }; 29062306a36Sopenharmony_ci}; 29162306a36Sopenharmony_ci 29262306a36Sopenharmony_ci/* Now include peripherals from each bus segment */ 29362306a36Sopenharmony_ci#include "k3-j784s4-main.dtsi" 29462306a36Sopenharmony_ci#include "k3-j784s4-mcu-wakeup.dtsi" 295