1*4882a593Smuzhiyun/* 2*4882a593Smuzhiyun * ARM Ltd. Juno Platform 3*4882a593Smuzhiyun * 4*4882a593Smuzhiyun * Copyright (c) 2013-2014 ARM Ltd. 5*4882a593Smuzhiyun * 6*4882a593Smuzhiyun * This file is licensed under a dual GPLv2 or BSD license. 7*4882a593Smuzhiyun */ 8*4882a593Smuzhiyun 9*4882a593Smuzhiyun/dts-v1/; 10*4882a593Smuzhiyun 11*4882a593Smuzhiyun#include <dt-bindings/interrupt-controller/arm-gic.h> 12*4882a593Smuzhiyun#include "juno-base.dtsi" 13*4882a593Smuzhiyun 14*4882a593Smuzhiyun/ { 15*4882a593Smuzhiyun model = "ARM Juno development board (r0)"; 16*4882a593Smuzhiyun compatible = "arm,juno", "arm,vexpress"; 17*4882a593Smuzhiyun interrupt-parent = <&gic>; 18*4882a593Smuzhiyun #address-cells = <2>; 19*4882a593Smuzhiyun #size-cells = <2>; 20*4882a593Smuzhiyun 21*4882a593Smuzhiyun aliases { 22*4882a593Smuzhiyun serial0 = &soc_uart0; 23*4882a593Smuzhiyun }; 24*4882a593Smuzhiyun 25*4882a593Smuzhiyun chosen { 26*4882a593Smuzhiyun stdout-path = "serial0:115200n8"; 27*4882a593Smuzhiyun }; 28*4882a593Smuzhiyun 29*4882a593Smuzhiyun psci { 30*4882a593Smuzhiyun compatible = "arm,psci-0.2"; 31*4882a593Smuzhiyun method = "smc"; 32*4882a593Smuzhiyun }; 33*4882a593Smuzhiyun 34*4882a593Smuzhiyun cpus { 35*4882a593Smuzhiyun #address-cells = <2>; 36*4882a593Smuzhiyun #size-cells = <0>; 37*4882a593Smuzhiyun 38*4882a593Smuzhiyun cpu-map { 39*4882a593Smuzhiyun cluster0 { 40*4882a593Smuzhiyun core0 { 41*4882a593Smuzhiyun cpu = <&A57_0>; 42*4882a593Smuzhiyun }; 43*4882a593Smuzhiyun core1 { 44*4882a593Smuzhiyun cpu = <&A57_1>; 45*4882a593Smuzhiyun }; 46*4882a593Smuzhiyun }; 47*4882a593Smuzhiyun 48*4882a593Smuzhiyun cluster1 { 49*4882a593Smuzhiyun core0 { 50*4882a593Smuzhiyun cpu = <&A53_0>; 51*4882a593Smuzhiyun }; 52*4882a593Smuzhiyun core1 { 53*4882a593Smuzhiyun cpu = <&A53_1>; 54*4882a593Smuzhiyun }; 55*4882a593Smuzhiyun core2 { 56*4882a593Smuzhiyun cpu = <&A53_2>; 57*4882a593Smuzhiyun }; 58*4882a593Smuzhiyun core3 { 59*4882a593Smuzhiyun cpu = <&A53_3>; 60*4882a593Smuzhiyun }; 61*4882a593Smuzhiyun }; 62*4882a593Smuzhiyun }; 63*4882a593Smuzhiyun 64*4882a593Smuzhiyun idle-states { 65*4882a593Smuzhiyun entry-method = "psci"; 66*4882a593Smuzhiyun 67*4882a593Smuzhiyun CPU_SLEEP_0: cpu-sleep-0 { 68*4882a593Smuzhiyun compatible = "arm,idle-state"; 69*4882a593Smuzhiyun arm,psci-suspend-param = <0x0010000>; 70*4882a593Smuzhiyun local-timer-stop; 71*4882a593Smuzhiyun entry-latency-us = <300>; 72*4882a593Smuzhiyun exit-latency-us = <1200>; 73*4882a593Smuzhiyun min-residency-us = <2000>; 74*4882a593Smuzhiyun }; 75*4882a593Smuzhiyun 76*4882a593Smuzhiyun CLUSTER_SLEEP_0: cluster-sleep-0 { 77*4882a593Smuzhiyun compatible = "arm,idle-state"; 78*4882a593Smuzhiyun arm,psci-suspend-param = <0x1010000>; 79*4882a593Smuzhiyun local-timer-stop; 80*4882a593Smuzhiyun entry-latency-us = <400>; 81*4882a593Smuzhiyun exit-latency-us = <1200>; 82*4882a593Smuzhiyun min-residency-us = <2500>; 83*4882a593Smuzhiyun }; 84*4882a593Smuzhiyun }; 85*4882a593Smuzhiyun 86*4882a593Smuzhiyun A57_0: cpu@0 { 87*4882a593Smuzhiyun compatible = "arm,cortex-a57"; 88*4882a593Smuzhiyun reg = <0x0 0x0>; 89*4882a593Smuzhiyun device_type = "cpu"; 90*4882a593Smuzhiyun enable-method = "psci"; 91*4882a593Smuzhiyun i-cache-size = <0xc000>; 92*4882a593Smuzhiyun i-cache-line-size = <64>; 93*4882a593Smuzhiyun i-cache-sets = <256>; 94*4882a593Smuzhiyun d-cache-size = <0x8000>; 95*4882a593Smuzhiyun d-cache-line-size = <64>; 96*4882a593Smuzhiyun d-cache-sets = <256>; 97*4882a593Smuzhiyun next-level-cache = <&A57_L2>; 98*4882a593Smuzhiyun clocks = <&scpi_dvfs 0>; 99*4882a593Smuzhiyun cpu-idle-states = <&CPU_SLEEP_0 &CLUSTER_SLEEP_0>; 100*4882a593Smuzhiyun capacity-dmips-mhz = <1024>; 101*4882a593Smuzhiyun dynamic-power-coefficient = <530>; 102*4882a593Smuzhiyun }; 103*4882a593Smuzhiyun 104*4882a593Smuzhiyun A57_1: cpu@1 { 105*4882a593Smuzhiyun compatible = "arm,cortex-a57"; 106*4882a593Smuzhiyun reg = <0x0 0x1>; 107*4882a593Smuzhiyun device_type = "cpu"; 108*4882a593Smuzhiyun enable-method = "psci"; 109*4882a593Smuzhiyun i-cache-size = <0xc000>; 110*4882a593Smuzhiyun i-cache-line-size = <64>; 111*4882a593Smuzhiyun i-cache-sets = <256>; 112*4882a593Smuzhiyun d-cache-size = <0x8000>; 113*4882a593Smuzhiyun d-cache-line-size = <64>; 114*4882a593Smuzhiyun d-cache-sets = <256>; 115*4882a593Smuzhiyun next-level-cache = <&A57_L2>; 116*4882a593Smuzhiyun clocks = <&scpi_dvfs 0>; 117*4882a593Smuzhiyun cpu-idle-states = <&CPU_SLEEP_0 &CLUSTER_SLEEP_0>; 118*4882a593Smuzhiyun capacity-dmips-mhz = <1024>; 119*4882a593Smuzhiyun dynamic-power-coefficient = <530>; 120*4882a593Smuzhiyun }; 121*4882a593Smuzhiyun 122*4882a593Smuzhiyun A53_0: cpu@100 { 123*4882a593Smuzhiyun compatible = "arm,cortex-a53"; 124*4882a593Smuzhiyun reg = <0x0 0x100>; 125*4882a593Smuzhiyun device_type = "cpu"; 126*4882a593Smuzhiyun enable-method = "psci"; 127*4882a593Smuzhiyun i-cache-size = <0x8000>; 128*4882a593Smuzhiyun i-cache-line-size = <64>; 129*4882a593Smuzhiyun i-cache-sets = <256>; 130*4882a593Smuzhiyun d-cache-size = <0x8000>; 131*4882a593Smuzhiyun d-cache-line-size = <64>; 132*4882a593Smuzhiyun d-cache-sets = <128>; 133*4882a593Smuzhiyun next-level-cache = <&A53_L2>; 134*4882a593Smuzhiyun clocks = <&scpi_dvfs 1>; 135*4882a593Smuzhiyun cpu-idle-states = <&CPU_SLEEP_0 &CLUSTER_SLEEP_0>; 136*4882a593Smuzhiyun capacity-dmips-mhz = <578>; 137*4882a593Smuzhiyun dynamic-power-coefficient = <140>; 138*4882a593Smuzhiyun }; 139*4882a593Smuzhiyun 140*4882a593Smuzhiyun A53_1: cpu@101 { 141*4882a593Smuzhiyun compatible = "arm,cortex-a53"; 142*4882a593Smuzhiyun reg = <0x0 0x101>; 143*4882a593Smuzhiyun device_type = "cpu"; 144*4882a593Smuzhiyun enable-method = "psci"; 145*4882a593Smuzhiyun i-cache-size = <0x8000>; 146*4882a593Smuzhiyun i-cache-line-size = <64>; 147*4882a593Smuzhiyun i-cache-sets = <256>; 148*4882a593Smuzhiyun d-cache-size = <0x8000>; 149*4882a593Smuzhiyun d-cache-line-size = <64>; 150*4882a593Smuzhiyun d-cache-sets = <128>; 151*4882a593Smuzhiyun next-level-cache = <&A53_L2>; 152*4882a593Smuzhiyun clocks = <&scpi_dvfs 1>; 153*4882a593Smuzhiyun cpu-idle-states = <&CPU_SLEEP_0 &CLUSTER_SLEEP_0>; 154*4882a593Smuzhiyun capacity-dmips-mhz = <578>; 155*4882a593Smuzhiyun dynamic-power-coefficient = <140>; 156*4882a593Smuzhiyun }; 157*4882a593Smuzhiyun 158*4882a593Smuzhiyun A53_2: cpu@102 { 159*4882a593Smuzhiyun compatible = "arm,cortex-a53"; 160*4882a593Smuzhiyun reg = <0x0 0x102>; 161*4882a593Smuzhiyun device_type = "cpu"; 162*4882a593Smuzhiyun enable-method = "psci"; 163*4882a593Smuzhiyun i-cache-size = <0x8000>; 164*4882a593Smuzhiyun i-cache-line-size = <64>; 165*4882a593Smuzhiyun i-cache-sets = <256>; 166*4882a593Smuzhiyun d-cache-size = <0x8000>; 167*4882a593Smuzhiyun d-cache-line-size = <64>; 168*4882a593Smuzhiyun d-cache-sets = <128>; 169*4882a593Smuzhiyun next-level-cache = <&A53_L2>; 170*4882a593Smuzhiyun clocks = <&scpi_dvfs 1>; 171*4882a593Smuzhiyun cpu-idle-states = <&CPU_SLEEP_0 &CLUSTER_SLEEP_0>; 172*4882a593Smuzhiyun capacity-dmips-mhz = <578>; 173*4882a593Smuzhiyun dynamic-power-coefficient = <140>; 174*4882a593Smuzhiyun }; 175*4882a593Smuzhiyun 176*4882a593Smuzhiyun A53_3: cpu@103 { 177*4882a593Smuzhiyun compatible = "arm,cortex-a53"; 178*4882a593Smuzhiyun reg = <0x0 0x103>; 179*4882a593Smuzhiyun device_type = "cpu"; 180*4882a593Smuzhiyun enable-method = "psci"; 181*4882a593Smuzhiyun i-cache-size = <0x8000>; 182*4882a593Smuzhiyun i-cache-line-size = <64>; 183*4882a593Smuzhiyun i-cache-sets = <256>; 184*4882a593Smuzhiyun d-cache-size = <0x8000>; 185*4882a593Smuzhiyun d-cache-line-size = <64>; 186*4882a593Smuzhiyun d-cache-sets = <128>; 187*4882a593Smuzhiyun next-level-cache = <&A53_L2>; 188*4882a593Smuzhiyun clocks = <&scpi_dvfs 1>; 189*4882a593Smuzhiyun cpu-idle-states = <&CPU_SLEEP_0 &CLUSTER_SLEEP_0>; 190*4882a593Smuzhiyun capacity-dmips-mhz = <578>; 191*4882a593Smuzhiyun dynamic-power-coefficient = <140>; 192*4882a593Smuzhiyun }; 193*4882a593Smuzhiyun 194*4882a593Smuzhiyun A57_L2: l2-cache0 { 195*4882a593Smuzhiyun compatible = "cache"; 196*4882a593Smuzhiyun cache-size = <0x200000>; 197*4882a593Smuzhiyun cache-line-size = <64>; 198*4882a593Smuzhiyun cache-sets = <2048>; 199*4882a593Smuzhiyun }; 200*4882a593Smuzhiyun 201*4882a593Smuzhiyun A53_L2: l2-cache1 { 202*4882a593Smuzhiyun compatible = "cache"; 203*4882a593Smuzhiyun cache-size = <0x100000>; 204*4882a593Smuzhiyun cache-line-size = <64>; 205*4882a593Smuzhiyun cache-sets = <1024>; 206*4882a593Smuzhiyun }; 207*4882a593Smuzhiyun }; 208*4882a593Smuzhiyun 209*4882a593Smuzhiyun pmu-a57 { 210*4882a593Smuzhiyun compatible = "arm,cortex-a57-pmu"; 211*4882a593Smuzhiyun interrupts = <GIC_SPI 02 IRQ_TYPE_LEVEL_HIGH>, 212*4882a593Smuzhiyun <GIC_SPI 06 IRQ_TYPE_LEVEL_HIGH>; 213*4882a593Smuzhiyun interrupt-affinity = <&A57_0>, 214*4882a593Smuzhiyun <&A57_1>; 215*4882a593Smuzhiyun }; 216*4882a593Smuzhiyun 217*4882a593Smuzhiyun pmu-a53 { 218*4882a593Smuzhiyun compatible = "arm,cortex-a53-pmu"; 219*4882a593Smuzhiyun interrupts = <GIC_SPI 18 IRQ_TYPE_LEVEL_HIGH>, 220*4882a593Smuzhiyun <GIC_SPI 22 IRQ_TYPE_LEVEL_HIGH>, 221*4882a593Smuzhiyun <GIC_SPI 26 IRQ_TYPE_LEVEL_HIGH>, 222*4882a593Smuzhiyun <GIC_SPI 30 IRQ_TYPE_LEVEL_HIGH>; 223*4882a593Smuzhiyun interrupt-affinity = <&A53_0>, 224*4882a593Smuzhiyun <&A53_1>, 225*4882a593Smuzhiyun <&A53_2>, 226*4882a593Smuzhiyun <&A53_3>; 227*4882a593Smuzhiyun }; 228*4882a593Smuzhiyun}; 229*4882a593Smuzhiyun 230*4882a593Smuzhiyun&etm0 { 231*4882a593Smuzhiyun cpu = <&A57_0>; 232*4882a593Smuzhiyun}; 233*4882a593Smuzhiyun 234*4882a593Smuzhiyun&etm1 { 235*4882a593Smuzhiyun cpu = <&A57_1>; 236*4882a593Smuzhiyun}; 237*4882a593Smuzhiyun 238*4882a593Smuzhiyun&etm2 { 239*4882a593Smuzhiyun cpu = <&A53_0>; 240*4882a593Smuzhiyun}; 241*4882a593Smuzhiyun 242*4882a593Smuzhiyun&etm3 { 243*4882a593Smuzhiyun cpu = <&A53_1>; 244*4882a593Smuzhiyun}; 245*4882a593Smuzhiyun 246*4882a593Smuzhiyun&etm4 { 247*4882a593Smuzhiyun cpu = <&A53_2>; 248*4882a593Smuzhiyun}; 249*4882a593Smuzhiyun 250*4882a593Smuzhiyun&etm5 { 251*4882a593Smuzhiyun cpu = <&A53_3>; 252*4882a593Smuzhiyun}; 253*4882a593Smuzhiyun 254*4882a593Smuzhiyun&etf0_out_port { 255*4882a593Smuzhiyun remote-endpoint = <&replicator_in_port0>; 256*4882a593Smuzhiyun}; 257*4882a593Smuzhiyun 258*4882a593Smuzhiyun&replicator_in_port0 { 259*4882a593Smuzhiyun remote-endpoint = <&etf0_out_port>; 260*4882a593Smuzhiyun}; 261*4882a593Smuzhiyun 262*4882a593Smuzhiyun&stm_out_port { 263*4882a593Smuzhiyun remote-endpoint = <&main_funnel_in_port2>; 264*4882a593Smuzhiyun}; 265*4882a593Smuzhiyun 266*4882a593Smuzhiyun&main_funnel_in_ports { 267*4882a593Smuzhiyun port@2 { 268*4882a593Smuzhiyun reg = <2>; 269*4882a593Smuzhiyun main_funnel_in_port2: endpoint { 270*4882a593Smuzhiyun remote-endpoint = <&stm_out_port>; 271*4882a593Smuzhiyun }; 272*4882a593Smuzhiyun }; 273*4882a593Smuzhiyun}; 274*4882a593Smuzhiyun 275*4882a593Smuzhiyun&cpu_debug0 { 276*4882a593Smuzhiyun cpu = <&A57_0>; 277*4882a593Smuzhiyun}; 278*4882a593Smuzhiyun 279*4882a593Smuzhiyun&cpu_debug1 { 280*4882a593Smuzhiyun cpu = <&A57_1>; 281*4882a593Smuzhiyun}; 282*4882a593Smuzhiyun 283*4882a593Smuzhiyun&cpu_debug2 { 284*4882a593Smuzhiyun cpu = <&A53_0>; 285*4882a593Smuzhiyun}; 286*4882a593Smuzhiyun 287*4882a593Smuzhiyun&cpu_debug3 { 288*4882a593Smuzhiyun cpu = <&A53_1>; 289*4882a593Smuzhiyun}; 290*4882a593Smuzhiyun 291*4882a593Smuzhiyun&cpu_debug4 { 292*4882a593Smuzhiyun cpu = <&A53_2>; 293*4882a593Smuzhiyun}; 294*4882a593Smuzhiyun 295*4882a593Smuzhiyun&cpu_debug5 { 296*4882a593Smuzhiyun cpu = <&A53_3>; 297*4882a593Smuzhiyun}; 298