1 // SPDX-License-Identifier: GPL-2.0 1 // SPDX-License-Identifier: GPL-2.0 2 #include "juno-clocks.dtsi" 2 #include "juno-clocks.dtsi" 3 #include "juno-motherboard.dtsi" 3 #include "juno-motherboard.dtsi" 4 4 5 / { 5 / { 6 /* 6 /* 7 * Devices shared by all Juno boards 7 * Devices shared by all Juno boards 8 */ 8 */ 9 9 10 memtimer: timer@2a810000 { 10 memtimer: timer@2a810000 { 11 compatible = "arm,armv7-timer- 11 compatible = "arm,armv7-timer-mem"; 12 reg = <0x0 0x2a810000 0x0 0x10 12 reg = <0x0 0x2a810000 0x0 0x10000>; 13 clock-frequency = <50000000>; 13 clock-frequency = <50000000>; 14 #address-cells = <1>; 14 #address-cells = <1>; 15 #size-cells = <1>; 15 #size-cells = <1>; 16 ranges = <0 0x0 0x2a820000 0x2 16 ranges = <0 0x0 0x2a820000 0x20000>; 17 status = "disabled"; 17 status = "disabled"; 18 frame@2a830000 { 18 frame@2a830000 { 19 frame-number = <1>; 19 frame-number = <1>; 20 interrupts = <GIC_SPI 20 interrupts = <GIC_SPI 60 IRQ_TYPE_LEVEL_HIGH>; 21 reg = <0x10000 0x10000 21 reg = <0x10000 0x10000>; 22 }; 22 }; 23 }; 23 }; 24 24 25 mailbox: mhu@2b1f0000 { 25 mailbox: mhu@2b1f0000 { 26 compatible = "arm,mhu", "arm,p 26 compatible = "arm,mhu", "arm,primecell"; 27 reg = <0x0 0x2b1f0000 0x0 0x10 27 reg = <0x0 0x2b1f0000 0x0 0x1000>; 28 interrupts = <GIC_SPI 36 IRQ_T 28 interrupts = <GIC_SPI 36 IRQ_TYPE_LEVEL_HIGH>, 29 <GIC_SPI 35 IRQ_T 29 <GIC_SPI 35 IRQ_TYPE_LEVEL_HIGH>, 30 <GIC_SPI 37 IRQ_T 30 <GIC_SPI 37 IRQ_TYPE_LEVEL_HIGH>; 31 #mbox-cells = <1>; 31 #mbox-cells = <1>; 32 clocks = <&soc_refclk100mhz>; 32 clocks = <&soc_refclk100mhz>; 33 clock-names = "apb_pclk"; 33 clock-names = "apb_pclk"; 34 }; 34 }; 35 35 36 smmu_gpu: iommu@2b400000 { 36 smmu_gpu: iommu@2b400000 { 37 compatible = "arm,mmu-400", "a 37 compatible = "arm,mmu-400", "arm,smmu-v1"; 38 reg = <0x0 0x2b400000 0x0 0x10 38 reg = <0x0 0x2b400000 0x0 0x10000>; 39 interrupts = <GIC_SPI 38 IRQ_T 39 interrupts = <GIC_SPI 38 IRQ_TYPE_LEVEL_HIGH>, 40 <GIC_SPI 38 IRQ_T 40 <GIC_SPI 38 IRQ_TYPE_LEVEL_HIGH>; 41 #iommu-cells = <1>; 41 #iommu-cells = <1>; 42 #global-interrupts = <1>; 42 #global-interrupts = <1>; 43 power-domains = <&scpi_devpd 1 43 power-domains = <&scpi_devpd 1>; 44 dma-coherent; 44 dma-coherent; 45 status = "disabled"; 45 status = "disabled"; 46 }; 46 }; 47 47 48 smmu_pcie: iommu@2b500000 { 48 smmu_pcie: iommu@2b500000 { 49 compatible = "arm,mmu-401", "a 49 compatible = "arm,mmu-401", "arm,smmu-v1"; 50 reg = <0x0 0x2b500000 0x0 0x10 50 reg = <0x0 0x2b500000 0x0 0x10000>; 51 interrupts = <GIC_SPI 40 IRQ_T 51 interrupts = <GIC_SPI 40 IRQ_TYPE_LEVEL_HIGH>, 52 <GIC_SPI 40 IRQ_T 52 <GIC_SPI 40 IRQ_TYPE_LEVEL_HIGH>; 53 #iommu-cells = <1>; 53 #iommu-cells = <1>; 54 #global-interrupts = <1>; 54 #global-interrupts = <1>; 55 dma-coherent; 55 dma-coherent; 56 status = "disabled"; 56 status = "disabled"; 57 }; 57 }; 58 58 59 smmu_etr: iommu@2b600000 { 59 smmu_etr: iommu@2b600000 { 60 compatible = "arm,mmu-401", "a 60 compatible = "arm,mmu-401", "arm,smmu-v1"; 61 reg = <0x0 0x2b600000 0x0 0x10 61 reg = <0x0 0x2b600000 0x0 0x10000>; 62 interrupts = <GIC_SPI 42 IRQ_T 62 interrupts = <GIC_SPI 42 IRQ_TYPE_LEVEL_HIGH>, 63 <GIC_SPI 42 IRQ_T 63 <GIC_SPI 42 IRQ_TYPE_LEVEL_HIGH>; 64 #iommu-cells = <1>; 64 #iommu-cells = <1>; 65 #global-interrupts = <1>; 65 #global-interrupts = <1>; 66 dma-coherent; 66 dma-coherent; 67 power-domains = <&scpi_devpd 0 67 power-domains = <&scpi_devpd 0>; 68 }; 68 }; 69 69 70 gic: interrupt-controller@2c010000 { 70 gic: interrupt-controller@2c010000 { 71 compatible = "arm,gic-400", "a 71 compatible = "arm,gic-400", "arm,cortex-a15-gic"; 72 reg = <0x0 0x2c010000 0 0x1000 72 reg = <0x0 0x2c010000 0 0x1000>, 73 <0x0 0x2c02f000 0 0x2000 73 <0x0 0x2c02f000 0 0x2000>, 74 <0x0 0x2c04f000 0 0x2000 74 <0x0 0x2c04f000 0 0x2000>, 75 <0x0 0x2c06f000 0 0x2000 75 <0x0 0x2c06f000 0 0x2000>; 76 #address-cells = <1>; 76 #address-cells = <1>; 77 #interrupt-cells = <3>; 77 #interrupt-cells = <3>; 78 #size-cells = <1>; 78 #size-cells = <1>; 79 interrupt-controller; 79 interrupt-controller; 80 interrupts = <GIC_PPI 9 (GIC_C 80 interrupts = <GIC_PPI 9 (GIC_CPU_MASK_SIMPLE(6) | IRQ_TYPE_LEVEL_HIGH)>; 81 ranges = <0 0 0x2c1c0000 0x400 81 ranges = <0 0 0x2c1c0000 0x40000>; 82 82 83 v2m_0: v2m@0 { 83 v2m_0: v2m@0 { 84 compatible = "arm,gic- 84 compatible = "arm,gic-v2m-frame"; 85 msi-controller; 85 msi-controller; 86 reg = <0 0x10000>; 86 reg = <0 0x10000>; 87 }; 87 }; 88 88 89 v2m@10000 { 89 v2m@10000 { 90 compatible = "arm,gic- 90 compatible = "arm,gic-v2m-frame"; 91 msi-controller; 91 msi-controller; 92 reg = <0x10000 0x10000 92 reg = <0x10000 0x10000>; 93 }; 93 }; 94 94 95 v2m@20000 { 95 v2m@20000 { 96 compatible = "arm,gic- 96 compatible = "arm,gic-v2m-frame"; 97 msi-controller; 97 msi-controller; 98 reg = <0x20000 0x10000 98 reg = <0x20000 0x10000>; 99 }; 99 }; 100 100 101 v2m@30000 { 101 v2m@30000 { 102 compatible = "arm,gic- 102 compatible = "arm,gic-v2m-frame"; 103 msi-controller; 103 msi-controller; 104 reg = <0x30000 0x10000 104 reg = <0x30000 0x10000>; 105 }; 105 }; 106 }; 106 }; 107 107 108 timer { 108 timer { 109 compatible = "arm,armv8-timer" 109 compatible = "arm,armv8-timer"; 110 interrupts = <GIC_PPI 13 (GIC_ 110 interrupts = <GIC_PPI 13 (GIC_CPU_MASK_SIMPLE(6) | IRQ_TYPE_LEVEL_LOW)>, 111 <GIC_PPI 14 (GIC_ 111 <GIC_PPI 14 (GIC_CPU_MASK_SIMPLE(6) | IRQ_TYPE_LEVEL_LOW)>, 112 <GIC_PPI 11 (GIC_ 112 <GIC_PPI 11 (GIC_CPU_MASK_SIMPLE(6) | IRQ_TYPE_LEVEL_LOW)>, 113 <GIC_PPI 10 (GIC_ 113 <GIC_PPI 10 (GIC_CPU_MASK_SIMPLE(6) | IRQ_TYPE_LEVEL_LOW)>; 114 }; 114 }; 115 115 116 /* 116 /* 117 * Juno TRMs specify the size for thes 117 * Juno TRMs specify the size for these coresight components as 64K. 118 * The actual size is just 4K though 6 118 * The actual size is just 4K though 64K is reserved. Access to the 119 * unmapped reserved region results in 119 * unmapped reserved region results in a DECERR response. 120 */ 120 */ 121 etf_sys0: etf@20010000 { /* etf0 */ 121 etf_sys0: etf@20010000 { /* etf0 */ 122 compatible = "arm,coresight-tm 122 compatible = "arm,coresight-tmc", "arm,primecell"; 123 reg = <0 0x20010000 0 0x1000>; 123 reg = <0 0x20010000 0 0x1000>; 124 124 125 clocks = <&soc_smc50mhz>; 125 clocks = <&soc_smc50mhz>; 126 clock-names = "apb_pclk"; 126 clock-names = "apb_pclk"; 127 power-domains = <&scpi_devpd 0 127 power-domains = <&scpi_devpd 0>; 128 128 129 in-ports { 129 in-ports { 130 port { 130 port { 131 etf0_in_port: 131 etf0_in_port: endpoint { 132 remote 132 remote-endpoint = <&main_funnel_out_port>; 133 }; 133 }; 134 }; 134 }; 135 }; 135 }; 136 136 137 out-ports { 137 out-ports { 138 port { 138 port { 139 etf0_out_port: 139 etf0_out_port: endpoint { 140 }; 140 }; 141 }; 141 }; 142 }; 142 }; 143 }; 143 }; 144 144 145 tpiu_sys: tpiu@20030000 { 145 tpiu_sys: tpiu@20030000 { 146 compatible = "arm,coresight-tp 146 compatible = "arm,coresight-tpiu", "arm,primecell"; 147 reg = <0 0x20030000 0 0x1000>; 147 reg = <0 0x20030000 0 0x1000>; 148 148 149 clocks = <&soc_smc50mhz>; 149 clocks = <&soc_smc50mhz>; 150 clock-names = "apb_pclk"; 150 clock-names = "apb_pclk"; 151 power-domains = <&scpi_devpd 0 151 power-domains = <&scpi_devpd 0>; 152 in-ports { 152 in-ports { 153 port { 153 port { 154 tpiu_in_port: 154 tpiu_in_port: endpoint { 155 remote 155 remote-endpoint = <&replicator_out_port0>; 156 }; 156 }; 157 }; 157 }; 158 }; 158 }; 159 }; 159 }; 160 160 161 /* main funnel on Juno r0, cssys0 funn 161 /* main funnel on Juno r0, cssys0 funnel on Juno r1/r2 as per TRM*/ 162 main_funnel: funnel@20040000 { 162 main_funnel: funnel@20040000 { 163 compatible = "arm,coresight-dy 163 compatible = "arm,coresight-dynamic-funnel", "arm,primecell"; 164 reg = <0 0x20040000 0 0x1000>; 164 reg = <0 0x20040000 0 0x1000>; 165 165 166 clocks = <&soc_smc50mhz>; 166 clocks = <&soc_smc50mhz>; 167 clock-names = "apb_pclk"; 167 clock-names = "apb_pclk"; 168 power-domains = <&scpi_devpd 0 168 power-domains = <&scpi_devpd 0>; 169 169 170 out-ports { 170 out-ports { 171 port { 171 port { 172 main_funnel_ou 172 main_funnel_out_port: endpoint { 173 remote 173 remote-endpoint = <&etf0_in_port>; 174 }; 174 }; 175 }; 175 }; 176 }; 176 }; 177 177 178 main_funnel_in_ports: in-ports 178 main_funnel_in_ports: in-ports { 179 #address-cells = <1>; 179 #address-cells = <1>; 180 #size-cells = <0>; 180 #size-cells = <0>; 181 181 182 port@0 { 182 port@0 { 183 reg = <0>; 183 reg = <0>; 184 main_funnel_in 184 main_funnel_in_port0: endpoint { 185 remote 185 remote-endpoint = <&cluster0_funnel_out_port>; 186 }; 186 }; 187 }; 187 }; 188 188 189 port@1 { 189 port@1 { 190 reg = <1>; 190 reg = <1>; 191 main_funnel_in 191 main_funnel_in_port1: endpoint { 192 remote 192 remote-endpoint = <&cluster1_funnel_out_port>; 193 }; 193 }; 194 }; 194 }; 195 }; 195 }; 196 }; 196 }; 197 197 198 etr_sys: etr@20070000 { 198 etr_sys: etr@20070000 { 199 compatible = "arm,coresight-tm 199 compatible = "arm,coresight-tmc", "arm,primecell"; 200 reg = <0 0x20070000 0 0x1000>; 200 reg = <0 0x20070000 0 0x1000>; 201 iommus = <&smmu_etr 0>; 201 iommus = <&smmu_etr 0>; 202 202 203 clocks = <&soc_smc50mhz>; 203 clocks = <&soc_smc50mhz>; 204 clock-names = "apb_pclk"; 204 clock-names = "apb_pclk"; 205 power-domains = <&scpi_devpd 0 205 power-domains = <&scpi_devpd 0>; 206 arm,scatter-gather; 206 arm,scatter-gather; 207 in-ports { 207 in-ports { 208 port { 208 port { 209 etr_in_port: e 209 etr_in_port: endpoint { 210 remote 210 remote-endpoint = <&replicator_out_port1>; 211 }; 211 }; 212 }; 212 }; 213 }; 213 }; 214 }; 214 }; 215 215 216 stm_sys: stm@20100000 { 216 stm_sys: stm@20100000 { 217 compatible = "arm,coresight-st 217 compatible = "arm,coresight-stm", "arm,primecell"; 218 reg = <0 0x20100000 0 0x1000>, 218 reg = <0 0x20100000 0 0x1000>, 219 <0 0x28000000 0 0x100000 219 <0 0x28000000 0 0x1000000>; 220 reg-names = "stm-base", "stm-s 220 reg-names = "stm-base", "stm-stimulus-base"; 221 221 222 clocks = <&soc_smc50mhz>; 222 clocks = <&soc_smc50mhz>; 223 clock-names = "apb_pclk"; 223 clock-names = "apb_pclk"; 224 power-domains = <&scpi_devpd 0 224 power-domains = <&scpi_devpd 0>; 225 out-ports { 225 out-ports { 226 port { 226 port { 227 stm_out_port: 227 stm_out_port: endpoint { 228 }; 228 }; 229 }; 229 }; 230 }; 230 }; 231 }; 231 }; 232 232 233 replicator@20120000 { 233 replicator@20120000 { 234 compatible = "arm,coresight-dy 234 compatible = "arm,coresight-dynamic-replicator", "arm,primecell"; 235 reg = <0 0x20120000 0 0x1000>; 235 reg = <0 0x20120000 0 0x1000>; 236 236 237 clocks = <&soc_smc50mhz>; 237 clocks = <&soc_smc50mhz>; 238 clock-names = "apb_pclk"; 238 clock-names = "apb_pclk"; 239 power-domains = <&scpi_devpd 0 239 power-domains = <&scpi_devpd 0>; 240 240 241 out-ports { 241 out-ports { 242 #address-cells = <1>; 242 #address-cells = <1>; 243 #size-cells = <0>; 243 #size-cells = <0>; 244 244 245 /* replicator output p 245 /* replicator output ports */ 246 port@0 { 246 port@0 { 247 reg = <0>; 247 reg = <0>; 248 replicator_out 248 replicator_out_port0: endpoint { 249 remote 249 remote-endpoint = <&tpiu_in_port>; 250 }; 250 }; 251 }; 251 }; 252 252 253 port@1 { 253 port@1 { 254 reg = <1>; 254 reg = <1>; 255 replicator_out 255 replicator_out_port1: endpoint { 256 remote 256 remote-endpoint = <&etr_in_port>; 257 }; 257 }; 258 }; 258 }; 259 }; 259 }; 260 in-ports { 260 in-ports { 261 port { 261 port { 262 replicator_in_ 262 replicator_in_port0: endpoint { 263 }; 263 }; 264 }; 264 }; 265 }; 265 }; 266 }; 266 }; 267 267 268 cpu_debug0: cpu-debug@22010000 { 268 cpu_debug0: cpu-debug@22010000 { 269 compatible = "arm,coresight-cp 269 compatible = "arm,coresight-cpu-debug", "arm,primecell"; 270 reg = <0x0 0x22010000 0x0 0x10 270 reg = <0x0 0x22010000 0x0 0x1000>; 271 271 272 clocks = <&soc_smc50mhz>; 272 clocks = <&soc_smc50mhz>; 273 clock-names = "apb_pclk"; 273 clock-names = "apb_pclk"; 274 power-domains = <&scpi_devpd 0 274 power-domains = <&scpi_devpd 0>; 275 }; 275 }; 276 276 277 etm0: etm@22040000 { 277 etm0: etm@22040000 { 278 compatible = "arm,coresight-et 278 compatible = "arm,coresight-etm4x", "arm,primecell"; 279 reg = <0 0x22040000 0 0x1000>; 279 reg = <0 0x22040000 0 0x1000>; 280 280 281 clocks = <&soc_smc50mhz>; 281 clocks = <&soc_smc50mhz>; 282 clock-names = "apb_pclk"; 282 clock-names = "apb_pclk"; 283 power-domains = <&scpi_devpd 0 283 power-domains = <&scpi_devpd 0>; 284 out-ports { 284 out-ports { 285 port { 285 port { 286 cluster0_etm0_ 286 cluster0_etm0_out_port: endpoint { 287 remote 287 remote-endpoint = <&cluster0_funnel_in_port0>; 288 }; 288 }; 289 }; 289 }; 290 }; 290 }; 291 }; 291 }; 292 292 293 cti0: cti@22020000 { 293 cti0: cti@22020000 { 294 compatible = "arm,coresight-ct 294 compatible = "arm,coresight-cti-v8-arch", "arm,coresight-cti", 295 "arm,primecell"; 295 "arm,primecell"; 296 reg = <0 0x22020000 0 0x1000>; 296 reg = <0 0x22020000 0 0x1000>; 297 297 298 clocks = <&soc_smc50mhz>; 298 clocks = <&soc_smc50mhz>; 299 clock-names = "apb_pclk"; 299 clock-names = "apb_pclk"; 300 power-domains = <&scpi_devpd 0 300 power-domains = <&scpi_devpd 0>; 301 301 302 arm,cs-dev-assoc = <&etm0>; 302 arm,cs-dev-assoc = <&etm0>; 303 }; 303 }; 304 304 305 funnel@220c0000 { /* cluster0 funnel * 305 funnel@220c0000 { /* cluster0 funnel */ 306 compatible = "arm,coresight-dy 306 compatible = "arm,coresight-dynamic-funnel", "arm,primecell"; 307 reg = <0 0x220c0000 0 0x1000>; 307 reg = <0 0x220c0000 0 0x1000>; 308 308 309 clocks = <&soc_smc50mhz>; 309 clocks = <&soc_smc50mhz>; 310 clock-names = "apb_pclk"; 310 clock-names = "apb_pclk"; 311 power-domains = <&scpi_devpd 0 311 power-domains = <&scpi_devpd 0>; 312 out-ports { 312 out-ports { 313 port { 313 port { 314 cluster0_funne 314 cluster0_funnel_out_port: endpoint { 315 remote 315 remote-endpoint = <&main_funnel_in_port0>; 316 }; 316 }; 317 }; 317 }; 318 }; 318 }; 319 319 320 in-ports { 320 in-ports { 321 #address-cells = <1>; 321 #address-cells = <1>; 322 #size-cells = <0>; 322 #size-cells = <0>; 323 323 324 port@0 { 324 port@0 { 325 reg = <0>; 325 reg = <0>; 326 cluster0_funne 326 cluster0_funnel_in_port0: endpoint { 327 remote 327 remote-endpoint = <&cluster0_etm0_out_port>; 328 }; 328 }; 329 }; 329 }; 330 330 331 port@1 { 331 port@1 { 332 reg = <1>; 332 reg = <1>; 333 cluster0_funne 333 cluster0_funnel_in_port1: endpoint { 334 remote 334 remote-endpoint = <&cluster0_etm1_out_port>; 335 }; 335 }; 336 }; 336 }; 337 }; 337 }; 338 }; 338 }; 339 339 340 cpu_debug1: cpu-debug@22110000 { 340 cpu_debug1: cpu-debug@22110000 { 341 compatible = "arm,coresight-cp 341 compatible = "arm,coresight-cpu-debug", "arm,primecell"; 342 reg = <0x0 0x22110000 0x0 0x10 342 reg = <0x0 0x22110000 0x0 0x1000>; 343 343 344 clocks = <&soc_smc50mhz>; 344 clocks = <&soc_smc50mhz>; 345 clock-names = "apb_pclk"; 345 clock-names = "apb_pclk"; 346 power-domains = <&scpi_devpd 0 346 power-domains = <&scpi_devpd 0>; 347 }; 347 }; 348 348 349 etm1: etm@22140000 { 349 etm1: etm@22140000 { 350 compatible = "arm,coresight-et 350 compatible = "arm,coresight-etm4x", "arm,primecell"; 351 reg = <0 0x22140000 0 0x1000>; 351 reg = <0 0x22140000 0 0x1000>; 352 352 353 clocks = <&soc_smc50mhz>; 353 clocks = <&soc_smc50mhz>; 354 clock-names = "apb_pclk"; 354 clock-names = "apb_pclk"; 355 power-domains = <&scpi_devpd 0 355 power-domains = <&scpi_devpd 0>; 356 out-ports { 356 out-ports { 357 port { 357 port { 358 cluster0_etm1_ 358 cluster0_etm1_out_port: endpoint { 359 remote 359 remote-endpoint = <&cluster0_funnel_in_port1>; 360 }; 360 }; 361 }; 361 }; 362 }; 362 }; 363 }; 363 }; 364 364 365 cti1: cti@22120000 { 365 cti1: cti@22120000 { 366 compatible = "arm,coresight-ct 366 compatible = "arm,coresight-cti-v8-arch", "arm,coresight-cti", 367 "arm,primecell"; 367 "arm,primecell"; 368 reg = <0 0x22120000 0 0x1000>; 368 reg = <0 0x22120000 0 0x1000>; 369 369 370 clocks = <&soc_smc50mhz>; 370 clocks = <&soc_smc50mhz>; 371 clock-names = "apb_pclk"; 371 clock-names = "apb_pclk"; 372 power-domains = <&scpi_devpd 0 372 power-domains = <&scpi_devpd 0>; 373 373 374 arm,cs-dev-assoc = <&etm1>; 374 arm,cs-dev-assoc = <&etm1>; 375 }; 375 }; 376 376 377 cpu_debug2: cpu-debug@23010000 { 377 cpu_debug2: cpu-debug@23010000 { 378 compatible = "arm,coresight-cp 378 compatible = "arm,coresight-cpu-debug", "arm,primecell"; 379 reg = <0x0 0x23010000 0x0 0x10 379 reg = <0x0 0x23010000 0x0 0x1000>; 380 380 381 clocks = <&soc_smc50mhz>; 381 clocks = <&soc_smc50mhz>; 382 clock-names = "apb_pclk"; 382 clock-names = "apb_pclk"; 383 power-domains = <&scpi_devpd 0 383 power-domains = <&scpi_devpd 0>; 384 }; 384 }; 385 385 386 etm2: etm@23040000 { 386 etm2: etm@23040000 { 387 compatible = "arm,coresight-et 387 compatible = "arm,coresight-etm4x", "arm,primecell"; 388 reg = <0 0x23040000 0 0x1000>; 388 reg = <0 0x23040000 0 0x1000>; 389 389 390 clocks = <&soc_smc50mhz>; 390 clocks = <&soc_smc50mhz>; 391 clock-names = "apb_pclk"; 391 clock-names = "apb_pclk"; 392 power-domains = <&scpi_devpd 0 392 power-domains = <&scpi_devpd 0>; 393 out-ports { 393 out-ports { 394 port { 394 port { 395 cluster1_etm0_ 395 cluster1_etm0_out_port: endpoint { 396 remote 396 remote-endpoint = <&cluster1_funnel_in_port0>; 397 }; 397 }; 398 }; 398 }; 399 }; 399 }; 400 }; 400 }; 401 401 402 cti2: cti@23020000 { 402 cti2: cti@23020000 { 403 compatible = "arm,coresight-ct 403 compatible = "arm,coresight-cti-v8-arch", "arm,coresight-cti", 404 "arm,primecell"; 404 "arm,primecell"; 405 reg = <0 0x23020000 0 0x1000>; 405 reg = <0 0x23020000 0 0x1000>; 406 406 407 clocks = <&soc_smc50mhz>; 407 clocks = <&soc_smc50mhz>; 408 clock-names = "apb_pclk"; 408 clock-names = "apb_pclk"; 409 power-domains = <&scpi_devpd 0 409 power-domains = <&scpi_devpd 0>; 410 410 411 arm,cs-dev-assoc = <&etm2>; 411 arm,cs-dev-assoc = <&etm2>; 412 }; 412 }; 413 413 414 funnel@230c0000 { /* cluster1 funnel * 414 funnel@230c0000 { /* cluster1 funnel */ 415 compatible = "arm,coresight-dy 415 compatible = "arm,coresight-dynamic-funnel", "arm,primecell"; 416 reg = <0 0x230c0000 0 0x1000>; 416 reg = <0 0x230c0000 0 0x1000>; 417 417 418 clocks = <&soc_smc50mhz>; 418 clocks = <&soc_smc50mhz>; 419 clock-names = "apb_pclk"; 419 clock-names = "apb_pclk"; 420 power-domains = <&scpi_devpd 0 420 power-domains = <&scpi_devpd 0>; 421 out-ports { 421 out-ports { 422 port { 422 port { 423 cluster1_funne 423 cluster1_funnel_out_port: endpoint { 424 remote 424 remote-endpoint = <&main_funnel_in_port1>; 425 }; 425 }; 426 }; 426 }; 427 }; 427 }; 428 428 429 in-ports { 429 in-ports { 430 #address-cells = <1>; 430 #address-cells = <1>; 431 #size-cells = <0>; 431 #size-cells = <0>; 432 432 433 port@0 { 433 port@0 { 434 reg = <0>; 434 reg = <0>; 435 cluster1_funne 435 cluster1_funnel_in_port0: endpoint { 436 remote 436 remote-endpoint = <&cluster1_etm0_out_port>; 437 }; 437 }; 438 }; 438 }; 439 439 440 port@1 { 440 port@1 { 441 reg = <1>; 441 reg = <1>; 442 cluster1_funne 442 cluster1_funnel_in_port1: endpoint { 443 remote 443 remote-endpoint = <&cluster1_etm1_out_port>; 444 }; 444 }; 445 }; 445 }; 446 port@2 { 446 port@2 { 447 reg = <2>; 447 reg = <2>; 448 cluster1_funne 448 cluster1_funnel_in_port2: endpoint { 449 remote 449 remote-endpoint = <&cluster1_etm2_out_port>; 450 }; 450 }; 451 }; 451 }; 452 port@3 { 452 port@3 { 453 reg = <3>; 453 reg = <3>; 454 cluster1_funne 454 cluster1_funnel_in_port3: endpoint { 455 remote 455 remote-endpoint = <&cluster1_etm3_out_port>; 456 }; 456 }; 457 }; 457 }; 458 }; 458 }; 459 }; 459 }; 460 460 461 cpu_debug3: cpu-debug@23110000 { 461 cpu_debug3: cpu-debug@23110000 { 462 compatible = "arm,coresight-cp 462 compatible = "arm,coresight-cpu-debug", "arm,primecell"; 463 reg = <0x0 0x23110000 0x0 0x10 463 reg = <0x0 0x23110000 0x0 0x1000>; 464 464 465 clocks = <&soc_smc50mhz>; 465 clocks = <&soc_smc50mhz>; 466 clock-names = "apb_pclk"; 466 clock-names = "apb_pclk"; 467 power-domains = <&scpi_devpd 0 467 power-domains = <&scpi_devpd 0>; 468 }; 468 }; 469 469 470 etm3: etm@23140000 { 470 etm3: etm@23140000 { 471 compatible = "arm,coresight-et 471 compatible = "arm,coresight-etm4x", "arm,primecell"; 472 reg = <0 0x23140000 0 0x1000>; 472 reg = <0 0x23140000 0 0x1000>; 473 473 474 clocks = <&soc_smc50mhz>; 474 clocks = <&soc_smc50mhz>; 475 clock-names = "apb_pclk"; 475 clock-names = "apb_pclk"; 476 power-domains = <&scpi_devpd 0 476 power-domains = <&scpi_devpd 0>; 477 out-ports { 477 out-ports { 478 port { 478 port { 479 cluster1_etm1_ 479 cluster1_etm1_out_port: endpoint { 480 remote 480 remote-endpoint = <&cluster1_funnel_in_port1>; 481 }; 481 }; 482 }; 482 }; 483 }; 483 }; 484 }; 484 }; 485 485 486 cti3: cti@23120000 { 486 cti3: cti@23120000 { 487 compatible = "arm,coresight-ct 487 compatible = "arm,coresight-cti-v8-arch", "arm,coresight-cti", 488 "arm,primecell"; 488 "arm,primecell"; 489 reg = <0 0x23120000 0 0x1000>; 489 reg = <0 0x23120000 0 0x1000>; 490 490 491 clocks = <&soc_smc50mhz>; 491 clocks = <&soc_smc50mhz>; 492 clock-names = "apb_pclk"; 492 clock-names = "apb_pclk"; 493 power-domains = <&scpi_devpd 0 493 power-domains = <&scpi_devpd 0>; 494 494 495 arm,cs-dev-assoc = <&etm3>; 495 arm,cs-dev-assoc = <&etm3>; 496 }; 496 }; 497 497 498 cpu_debug4: cpu-debug@23210000 { 498 cpu_debug4: cpu-debug@23210000 { 499 compatible = "arm,coresight-cp 499 compatible = "arm,coresight-cpu-debug", "arm,primecell"; 500 reg = <0x0 0x23210000 0x0 0x10 500 reg = <0x0 0x23210000 0x0 0x1000>; 501 501 502 clocks = <&soc_smc50mhz>; 502 clocks = <&soc_smc50mhz>; 503 clock-names = "apb_pclk"; 503 clock-names = "apb_pclk"; 504 power-domains = <&scpi_devpd 0 504 power-domains = <&scpi_devpd 0>; 505 }; 505 }; 506 506 507 etm4: etm@23240000 { 507 etm4: etm@23240000 { 508 compatible = "arm,coresight-et 508 compatible = "arm,coresight-etm4x", "arm,primecell"; 509 reg = <0 0x23240000 0 0x1000>; 509 reg = <0 0x23240000 0 0x1000>; 510 510 511 clocks = <&soc_smc50mhz>; 511 clocks = <&soc_smc50mhz>; 512 clock-names = "apb_pclk"; 512 clock-names = "apb_pclk"; 513 power-domains = <&scpi_devpd 0 513 power-domains = <&scpi_devpd 0>; 514 out-ports { 514 out-ports { 515 port { 515 port { 516 cluster1_etm2_ 516 cluster1_etm2_out_port: endpoint { 517 remote 517 remote-endpoint = <&cluster1_funnel_in_port2>; 518 }; 518 }; 519 }; 519 }; 520 }; 520 }; 521 }; 521 }; 522 522 523 cti4: cti@23220000 { 523 cti4: cti@23220000 { 524 compatible = "arm,coresight-ct 524 compatible = "arm,coresight-cti-v8-arch", "arm,coresight-cti", 525 "arm,primecell"; 525 "arm,primecell"; 526 reg = <0 0x23220000 0 0x1000>; 526 reg = <0 0x23220000 0 0x1000>; 527 527 528 clocks = <&soc_smc50mhz>; 528 clocks = <&soc_smc50mhz>; 529 clock-names = "apb_pclk"; 529 clock-names = "apb_pclk"; 530 power-domains = <&scpi_devpd 0 530 power-domains = <&scpi_devpd 0>; 531 531 532 arm,cs-dev-assoc = <&etm4>; 532 arm,cs-dev-assoc = <&etm4>; 533 }; 533 }; 534 534 535 cpu_debug5: cpu-debug@23310000 { 535 cpu_debug5: cpu-debug@23310000 { 536 compatible = "arm,coresight-cp 536 compatible = "arm,coresight-cpu-debug", "arm,primecell"; 537 reg = <0x0 0x23310000 0x0 0x10 537 reg = <0x0 0x23310000 0x0 0x1000>; 538 538 539 clocks = <&soc_smc50mhz>; 539 clocks = <&soc_smc50mhz>; 540 clock-names = "apb_pclk"; 540 clock-names = "apb_pclk"; 541 power-domains = <&scpi_devpd 0 541 power-domains = <&scpi_devpd 0>; 542 }; 542 }; 543 543 544 etm5: etm@23340000 { 544 etm5: etm@23340000 { 545 compatible = "arm,coresight-et 545 compatible = "arm,coresight-etm4x", "arm,primecell"; 546 reg = <0 0x23340000 0 0x1000>; 546 reg = <0 0x23340000 0 0x1000>; 547 547 548 clocks = <&soc_smc50mhz>; 548 clocks = <&soc_smc50mhz>; 549 clock-names = "apb_pclk"; 549 clock-names = "apb_pclk"; 550 power-domains = <&scpi_devpd 0 550 power-domains = <&scpi_devpd 0>; 551 out-ports { 551 out-ports { 552 port { 552 port { 553 cluster1_etm3_ 553 cluster1_etm3_out_port: endpoint { 554 remote 554 remote-endpoint = <&cluster1_funnel_in_port3>; 555 }; 555 }; 556 }; 556 }; 557 }; 557 }; 558 }; 558 }; 559 559 560 cti5: cti@23320000 { 560 cti5: cti@23320000 { 561 compatible = "arm,coresight-ct 561 compatible = "arm,coresight-cti-v8-arch", "arm,coresight-cti", 562 "arm,primecell"; 562 "arm,primecell"; 563 reg = <0 0x23320000 0 0x1000>; 563 reg = <0 0x23320000 0 0x1000>; 564 564 565 clocks = <&soc_smc50mhz>; 565 clocks = <&soc_smc50mhz>; 566 clock-names = "apb_pclk"; 566 clock-names = "apb_pclk"; 567 power-domains = <&scpi_devpd 0 567 power-domains = <&scpi_devpd 0>; 568 568 569 arm,cs-dev-assoc = <&etm5>; 569 arm,cs-dev-assoc = <&etm5>; 570 }; 570 }; 571 571 572 cti_sys0: cti@20020000 { /* sys_cti_0 572 cti_sys0: cti@20020000 { /* sys_cti_0 */ 573 compatible = "arm,coresight-ct 573 compatible = "arm,coresight-cti", "arm,primecell"; 574 reg = <0 0x20020000 0 0x1000>; 574 reg = <0 0x20020000 0 0x1000>; 575 575 576 clocks = <&soc_smc50mhz>; 576 clocks = <&soc_smc50mhz>; 577 clock-names = "apb_pclk"; 577 clock-names = "apb_pclk"; 578 power-domains = <&scpi_devpd 0 578 power-domains = <&scpi_devpd 0>; 579 579 580 #address-cells = <1>; 580 #address-cells = <1>; 581 #size-cells = <0>; 581 #size-cells = <0>; 582 582 583 trig-conns@0 { 583 trig-conns@0 { 584 reg = <0>; 584 reg = <0>; 585 arm,trig-in-sigs = <2 585 arm,trig-in-sigs = <2 3>; 586 arm,trig-in-types = <S 586 arm,trig-in-types = <SNK_FULL SNK_ACQCOMP>; 587 arm,trig-out-sigs = <0 587 arm,trig-out-sigs = <0 1>; 588 arm,trig-out-types = < 588 arm,trig-out-types = <SNK_FLUSHIN SNK_TRIGIN>; 589 arm,cs-dev-assoc = <&e 589 arm,cs-dev-assoc = <&etr_sys>; 590 }; 590 }; 591 591 592 trig-conns@1 { 592 trig-conns@1 { 593 reg = <1>; 593 reg = <1>; 594 arm,trig-in-sigs = <0 594 arm,trig-in-sigs = <0 1>; 595 arm,trig-in-types = <S 595 arm,trig-in-types = <SNK_FULL SNK_ACQCOMP>; 596 arm,trig-out-sigs = <7 596 arm,trig-out-sigs = <7 6>; 597 arm,trig-out-types = < 597 arm,trig-out-types = <SNK_FLUSHIN SNK_TRIGIN>; 598 arm,cs-dev-assoc = <&e 598 arm,cs-dev-assoc = <&etf_sys0>; 599 }; 599 }; 600 600 601 trig-conns@2 { 601 trig-conns@2 { 602 reg = <2>; 602 reg = <2>; 603 arm,trig-in-sigs = <4 603 arm,trig-in-sigs = <4 5 6 7>; 604 arm,trig-in-types = <S 604 arm,trig-in-types = <STM_TOUT_SPTE STM_TOUT_SW 605 STM 605 STM_TOUT_HETE STM_ASYNCOUT>; 606 arm,trig-out-sigs = <4 606 arm,trig-out-sigs = <4 5>; 607 arm,trig-out-types = < 607 arm,trig-out-types = <STM_HWEVENT STM_HWEVENT>; 608 arm,cs-dev-assoc = <&s 608 arm,cs-dev-assoc = <&stm_sys>; 609 }; 609 }; 610 610 611 trig-conns@3 { 611 trig-conns@3 { 612 reg = <3>; 612 reg = <3>; 613 arm,trig-out-sigs = <2 613 arm,trig-out-sigs = <2 3>; 614 arm,trig-out-types = < 614 arm,trig-out-types = <SNK_FLUSHIN SNK_TRIGIN>; 615 arm,cs-dev-assoc = <&t 615 arm,cs-dev-assoc = <&tpiu_sys>; 616 }; 616 }; 617 }; 617 }; 618 618 619 cti_sys1: cti@20110000 { /* sys_cti_1 619 cti_sys1: cti@20110000 { /* sys_cti_1 */ 620 compatible = "arm,coresight-ct 620 compatible = "arm,coresight-cti", "arm,primecell"; 621 reg = <0 0x20110000 0 0x1000>; 621 reg = <0 0x20110000 0 0x1000>; 622 622 623 clocks = <&soc_smc50mhz>; 623 clocks = <&soc_smc50mhz>; 624 clock-names = "apb_pclk"; 624 clock-names = "apb_pclk"; 625 power-domains = <&scpi_devpd 0 625 power-domains = <&scpi_devpd 0>; 626 626 627 #address-cells = <1>; 627 #address-cells = <1>; 628 #size-cells = <0>; 628 #size-cells = <0>; 629 629 630 trig-conns@0 { 630 trig-conns@0 { 631 reg = <0>; 631 reg = <0>; 632 arm,trig-in-sigs = <0> 632 arm,trig-in-sigs = <0>; 633 arm,trig-in-types = <G 633 arm,trig-in-types = <GEN_INTREQ>; 634 arm,trig-out-sigs = <0 634 arm,trig-out-sigs = <0>; 635 arm,trig-out-types = < 635 arm,trig-out-types = <GEN_HALTREQ>; 636 arm,trig-conn-name = " 636 arm,trig-conn-name = "sys_profiler"; 637 }; 637 }; 638 638 639 trig-conns@1 { 639 trig-conns@1 { 640 reg = <1>; 640 reg = <1>; 641 arm,trig-out-sigs = <2 641 arm,trig-out-sigs = <2 3>; 642 arm,trig-out-types = < 642 arm,trig-out-types = <GEN_HALTREQ GEN_RESTARTREQ>; 643 arm,trig-conn-name = " 643 arm,trig-conn-name = "watchdog"; 644 }; 644 }; 645 645 646 trig-conns@2 { 646 trig-conns@2 { 647 reg = <2>; 647 reg = <2>; 648 arm,trig-out-sigs = <1 648 arm,trig-out-sigs = <1 6>; 649 arm,trig-out-types = < 649 arm,trig-out-types = <GEN_HALTREQ GEN_RESTARTREQ>; 650 arm,trig-conn-name = " 650 arm,trig-conn-name = "g_counter"; 651 }; 651 }; 652 }; 652 }; 653 653 654 gpu: gpu@2d000000 { 654 gpu: gpu@2d000000 { 655 compatible = "arm,juno-mali", 655 compatible = "arm,juno-mali", "arm,mali-t624"; 656 reg = <0 0x2d000000 0 0x10000> 656 reg = <0 0x2d000000 0 0x10000>; 657 interrupts = <GIC_SPI 33 IRQ_T 657 interrupts = <GIC_SPI 33 IRQ_TYPE_LEVEL_HIGH>, 658 <GIC_SPI 34 IRQ_T 658 <GIC_SPI 34 IRQ_TYPE_LEVEL_HIGH>, 659 <GIC_SPI 32 IRQ_T 659 <GIC_SPI 32 IRQ_TYPE_LEVEL_HIGH>; 660 interrupt-names = "job", "mmu" 660 interrupt-names = "job", "mmu", "gpu"; 661 clocks = <&scpi_dvfs 2>; 661 clocks = <&scpi_dvfs 2>; 662 power-domains = <&scpi_devpd 1 662 power-domains = <&scpi_devpd 1>; 663 dma-coherent; 663 dma-coherent; 664 /* The SMMU is only really of 664 /* The SMMU is only really of interest to bare-metal hypervisors */ 665 /* iommus = <&smmu_gpu 0>; */ 665 /* iommus = <&smmu_gpu 0>; */ 666 }; 666 }; 667 667 668 sram: sram@2e000000 { 668 sram: sram@2e000000 { 669 compatible = "arm,juno-sram-ns 669 compatible = "arm,juno-sram-ns", "mmio-sram"; 670 reg = <0x0 0x2e000000 0x0 0x80 670 reg = <0x0 0x2e000000 0x0 0x8000>; 671 671 672 #address-cells = <1>; 672 #address-cells = <1>; 673 #size-cells = <1>; 673 #size-cells = <1>; 674 ranges = <0 0x0 0x2e000000 0x8 674 ranges = <0 0x0 0x2e000000 0x8000>; 675 675 676 cpu_scp_lpri: scp-sram@0 { 676 cpu_scp_lpri: scp-sram@0 { 677 compatible = "arm,juno 677 compatible = "arm,juno-scp-shmem"; 678 reg = <0x0 0x200>; 678 reg = <0x0 0x200>; 679 }; 679 }; 680 680 681 cpu_scp_hpri: scp-sram@200 { 681 cpu_scp_hpri: scp-sram@200 { 682 compatible = "arm,juno 682 compatible = "arm,juno-scp-shmem"; 683 reg = <0x200 0x200>; 683 reg = <0x200 0x200>; 684 }; 684 }; 685 }; 685 }; 686 686 687 pcie_ctlr: pcie@40000000 { 687 pcie_ctlr: pcie@40000000 { 688 compatible = "arm,juno-r1-pcie 688 compatible = "arm,juno-r1-pcie", "plda,xpressrich3-axi", "pci-host-ecam-generic"; 689 device_type = "pci"; 689 device_type = "pci"; 690 reg = <0 0x40000000 0 0x100000 690 reg = <0 0x40000000 0 0x10000000>; /* ECAM config space */ 691 bus-range = <0 255>; 691 bus-range = <0 255>; 692 linux,pci-domain = <0>; 692 linux,pci-domain = <0>; 693 #address-cells = <3>; 693 #address-cells = <3>; 694 #size-cells = <2>; 694 #size-cells = <2>; 695 dma-coherent; 695 dma-coherent; 696 ranges = <0x01000000 0x00 0x00 696 ranges = <0x01000000 0x00 0x00000000 0x00 0x5f800000 0x0 0x00800000>, 697 <0x02000000 0x00 0x50 697 <0x02000000 0x00 0x50000000 0x00 0x50000000 0x0 0x08000000>, 698 <0x42000000 0x40 0x00 698 <0x42000000 0x40 0x00000000 0x40 0x00000000 0x1 0x00000000>; 699 /* Standard AXI Translation en 699 /* Standard AXI Translation entries as programmed by EDK2 */ 700 dma-ranges = <0x02000000 0x0 0 700 dma-ranges = <0x02000000 0x0 0x80000000 0x0 0x80000000 0x0 0x80000000>, 701 <0x43000000 0x8 0 701 <0x43000000 0x8 0x00000000 0x8 0x00000000 0x2 0x00000000>; 702 #interrupt-cells = <1>; 702 #interrupt-cells = <1>; 703 interrupt-map-mask = <0 0 0 7> 703 interrupt-map-mask = <0 0 0 7>; 704 interrupt-map = <0 0 0 1 &gic 704 interrupt-map = <0 0 0 1 &gic 0 GIC_SPI 136 IRQ_TYPE_LEVEL_HIGH>, 705 <0 0 0 2 &gic 705 <0 0 0 2 &gic 0 GIC_SPI 137 IRQ_TYPE_LEVEL_HIGH>, 706 <0 0 0 3 &gic 706 <0 0 0 3 &gic 0 GIC_SPI 138 IRQ_TYPE_LEVEL_HIGH>, 707 <0 0 0 4 &gic 707 <0 0 0 4 &gic 0 GIC_SPI 139 IRQ_TYPE_LEVEL_HIGH>; 708 msi-parent = <&v2m_0>; 708 msi-parent = <&v2m_0>; 709 status = "disabled"; 709 status = "disabled"; 710 iommu-map-mask = <0x0>; /* RC 710 iommu-map-mask = <0x0>; /* RC has no means to output PCI RID */ 711 iommu-map = <0x0 &smmu_pcie 0x 711 iommu-map = <0x0 &smmu_pcie 0x0 0x1>; 712 }; 712 }; 713 713 714 scpi { 714 scpi { 715 compatible = "arm,scpi"; 715 compatible = "arm,scpi"; 716 mboxes = <&mailbox 1>; 716 mboxes = <&mailbox 1>; 717 shmem = <&cpu_scp_hpri>; 717 shmem = <&cpu_scp_hpri>; 718 718 719 clocks { 719 clocks { 720 compatible = "arm,scpi 720 compatible = "arm,scpi-clocks"; 721 721 722 scpi_dvfs: clocks-0 { 722 scpi_dvfs: clocks-0 { 723 compatible = " 723 compatible = "arm,scpi-dvfs-clocks"; 724 #clock-cells = 724 #clock-cells = <1>; 725 clock-indices 725 clock-indices = <0>, <1>, <2>; 726 clock-output-n 726 clock-output-names = "atlclk", "aplclk","gpuclk"; 727 }; 727 }; 728 scpi_clk: clocks-1 { 728 scpi_clk: clocks-1 { 729 compatible = " 729 compatible = "arm,scpi-variable-clocks"; 730 #clock-cells = 730 #clock-cells = <1>; 731 clock-indices 731 clock-indices = <3>; 732 clock-output-n 732 clock-output-names = "pxlclk"; 733 }; 733 }; 734 }; 734 }; 735 735 736 scpi_devpd: power-controller { 736 scpi_devpd: power-controller { 737 compatible = "arm,scpi 737 compatible = "arm,scpi-power-domains"; 738 num-domains = <2>; 738 num-domains = <2>; 739 #power-domain-cells = 739 #power-domain-cells = <1>; 740 }; 740 }; 741 741 742 scpi_sensors0: sensors { 742 scpi_sensors0: sensors { 743 compatible = "arm,scpi 743 compatible = "arm,scpi-sensors"; 744 #thermal-sensor-cells 744 #thermal-sensor-cells = <1>; 745 }; 745 }; 746 }; 746 }; 747 747 748 thermal-zones { 748 thermal-zones { 749 pmic-thermal { 749 pmic-thermal { 750 polling-delay = <1000> 750 polling-delay = <1000>; 751 polling-delay-passive 751 polling-delay-passive = <100>; 752 thermal-sensors = <&sc 752 thermal-sensors = <&scpi_sensors0 0>; 753 trips { 753 trips { 754 pmic_crit0: tr 754 pmic_crit0: trip0 { 755 temper 755 temperature = <90000>; 756 hyster 756 hysteresis = <2000>; 757 type = 757 type = "critical"; 758 }; 758 }; 759 }; 759 }; 760 }; 760 }; 761 761 762 soc-thermal { 762 soc-thermal { 763 polling-delay = <1000> 763 polling-delay = <1000>; 764 polling-delay-passive 764 polling-delay-passive = <100>; 765 thermal-sensors = <&sc 765 thermal-sensors = <&scpi_sensors0 3>; 766 trips { 766 trips { 767 soc_crit0: tri 767 soc_crit0: trip0 { 768 temper 768 temperature = <80000>; 769 hyster 769 hysteresis = <2000>; 770 type = 770 type = "critical"; 771 }; 771 }; 772 }; 772 }; 773 }; 773 }; 774 774 775 big_cluster_thermal_zone: big- 775 big_cluster_thermal_zone: big-cl-thermal { 776 polling-delay = <1000> 776 polling-delay = <1000>; 777 polling-delay-passive 777 polling-delay-passive = <100>; 778 thermal-sensors = <&sc 778 thermal-sensors = <&scpi_sensors0 21>; 779 status = "disabled"; 779 status = "disabled"; 780 }; 780 }; 781 781 782 little_cluster_thermal_zone: l 782 little_cluster_thermal_zone: little-cl-thermal { 783 polling-delay = <1000> 783 polling-delay = <1000>; 784 polling-delay-passive 784 polling-delay-passive = <100>; 785 thermal-sensors = <&sc 785 thermal-sensors = <&scpi_sensors0 22>; 786 status = "disabled"; 786 status = "disabled"; 787 }; 787 }; 788 788 789 gpu0_thermal_zone: gpu0-therma 789 gpu0_thermal_zone: gpu0-thermal { 790 polling-delay = <1000> 790 polling-delay = <1000>; 791 polling-delay-passive 791 polling-delay-passive = <100>; 792 thermal-sensors = <&sc 792 thermal-sensors = <&scpi_sensors0 23>; 793 status = "disabled"; 793 status = "disabled"; 794 }; 794 }; 795 795 796 gpu1_thermal_zone: gpu1-therma 796 gpu1_thermal_zone: gpu1-thermal { 797 polling-delay = <1000> 797 polling-delay = <1000>; 798 polling-delay-passive 798 polling-delay-passive = <100>; 799 thermal-sensors = <&sc 799 thermal-sensors = <&scpi_sensors0 24>; 800 status = "disabled"; 800 status = "disabled"; 801 }; 801 }; 802 }; 802 }; 803 803 804 smmu_dma: iommu@7fb00000 { 804 smmu_dma: iommu@7fb00000 { 805 compatible = "arm,mmu-401", "a 805 compatible = "arm,mmu-401", "arm,smmu-v1"; 806 reg = <0x0 0x7fb00000 0x0 0x10 806 reg = <0x0 0x7fb00000 0x0 0x10000>; 807 interrupts = <GIC_SPI 95 IRQ_T 807 interrupts = <GIC_SPI 95 IRQ_TYPE_LEVEL_HIGH>, 808 <GIC_SPI 95 IRQ_T 808 <GIC_SPI 95 IRQ_TYPE_LEVEL_HIGH>; 809 #iommu-cells = <1>; 809 #iommu-cells = <1>; 810 #global-interrupts = <1>; 810 #global-interrupts = <1>; 811 dma-coherent; 811 dma-coherent; 812 }; 812 }; 813 813 814 smmu_hdlcd1: iommu@7fb10000 { 814 smmu_hdlcd1: iommu@7fb10000 { 815 compatible = "arm,mmu-401", "a 815 compatible = "arm,mmu-401", "arm,smmu-v1"; 816 reg = <0x0 0x7fb10000 0x0 0x10 816 reg = <0x0 0x7fb10000 0x0 0x10000>; 817 interrupts = <GIC_SPI 99 IRQ_T 817 interrupts = <GIC_SPI 99 IRQ_TYPE_LEVEL_HIGH>, 818 <GIC_SPI 99 IRQ_T 818 <GIC_SPI 99 IRQ_TYPE_LEVEL_HIGH>; 819 #iommu-cells = <1>; 819 #iommu-cells = <1>; 820 #global-interrupts = <1>; 820 #global-interrupts = <1>; 821 }; 821 }; 822 822 823 smmu_hdlcd0: iommu@7fb20000 { 823 smmu_hdlcd0: iommu@7fb20000 { 824 compatible = "arm,mmu-401", "a 824 compatible = "arm,mmu-401", "arm,smmu-v1"; 825 reg = <0x0 0x7fb20000 0x0 0x10 825 reg = <0x0 0x7fb20000 0x0 0x10000>; 826 interrupts = <GIC_SPI 97 IRQ_T 826 interrupts = <GIC_SPI 97 IRQ_TYPE_LEVEL_HIGH>, 827 <GIC_SPI 97 IRQ_T 827 <GIC_SPI 97 IRQ_TYPE_LEVEL_HIGH>; 828 #iommu-cells = <1>; 828 #iommu-cells = <1>; 829 #global-interrupts = <1>; 829 #global-interrupts = <1>; 830 }; 830 }; 831 831 832 smmu_usb: iommu@7fb30000 { 832 smmu_usb: iommu@7fb30000 { 833 compatible = "arm,mmu-401", "a 833 compatible = "arm,mmu-401", "arm,smmu-v1"; 834 reg = <0x0 0x7fb30000 0x0 0x10 834 reg = <0x0 0x7fb30000 0x0 0x10000>; 835 interrupts = <GIC_SPI 101 IRQ_ 835 interrupts = <GIC_SPI 101 IRQ_TYPE_LEVEL_HIGH>, 836 <GIC_SPI 101 IRQ_ 836 <GIC_SPI 101 IRQ_TYPE_LEVEL_HIGH>; 837 #iommu-cells = <1>; 837 #iommu-cells = <1>; 838 #global-interrupts = <1>; 838 #global-interrupts = <1>; 839 dma-coherent; 839 dma-coherent; 840 }; 840 }; 841 841 842 dma-controller@7ff00000 { 842 dma-controller@7ff00000 { 843 compatible = "arm,pl330", "arm 843 compatible = "arm,pl330", "arm,primecell"; 844 reg = <0x0 0x7ff00000 0 0x1000 844 reg = <0x0 0x7ff00000 0 0x1000>; 845 #dma-cells = <1>; 845 #dma-cells = <1>; 846 interrupts = <GIC_SPI 88 IRQ_T 846 interrupts = <GIC_SPI 88 IRQ_TYPE_LEVEL_HIGH>, 847 <GIC_SPI 89 IRQ_T 847 <GIC_SPI 89 IRQ_TYPE_LEVEL_HIGH>, 848 <GIC_SPI 90 IRQ_T 848 <GIC_SPI 90 IRQ_TYPE_LEVEL_HIGH>, 849 <GIC_SPI 91 IRQ_T 849 <GIC_SPI 91 IRQ_TYPE_LEVEL_HIGH>, 850 <GIC_SPI 92 IRQ_T 850 <GIC_SPI 92 IRQ_TYPE_LEVEL_HIGH>, 851 <GIC_SPI 108 IRQ_ 851 <GIC_SPI 108 IRQ_TYPE_LEVEL_HIGH>, 852 <GIC_SPI 109 IRQ_ 852 <GIC_SPI 109 IRQ_TYPE_LEVEL_HIGH>, 853 <GIC_SPI 110 IRQ_ 853 <GIC_SPI 110 IRQ_TYPE_LEVEL_HIGH>, 854 <GIC_SPI 111 IRQ_ 854 <GIC_SPI 111 IRQ_TYPE_LEVEL_HIGH>; 855 iommus = <&smmu_dma 0>, 855 iommus = <&smmu_dma 0>, 856 <&smmu_dma 1>, 856 <&smmu_dma 1>, 857 <&smmu_dma 2>, 857 <&smmu_dma 2>, 858 <&smmu_dma 3>, 858 <&smmu_dma 3>, 859 <&smmu_dma 4>, 859 <&smmu_dma 4>, 860 <&smmu_dma 5>, 860 <&smmu_dma 5>, 861 <&smmu_dma 6>, 861 <&smmu_dma 6>, 862 <&smmu_dma 7>, 862 <&smmu_dma 7>, 863 <&smmu_dma 8>; 863 <&smmu_dma 8>; 864 clocks = <&soc_faxiclk>; 864 clocks = <&soc_faxiclk>; 865 clock-names = "apb_pclk"; 865 clock-names = "apb_pclk"; 866 }; 866 }; 867 867 868 hdlcd@7ff50000 { 868 hdlcd@7ff50000 { 869 compatible = "arm,hdlcd"; 869 compatible = "arm,hdlcd"; 870 reg = <0 0x7ff50000 0 0x1000>; 870 reg = <0 0x7ff50000 0 0x1000>; 871 interrupts = <GIC_SPI 93 IRQ_T 871 interrupts = <GIC_SPI 93 IRQ_TYPE_LEVEL_HIGH>; 872 iommus = <&smmu_hdlcd1 0>; 872 iommus = <&smmu_hdlcd1 0>; 873 clocks = <&scpi_clk 3>; 873 clocks = <&scpi_clk 3>; 874 clock-names = "pxlclk"; 874 clock-names = "pxlclk"; 875 875 876 port { 876 port { 877 hdlcd1_output: endpoin 877 hdlcd1_output: endpoint { 878 remote-endpoin 878 remote-endpoint = <&tda998x_1_input>; 879 }; 879 }; 880 }; 880 }; 881 }; 881 }; 882 882 883 hdlcd@7ff60000 { 883 hdlcd@7ff60000 { 884 compatible = "arm,hdlcd"; 884 compatible = "arm,hdlcd"; 885 reg = <0 0x7ff60000 0 0x1000>; 885 reg = <0 0x7ff60000 0 0x1000>; 886 interrupts = <GIC_SPI 85 IRQ_T 886 interrupts = <GIC_SPI 85 IRQ_TYPE_LEVEL_HIGH>; 887 iommus = <&smmu_hdlcd0 0>; 887 iommus = <&smmu_hdlcd0 0>; 888 clocks = <&scpi_clk 3>; 888 clocks = <&scpi_clk 3>; 889 clock-names = "pxlclk"; 889 clock-names = "pxlclk"; 890 890 891 port { 891 port { 892 hdlcd0_output: endpoin 892 hdlcd0_output: endpoint { 893 remote-endpoin 893 remote-endpoint = <&tda998x_0_input>; 894 }; 894 }; 895 }; 895 }; 896 }; 896 }; 897 897 898 soc_uart0: serial@7ff80000 { 898 soc_uart0: serial@7ff80000 { 899 compatible = "arm,pl011", "arm 899 compatible = "arm,pl011", "arm,primecell"; 900 reg = <0x0 0x7ff80000 0x0 0x10 900 reg = <0x0 0x7ff80000 0x0 0x1000>; 901 interrupts = <GIC_SPI 83 IRQ_T 901 interrupts = <GIC_SPI 83 IRQ_TYPE_LEVEL_HIGH>; 902 clocks = <&soc_uartclk>, <&soc 902 clocks = <&soc_uartclk>, <&soc_refclk100mhz>; 903 clock-names = "uartclk", "apb_ 903 clock-names = "uartclk", "apb_pclk"; 904 }; 904 }; 905 905 906 i2c@7ffa0000 { 906 i2c@7ffa0000 { 907 compatible = "snps,designware- 907 compatible = "snps,designware-i2c"; 908 reg = <0x0 0x7ffa0000 0x0 0x10 908 reg = <0x0 0x7ffa0000 0x0 0x1000>; 909 #address-cells = <1>; 909 #address-cells = <1>; 910 #size-cells = <0>; 910 #size-cells = <0>; 911 interrupts = <GIC_SPI 104 IRQ_ 911 interrupts = <GIC_SPI 104 IRQ_TYPE_LEVEL_HIGH>; 912 clock-frequency = <400000>; 912 clock-frequency = <400000>; 913 i2c-sda-hold-time-ns = <500>; 913 i2c-sda-hold-time-ns = <500>; 914 clocks = <&soc_smc50mhz>; 914 clocks = <&soc_smc50mhz>; 915 915 916 hdmi-transmitter@70 { 916 hdmi-transmitter@70 { 917 compatible = "nxp,tda9 917 compatible = "nxp,tda998x"; 918 reg = <0x70>; 918 reg = <0x70>; 919 port { 919 port { 920 tda998x_0_inpu 920 tda998x_0_input: endpoint { 921 remote 921 remote-endpoint = <&hdlcd0_output>; 922 }; 922 }; 923 }; 923 }; 924 }; 924 }; 925 925 926 hdmi-transmitter@71 { 926 hdmi-transmitter@71 { 927 compatible = "nxp,tda9 927 compatible = "nxp,tda998x"; 928 reg = <0x71>; 928 reg = <0x71>; 929 port { 929 port { 930 tda998x_1_inpu 930 tda998x_1_input: endpoint { 931 remote 931 remote-endpoint = <&hdlcd1_output>; 932 }; 932 }; 933 }; 933 }; 934 }; 934 }; 935 }; 935 }; 936 936 937 usb@7ffb0000 { 937 usb@7ffb0000 { 938 compatible = "generic-ohci"; 938 compatible = "generic-ohci"; 939 reg = <0x0 0x7ffb0000 0x0 0x10 939 reg = <0x0 0x7ffb0000 0x0 0x10000>; 940 interrupts = <GIC_SPI 116 IRQ_ 940 interrupts = <GIC_SPI 116 IRQ_TYPE_LEVEL_HIGH>; 941 iommus = <&smmu_usb 0>; 941 iommus = <&smmu_usb 0>; 942 clocks = <&soc_usb48mhz>; 942 clocks = <&soc_usb48mhz>; 943 }; 943 }; 944 944 945 usb@7ffc0000 { 945 usb@7ffc0000 { 946 compatible = "generic-ehci"; 946 compatible = "generic-ehci"; 947 reg = <0x0 0x7ffc0000 0x0 0x10 947 reg = <0x0 0x7ffc0000 0x0 0x10000>; 948 interrupts = <GIC_SPI 117 IRQ_ 948 interrupts = <GIC_SPI 117 IRQ_TYPE_LEVEL_HIGH>; 949 iommus = <&smmu_usb 0>; 949 iommus = <&smmu_usb 0>; 950 clocks = <&soc_usb48mhz>; 950 clocks = <&soc_usb48mhz>; 951 }; 951 }; 952 952 953 memory-controller@7ffd0000 { 953 memory-controller@7ffd0000 { 954 compatible = "arm,pl354", "arm 954 compatible = "arm,pl354", "arm,primecell"; 955 reg = <0 0x7ffd0000 0 0x1000>; 955 reg = <0 0x7ffd0000 0 0x1000>; 956 interrupts = <GIC_SPI 86 IRQ_T 956 interrupts = <GIC_SPI 86 IRQ_TYPE_LEVEL_HIGH>, 957 <GIC_SPI 87 IRQ_T 957 <GIC_SPI 87 IRQ_TYPE_LEVEL_HIGH>; 958 clocks = <&soc_smc50mhz>; 958 clocks = <&soc_smc50mhz>; 959 clock-names = "apb_pclk"; 959 clock-names = "apb_pclk"; 960 }; 960 }; 961 961 962 memory@80000000 { 962 memory@80000000 { 963 device_type = "memory"; 963 device_type = "memory"; 964 /* last 16MB of the first memo 964 /* last 16MB of the first memory area is reserved for secure world use by firmware */ 965 reg = <0x00000000 0x80000000 0 965 reg = <0x00000000 0x80000000 0x0 0x7f000000>, 966 <0x00000008 0x80000000 0 966 <0x00000008 0x80000000 0x1 0x80000000>; 967 }; 967 }; 968 968 969 bus@8000000 { 969 bus@8000000 { 970 #interrupt-cells = <1>; 970 #interrupt-cells = <1>; 971 interrupt-map-mask = <0 0 15>; 971 interrupt-map-mask = <0 0 15>; 972 interrupt-map = <0 0 0 &gic 0 972 interrupt-map = <0 0 0 &gic 0 GIC_SPI 68 IRQ_TYPE_LEVEL_HIGH>, 973 <0 0 1 &gic 0 973 <0 0 1 &gic 0 GIC_SPI 69 IRQ_TYPE_LEVEL_HIGH>, 974 <0 0 2 &gic 0 974 <0 0 2 &gic 0 GIC_SPI 70 IRQ_TYPE_LEVEL_HIGH>, 975 <0 0 3 &gic 0 975 <0 0 3 &gic 0 GIC_SPI 160 IRQ_TYPE_LEVEL_HIGH>, 976 <0 0 4 &gic 0 976 <0 0 4 &gic 0 GIC_SPI 161 IRQ_TYPE_LEVEL_HIGH>, 977 <0 0 5 &gic 0 977 <0 0 5 &gic 0 GIC_SPI 162 IRQ_TYPE_LEVEL_HIGH>, 978 <0 0 6 &gic 0 978 <0 0 6 &gic 0 GIC_SPI 163 IRQ_TYPE_LEVEL_HIGH>, 979 <0 0 7 &gic 0 979 <0 0 7 &gic 0 GIC_SPI 164 IRQ_TYPE_LEVEL_HIGH>, 980 <0 0 8 &gic 0 980 <0 0 8 &gic 0 GIC_SPI 165 IRQ_TYPE_LEVEL_HIGH>, 981 <0 0 9 &gic 0 981 <0 0 9 &gic 0 GIC_SPI 166 IRQ_TYPE_LEVEL_HIGH>, 982 <0 0 10 &gic 0 982 <0 0 10 &gic 0 GIC_SPI 167 IRQ_TYPE_LEVEL_HIGH>, 983 <0 0 11 &gic 0 983 <0 0 11 &gic 0 GIC_SPI 168 IRQ_TYPE_LEVEL_HIGH>, 984 <0 0 12 &gic 0 984 <0 0 12 &gic 0 GIC_SPI 169 IRQ_TYPE_LEVEL_HIGH>; 985 }; 985 }; 986 986 987 site2: tlx-bus@60000000 { 987 site2: tlx-bus@60000000 { 988 compatible = "simple-bus"; 988 compatible = "simple-bus"; 989 #address-cells = <1>; 989 #address-cells = <1>; 990 #size-cells = <1>; 990 #size-cells = <1>; 991 ranges = <0 0 0x60000000 0x100 991 ranges = <0 0 0x60000000 0x10000000>; 992 #interrupt-cells = <1>; 992 #interrupt-cells = <1>; 993 interrupt-map-mask = <0 0>; 993 interrupt-map-mask = <0 0>; 994 interrupt-map = <0 0 &gic 0 GI 994 interrupt-map = <0 0 &gic 0 GIC_SPI 168 IRQ_TYPE_LEVEL_HIGH>; 995 }; 995 }; 996 }; 996 };
Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.