162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * Device Tree Source for J721S2 SoC Family 462306a36Sopenharmony_ci * 562306a36Sopenharmony_ci * TRM (SPRUJ28 NOVEMBER 2021): https://www.ti.com/lit/pdf/spruj28 662306a36Sopenharmony_ci * 762306a36Sopenharmony_ci * Copyright (C) 2021 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 1962306a36Sopenharmony_ci model = "Texas Instruments K3 J721S2 SoC"; 2062306a36Sopenharmony_ci compatible = "ti,j721s2"; 2162306a36Sopenharmony_ci interrupt-parent = <&gic500>; 2262306a36Sopenharmony_ci #address-cells = <2>; 2362306a36Sopenharmony_ci #size-cells = <2>; 2462306a36Sopenharmony_ci 2562306a36Sopenharmony_ci chosen { }; 2662306a36Sopenharmony_ci 2762306a36Sopenharmony_ci cpus { 2862306a36Sopenharmony_ci #address-cells = <1>; 2962306a36Sopenharmony_ci #size-cells = <0>; 3062306a36Sopenharmony_ci cpu-map { 3162306a36Sopenharmony_ci cluster0: cluster0 { 3262306a36Sopenharmony_ci core0 { 3362306a36Sopenharmony_ci cpu = <&cpu0>; 3462306a36Sopenharmony_ci }; 3562306a36Sopenharmony_ci 3662306a36Sopenharmony_ci core1 { 3762306a36Sopenharmony_ci cpu = <&cpu1>; 3862306a36Sopenharmony_ci }; 3962306a36Sopenharmony_ci }; 4062306a36Sopenharmony_ci }; 4162306a36Sopenharmony_ci 4262306a36Sopenharmony_ci cpu0: cpu@0 { 4362306a36Sopenharmony_ci compatible = "arm,cortex-a72"; 4462306a36Sopenharmony_ci reg = <0x000>; 4562306a36Sopenharmony_ci device_type = "cpu"; 4662306a36Sopenharmony_ci enable-method = "psci"; 4762306a36Sopenharmony_ci i-cache-size = <0xc000>; 4862306a36Sopenharmony_ci i-cache-line-size = <64>; 4962306a36Sopenharmony_ci i-cache-sets = <256>; 5062306a36Sopenharmony_ci d-cache-size = <0x8000>; 5162306a36Sopenharmony_ci d-cache-line-size = <64>; 5262306a36Sopenharmony_ci d-cache-sets = <256>; 5362306a36Sopenharmony_ci next-level-cache = <&L2_0>; 5462306a36Sopenharmony_ci }; 5562306a36Sopenharmony_ci 5662306a36Sopenharmony_ci cpu1: cpu@1 { 5762306a36Sopenharmony_ci compatible = "arm,cortex-a72"; 5862306a36Sopenharmony_ci reg = <0x001>; 5962306a36Sopenharmony_ci device_type = "cpu"; 6062306a36Sopenharmony_ci enable-method = "psci"; 6162306a36Sopenharmony_ci i-cache-size = <0xc000>; 6262306a36Sopenharmony_ci i-cache-line-size = <64>; 6362306a36Sopenharmony_ci i-cache-sets = <256>; 6462306a36Sopenharmony_ci d-cache-size = <0x8000>; 6562306a36Sopenharmony_ci d-cache-line-size = <64>; 6662306a36Sopenharmony_ci d-cache-sets = <256>; 6762306a36Sopenharmony_ci next-level-cache = <&L2_0>; 6862306a36Sopenharmony_ci }; 6962306a36Sopenharmony_ci }; 7062306a36Sopenharmony_ci 7162306a36Sopenharmony_ci L2_0: l2-cache0 { 7262306a36Sopenharmony_ci compatible = "cache"; 7362306a36Sopenharmony_ci cache-unified; 7462306a36Sopenharmony_ci cache-level = <2>; 7562306a36Sopenharmony_ci cache-size = <0x100000>; 7662306a36Sopenharmony_ci cache-line-size = <64>; 7762306a36Sopenharmony_ci cache-sets = <1024>; 7862306a36Sopenharmony_ci next-level-cache = <&msmc_l3>; 7962306a36Sopenharmony_ci }; 8062306a36Sopenharmony_ci 8162306a36Sopenharmony_ci msmc_l3: l3-cache0 { 8262306a36Sopenharmony_ci compatible = "cache"; 8362306a36Sopenharmony_ci cache-level = <3>; 8462306a36Sopenharmony_ci cache-unified; 8562306a36Sopenharmony_ci }; 8662306a36Sopenharmony_ci 8762306a36Sopenharmony_ci firmware { 8862306a36Sopenharmony_ci optee { 8962306a36Sopenharmony_ci compatible = "linaro,optee-tz"; 9062306a36Sopenharmony_ci method = "smc"; 9162306a36Sopenharmony_ci }; 9262306a36Sopenharmony_ci 9362306a36Sopenharmony_ci psci: psci { 9462306a36Sopenharmony_ci compatible = "arm,psci-1.0"; 9562306a36Sopenharmony_ci method = "smc"; 9662306a36Sopenharmony_ci }; 9762306a36Sopenharmony_ci }; 9862306a36Sopenharmony_ci 9962306a36Sopenharmony_ci a72_timer0: timer-cl0-cpu0 { 10062306a36Sopenharmony_ci compatible = "arm,armv8-timer"; 10162306a36Sopenharmony_ci interrupts = <GIC_PPI 13 IRQ_TYPE_LEVEL_LOW>, /* cntpsirq */ 10262306a36Sopenharmony_ci <GIC_PPI 14 IRQ_TYPE_LEVEL_LOW>, /* cntpnsirq */ 10362306a36Sopenharmony_ci <GIC_PPI 11 IRQ_TYPE_LEVEL_LOW>, /* cntvirq */ 10462306a36Sopenharmony_ci <GIC_PPI 10 IRQ_TYPE_LEVEL_LOW>; /* cnthpirq */ 10562306a36Sopenharmony_ci 10662306a36Sopenharmony_ci }; 10762306a36Sopenharmony_ci 10862306a36Sopenharmony_ci pmu: pmu { 10962306a36Sopenharmony_ci compatible = "arm,cortex-a72-pmu"; 11062306a36Sopenharmony_ci /* Recommendation from GIC500 TRM Table A.3 */ 11162306a36Sopenharmony_ci interrupts = <GIC_PPI 7 IRQ_TYPE_LEVEL_HIGH>; 11262306a36Sopenharmony_ci }; 11362306a36Sopenharmony_ci 11462306a36Sopenharmony_ci cbass_main: bus@100000 { 11562306a36Sopenharmony_ci compatible = "simple-bus"; 11662306a36Sopenharmony_ci #address-cells = <2>; 11762306a36Sopenharmony_ci #size-cells = <2>; 11862306a36Sopenharmony_ci ranges = <0x00 0x00100000 0x00 0x00100000 0x00 0x00020000>, /* ctrl mmr */ 11962306a36Sopenharmony_ci <0x00 0x00600000 0x00 0x00600000 0x00 0x00031100>, /* GPIO */ 12062306a36Sopenharmony_ci <0x00 0x01000000 0x00 0x01000000 0x00 0x0d000000>, /* Most peripherals */ 12162306a36Sopenharmony_ci <0x00 0x0d800000 0x00 0x0d800000 0x00 0x00800000>, /* PCIe Core*/ 12262306a36Sopenharmony_ci <0x00 0x18000000 0x00 0x18000000 0x00 0x08000000>, /* PCIe1 DAT0 */ 12362306a36Sopenharmony_ci <0x00 0x64800000 0x00 0x64800000 0x00 0x0070c000>, /* C71_1 */ 12462306a36Sopenharmony_ci <0x00 0x65800000 0x00 0x65800000 0x00 0x0070c000>, /* C71_2 */ 12562306a36Sopenharmony_ci <0x00 0x6f000000 0x00 0x6f000000 0x00 0x00310000>, /* A72 PERIPHBASE */ 12662306a36Sopenharmony_ci <0x00 0x70000000 0x00 0x70000000 0x00 0x00400000>, /* MSMC RAM */ 12762306a36Sopenharmony_ci <0x00 0x30000000 0x00 0x30000000 0x00 0x0c400000>, /* MAIN NAVSS */ 12862306a36Sopenharmony_ci <0x41 0x00000000 0x41 0x00000000 0x01 0x00000000>, /* PCIe1 DAT1 */ 12962306a36Sopenharmony_ci <0x4e 0x20000000 0x4e 0x20000000 0x00 0x00080000>, /* GPU */ 13062306a36Sopenharmony_ci 13162306a36Sopenharmony_ci /* MCUSS_WKUP Range */ 13262306a36Sopenharmony_ci <0x00 0x28380000 0x00 0x28380000 0x00 0x03880000>, 13362306a36Sopenharmony_ci <0x00 0x40200000 0x00 0x40200000 0x00 0x00998400>, 13462306a36Sopenharmony_ci <0x00 0x40f00000 0x00 0x40f00000 0x00 0x00020000>, 13562306a36Sopenharmony_ci <0x00 0x41000000 0x00 0x41000000 0x00 0x00020000>, 13662306a36Sopenharmony_ci <0x00 0x41400000 0x00 0x41400000 0x00 0x00020000>, 13762306a36Sopenharmony_ci <0x00 0x41c00000 0x00 0x41c00000 0x00 0x00100000>, 13862306a36Sopenharmony_ci <0x00 0x42040000 0x00 0x42040000 0x00 0x03ac2400>, 13962306a36Sopenharmony_ci <0x00 0x45100000 0x00 0x45100000 0x00 0x00c24000>, 14062306a36Sopenharmony_ci <0x00 0x46000000 0x00 0x46000000 0x00 0x00200000>, 14162306a36Sopenharmony_ci <0x00 0x47000000 0x00 0x47000000 0x00 0x00068400>, 14262306a36Sopenharmony_ci <0x00 0x50000000 0x00 0x50000000 0x00 0x10000000>, 14362306a36Sopenharmony_ci <0x05 0x00000000 0x05 0x00000000 0x01 0x00000000>, 14462306a36Sopenharmony_ci <0x07 0x00000000 0x07 0x00000000 0x01 0x00000000>; 14562306a36Sopenharmony_ci 14662306a36Sopenharmony_ci cbass_mcu_wakeup: bus@28380000 { 14762306a36Sopenharmony_ci compatible = "simple-bus"; 14862306a36Sopenharmony_ci #address-cells = <2>; 14962306a36Sopenharmony_ci #size-cells = <2>; 15062306a36Sopenharmony_ci ranges = <0x00 0x28380000 0x00 0x28380000 0x00 0x03880000>, /* MCU NAVSS*/ 15162306a36Sopenharmony_ci <0x00 0x40200000 0x00 0x40200000 0x00 0x00998400>, /* First peripheral window */ 15262306a36Sopenharmony_ci <0x00 0x40f00000 0x00 0x40f00000 0x00 0x00020000>, /* CTRL_MMR0 */ 15362306a36Sopenharmony_ci <0x00 0x41000000 0x00 0x41000000 0x00 0x00020000>, /* MCU R5F Core0 */ 15462306a36Sopenharmony_ci <0x00 0x41400000 0x00 0x41400000 0x00 0x00020000>, /* MCU R5F Core1 */ 15562306a36Sopenharmony_ci <0x00 0x41c00000 0x00 0x41c00000 0x00 0x00100000>, /* MCU SRAM */ 15662306a36Sopenharmony_ci <0x00 0x42040000 0x00 0x42040000 0x00 0x03ac2400>, /* WKUP peripheral window */ 15762306a36Sopenharmony_ci <0x00 0x45100000 0x00 0x45100000 0x00 0x00c24000>, /* MMRs, remaining NAVSS */ 15862306a36Sopenharmony_ci <0x00 0x46000000 0x00 0x46000000 0x00 0x00200000>, /* CPSW */ 15962306a36Sopenharmony_ci <0x00 0x47000000 0x00 0x47000000 0x00 0x00068400>, /* OSPI register space */ 16062306a36Sopenharmony_ci <0x00 0x50000000 0x00 0x50000000 0x00 0x10000000>, /* FSS OSPI0/1 data region 0 */ 16162306a36Sopenharmony_ci <0x05 0x00000000 0x05 0x00000000 0x01 0x00000000>, /* FSS OSPI0 data region 3 */ 16262306a36Sopenharmony_ci <0x07 0x00000000 0x07 0x00000000 0x01 0x00000000>; /* FSS OSPI1 data region 3*/ 16362306a36Sopenharmony_ci 16462306a36Sopenharmony_ci }; 16562306a36Sopenharmony_ci 16662306a36Sopenharmony_ci }; 16762306a36Sopenharmony_ci 16862306a36Sopenharmony_ci thermal_zones: thermal-zones { 16962306a36Sopenharmony_ci #include "k3-j721s2-thermal.dtsi" 17062306a36Sopenharmony_ci }; 17162306a36Sopenharmony_ci}; 17262306a36Sopenharmony_ci 17362306a36Sopenharmony_ci/* Now include peripherals from each bus segment */ 17462306a36Sopenharmony_ci#include "k3-j721s2-main.dtsi" 17562306a36Sopenharmony_ci#include "k3-j721s2-mcu-wakeup.dtsi" 176