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