Linux kernel mirror (for testing) git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
kernel os linux

ARM: dts: Add dts files for exynos4415 SoC

This patch adds new exynos4415.dtsi to support Exynos4415 SoC
based on Cortex-A9 quad cores and includes following dt nodes:

- GIC interrupt controller (GIC-400)
- Pinctrl to control three GPIO parts
- CMU (Clock Management Unit) for CMU/CMU_DMC/AUDSS
- CPU information (Cortex-A9 quad cores)
- UART to support serial port
- MCT (Multi Core Timer)
- ADC (Analog Digital Converter)
- RTC (Real Time Clock)
- I2C/SPI busses
- Power domains (CAM, TV, MFC, G3D, LCD0, ISP0/1)
- PMU (Performance Monitoring Unit)
- MSHC (Mobile Storage Host Controller)
- EHCI (Enhanced Host Controller Interface)
- OHIC (Open Host Controller Interface)
- USB 2.0 device with hsotg
- PWM (Pluse Width Modulation) Timer
- AMBA bus for PDMA0/1
- SYSRAM node for memory mapping
- SYSREG node for memory mapping
- PMU (Power Management Unit) node for memory mapping

Cc: Ben Dooks <ben-linux@fluff.org>
Cc: Russell King <linux@arm.linux.org.uk>
Cc: Mark Rutland <mark.rutland@arm.com>
Cc: Olof Johansson <olof@lixom.net>
Cc: Arnd Bergmann <arnd@arndb.de>
Signed-off-by: Chanwoo Choi <cw00.choi@samsung.com>
Signed-off-by: Seung-Woo Kim <sw0312.kim@samsung.com>
[m.szyprowski: Add OHCI node and correct EHCI node]
Signed-off-by: Marek Szyprowski <m.szyprowski@samsung.com>
[yj44.cho: Add mipi-phy node]
Signed-off-by: YoungJun Cho <yj44.cho@samsung.com>
[jaewon02: Add EHCI and SPI_2 node]
Signed-off-by: Jaewon Kim <jaewon02.kim@samsung.com>
[ideal.song: Add I2S0 node for audio interface]
Signed-off-by: Inha Song <ideal.song@samsung.com>
[tomasz.figa: Add L2 cache node]
Signed-off-by: Tomasz Figa <tomasz.figa@gmail.com>
Acked-by: Kyungmin Park <kyungmin.park@samsung.com>
Signed-off-by: Kukjin Kim <kgene.kim@samsung.com>

authored by

Chanwoo Choi and committed by
Kukjin Kim
9246e7ff b9d7fdac

+1177
+573
arch/arm/boot/dts/exynos4415-pinctrl.dtsi
··· 1 + /* 2 + * Samsung's Exynos4415 SoCs pin-mux and pin-config device tree source 3 + * 4 + * Copyright (c) 2014 Samsung Electronics Co., Ltd. 5 + * 6 + * Samsung's Exynos4415 SoCs pin-mux and pin-config optiosn are listed as device 7 + * tree nodes are listed in this file. 8 + * 9 + * This program is free software; you can redistribute it and/or modify 10 + * it under the terms of the GNU General Public License version 2 as 11 + * published by the Free Software Foundation. 12 + */ 13 + 14 + &pinctrl_0 { 15 + gpa0: gpa0 { 16 + gpio-controller; 17 + #gpio-cells = <2>; 18 + 19 + interrupt-controller; 20 + #interrupt-cells = <2>; 21 + }; 22 + 23 + gpa1: gpa1 { 24 + gpio-controller; 25 + #gpio-cells = <2>; 26 + 27 + interrupt-controller; 28 + #interrupt-cells = <2>; 29 + }; 30 + 31 + gpb: gpb { 32 + gpio-controller; 33 + #gpio-cells = <2>; 34 + 35 + interrupt-controller; 36 + #interrupt-cells = <2>; 37 + }; 38 + 39 + gpc0: gpc0 { 40 + gpio-controller; 41 + #gpio-cells = <2>; 42 + 43 + interrupt-controller; 44 + #interrupt-cells = <2>; 45 + }; 46 + 47 + gpc1: gpc1 { 48 + gpio-controller; 49 + #gpio-cells = <2>; 50 + 51 + interrupt-controller; 52 + #interrupt-cells = <2>; 53 + }; 54 + 55 + gpd0: gpd0 { 56 + gpio-controller; 57 + #gpio-cells = <2>; 58 + 59 + interrupt-controller; 60 + #interrupt-cells = <2>; 61 + }; 62 + 63 + gpd1: gpd1 { 64 + gpio-controller; 65 + #gpio-cells = <2>; 66 + 67 + interrupt-controller; 68 + #interrupt-cells = <2>; 69 + }; 70 + 71 + gpf0: gpf0 { 72 + gpio-controller; 73 + #gpio-cells = <2>; 74 + 75 + interrupt-controller; 76 + #interrupt-cells = <2>; 77 + }; 78 + 79 + gpf1: gpf1 { 80 + gpio-controller; 81 + #gpio-cells = <2>; 82 + 83 + interrupt-controller; 84 + #interrupt-cells = <2>; 85 + }; 86 + 87 + gpf2: gpf2 { 88 + gpio-controller; 89 + #gpio-cells = <2>; 90 + 91 + interrupt-controller; 92 + #interrupt-cells = <2>; 93 + }; 94 + 95 + uart0_data: uart0-data { 96 + samsung,pins = "gpa0-0", "gpa0-1"; 97 + samsung,pin-function = <0x2>; 98 + samsung,pin-pud = <0>; 99 + samsung,pin-drv = <0>; 100 + }; 101 + 102 + uart0_fctl: uart0-fctl { 103 + samsung,pins = "gpa0-2", "gpa0-3"; 104 + samsung,pin-function = <2>; 105 + samsung,pin-pud = <0>; 106 + samsung,pin-drv = <0>; 107 + }; 108 + 109 + uart1_data: uart1-data { 110 + samsung,pins = "gpa0-4", "gpa0-5"; 111 + samsung,pin-function = <2>; 112 + samsung,pin-pud = <0>; 113 + samsung,pin-drv = <0>; 114 + }; 115 + 116 + uart1_fctl: uart1-fctl { 117 + samsung,pins = "gpa0-6", "gpa0-7"; 118 + samsung,pin-function = <2>; 119 + samsung,pin-pud = <0>; 120 + samsung,pin-drv = <0>; 121 + }; 122 + 123 + uart2_data: uart2-data { 124 + samsung,pins = "gpa1-0", "gpa1-1"; 125 + samsung,pin-function = <2>; 126 + samsung,pin-pud = <0>; 127 + samsung,pin-drv = <0>; 128 + }; 129 + 130 + uart2_fctl: uart2-fctl { 131 + samsung,pins = "gpa1-2", "gpa1-3"; 132 + samsung,pin-function = <2>; 133 + samsung,pin-pud = <0>; 134 + samsung,pin-drv = <0>; 135 + }; 136 + 137 + uart3_data: uart3-data { 138 + samsung,pins = "gpa1-4", "gpa1-5"; 139 + samsung,pin-function = <2>; 140 + samsung,pin-pud = <0>; 141 + samsung,pin-drv = <0>; 142 + }; 143 + 144 + i2c2_bus: i2c2-bus { 145 + samsung,pins = "gpa0-6", "gpa0-7"; 146 + samsung,pin-function = <3>; 147 + samsung,pin-pud = <3>; 148 + samsung,pin-drv = <0>; 149 + }; 150 + 151 + i2c3_bus: i2c3-bus { 152 + samsung,pins = "gpa1-2", "gpa1-3"; 153 + samsung,pin-function = <3>; 154 + samsung,pin-pud = <3>; 155 + samsung,pin-drv = <0>; 156 + }; 157 + 158 + spi0_bus: spi0-bus { 159 + samsung,pins = "gpb-0", "gpb-2", "gpb-3"; 160 + samsung,pin-function = <2>; 161 + samsung,pin-pud = <3>; 162 + samsung,pin-drv = <0>; 163 + }; 164 + 165 + i2c4_bus: i2c4-bus { 166 + samsung,pins = "gpb-0", "gpb-1"; 167 + samsung,pin-function = <3>; 168 + samsung,pin-pud = <3>; 169 + samsung,pin-drv = <0>; 170 + }; 171 + 172 + spi1_bus: spi1-bus { 173 + samsung,pins = "gpb-4", "gpb-6", "gpb-7"; 174 + samsung,pin-function = <2>; 175 + samsung,pin-pud = <3>; 176 + samsung,pin-drv = <0>; 177 + }; 178 + 179 + i2c5_bus: i2c5-bus { 180 + samsung,pins = "gpb-2", "gpb-3"; 181 + samsung,pin-function = <3>; 182 + samsung,pin-pud = <3>; 183 + samsung,pin-drv = <0>; 184 + }; 185 + 186 + i2s1_bus: i2s1-bus { 187 + samsung,pins = "gpc0-0", "gpc0-1", "gpc0-2", "gpc0-3", 188 + "gpc0-4"; 189 + samsung,pin-function = <2>; 190 + samsung,pin-pud = <0>; 191 + samsung,pin-drv = <0>; 192 + }; 193 + 194 + i2s2_bus: i2s2-bus { 195 + samsung,pins = "gpc1-0", "gpc1-1", "gpc1-2", "gpc1-3", 196 + "gpc1-4"; 197 + samsung,pin-function = <2>; 198 + samsung,pin-pud = <0>; 199 + samsung,pin-drv = <0>; 200 + }; 201 + 202 + pcm2_bus: pcm2-bus { 203 + samsung,pins = "gpc1-0", "gpc1-1", "gpc1-2", "gpc1-3", 204 + "gpc1-4"; 205 + samsung,pin-function = <3>; 206 + samsung,pin-pud = <0>; 207 + samsung,pin-drv = <0>; 208 + }; 209 + 210 + i2c6_bus: i2c6-bus { 211 + samsung,pins = "gpc1-3", "gpc1-4"; 212 + samsung,pin-function = <4>; 213 + samsung,pin-pud = <3>; 214 + samsung,pin-drv = <0>; 215 + }; 216 + 217 + spi2_bus: spi2-bus { 218 + samsung,pins = "gpc1-1", "gpc1-3", "gpc1-4"; 219 + samsung,pin-function = <5>; 220 + samsung,pin-pud = <3>; 221 + samsung,pin-drv = <0>; 222 + }; 223 + 224 + pwm0_out: pwm0-out { 225 + samsung,pins = "gpd0-0"; 226 + samsung,pin-function = <2>; 227 + samsung,pin-pud = <0>; 228 + samsung,pin-drv = <0>; 229 + }; 230 + 231 + pwm1_out: pwm1-out { 232 + samsung,pins = "gpd0-1"; 233 + samsung,pin-function = <2>; 234 + samsung,pin-pud = <0>; 235 + samsung,pin-drv = <0>; 236 + }; 237 + 238 + pwm2_out: pwm2-out { 239 + samsung,pins = "gpd0-2"; 240 + samsung,pin-function = <2>; 241 + samsung,pin-pud = <0>; 242 + samsung,pin-drv = <0>; 243 + }; 244 + 245 + pwm3_out: pwm3-out { 246 + samsung,pins = "gpd0-3"; 247 + samsung,pin-function = <2>; 248 + samsung,pin-pud = <0>; 249 + samsung,pin-drv = <0>; 250 + }; 251 + 252 + i2c7_bus: i2c7-bus { 253 + samsung,pins = "gpd0-2", "gpd0-3"; 254 + samsung,pin-function = <3>; 255 + samsung,pin-pud = <3>; 256 + samsung,pin-drv = <0>; 257 + }; 258 + 259 + i2c0_bus: i2c0-bus { 260 + samsung,pins = "gpd1-0", "gpd1-1"; 261 + samsung,pin-function = <2>; 262 + samsung,pin-pud = <3>; 263 + samsung,pin-drv = <0>; 264 + }; 265 + 266 + i2c1_bus: i2c1-bus { 267 + samsung,pins = "gpd1-2", "gpd1-3"; 268 + samsung,pin-function = <2>; 269 + samsung,pin-pud = <3>; 270 + samsung,pin-drv = <0>; 271 + }; 272 + }; 273 + 274 + &pinctrl_1 { 275 + gpk0: gpk0 { 276 + gpio-controller; 277 + #gpio-cells = <2>; 278 + 279 + interrupt-controller; 280 + #interrupt-cells = <2>; 281 + }; 282 + 283 + gpk1: gpk1 { 284 + gpio-controller; 285 + #gpio-cells = <2>; 286 + 287 + interrupt-controller; 288 + #interrupt-cells = <2>; 289 + }; 290 + 291 + gpk2: gpk2 { 292 + gpio-controller; 293 + #gpio-cells = <2>; 294 + 295 + interrupt-controller; 296 + #interrupt-cells = <2>; 297 + }; 298 + 299 + gpk3: gpk3 { 300 + gpio-controller; 301 + #gpio-cells = <2>; 302 + 303 + interrupt-controller; 304 + #interrupt-cells = <2>; 305 + }; 306 + 307 + gpl0: gpl0 { 308 + gpio-controller; 309 + #gpio-cells = <2>; 310 + 311 + interrupt-controller; 312 + #interrupt-cells = <2>; 313 + }; 314 + 315 + gpm0: gpm0 { 316 + gpio-controller; 317 + #gpio-cells = <2>; 318 + 319 + interrupt-controller; 320 + #interrupt-cells = <2>; 321 + }; 322 + 323 + gpm1: gpm1 { 324 + gpio-controller; 325 + #gpio-cells = <2>; 326 + 327 + interrupt-controller; 328 + #interrupt-cells = <2>; 329 + }; 330 + 331 + gpm2: gpm2 { 332 + gpio-controller; 333 + #gpio-cells = <2>; 334 + 335 + interrupt-controller; 336 + #interrupt-cells = <2>; 337 + }; 338 + 339 + gpm3: gpm3 { 340 + gpio-controller; 341 + #gpio-cells = <2>; 342 + 343 + interrupt-controller; 344 + #interrupt-cells = <2>; 345 + }; 346 + 347 + gpm4: gpm4 { 348 + gpio-controller; 349 + #gpio-cells = <2>; 350 + 351 + interrupt-controller; 352 + #interrupt-cells = <2>; 353 + }; 354 + 355 + gpx0: gpx0 { 356 + gpio-controller; 357 + #gpio-cells = <2>; 358 + 359 + interrupt-controller; 360 + interrupt-parent = <&gic>; 361 + interrupts = <0 32 0>, <0 33 0>, <0 34 0>, <0 35 0>, 362 + <0 36 0>, <0 37 0>, <0 38 0>, <0 39 0>; 363 + #interrupt-cells = <2>; 364 + }; 365 + 366 + gpx1: gpx1 { 367 + gpio-controller; 368 + #gpio-cells = <2>; 369 + 370 + interrupt-controller; 371 + interrupt-parent = <&gic>; 372 + interrupts = <0 40 0>, <0 41 0>, <0 42 0>, <0 43 0>, 373 + <0 44 0>, <0 45 0>, <0 46 0>, <0 47 0>; 374 + #interrupt-cells = <2>; 375 + }; 376 + 377 + gpx2: gpx2 { 378 + gpio-controller; 379 + #gpio-cells = <2>; 380 + 381 + interrupt-controller; 382 + #interrupt-cells = <2>; 383 + }; 384 + 385 + gpx3: gpx3 { 386 + gpio-controller; 387 + #gpio-cells = <2>; 388 + 389 + interrupt-controller; 390 + #interrupt-cells = <2>; 391 + }; 392 + 393 + sd0_clk: sd0-clk { 394 + samsung,pins = "gpk0-0"; 395 + samsung,pin-function = <2>; 396 + samsung,pin-pud = <0>; 397 + samsung,pin-drv = <3>; 398 + }; 399 + 400 + sd0_cmd: sd0-cmd { 401 + samsung,pins = "gpk0-1"; 402 + samsung,pin-function = <2>; 403 + samsung,pin-pud = <0>; 404 + samsung,pin-drv = <3>; 405 + }; 406 + 407 + sd0_cd: sd0-cd { 408 + samsung,pins = "gpk0-2"; 409 + samsung,pin-function = <2>; 410 + samsung,pin-pud = <3>; 411 + samsung,pin-drv = <3>; 412 + }; 413 + 414 + sd0_rdqs: sd0-rdqs { 415 + samsung,pins = "gpk0-7"; 416 + samsung,pin-function = <2>; 417 + samsung,pin-pud = <0>; 418 + samsung,pin-drv = <3>; 419 + }; 420 + 421 + sd0_bus1: sd0-bus-width1 { 422 + samsung,pins = "gpk0-3"; 423 + samsung,pin-function = <2>; 424 + samsung,pin-pud = <3>; 425 + samsung,pin-drv = <3>; 426 + }; 427 + 428 + sd0_bus4: sd0-bus-width4 { 429 + samsung,pins = "gpk0-4", "gpk0-5", "gpk0-6"; 430 + samsung,pin-function = <2>; 431 + samsung,pin-pud = <3>; 432 + samsung,pin-drv = <3>; 433 + }; 434 + 435 + sd0_bus8: sd0-bus-width8 { 436 + samsung,pins = "gpl0-0", "gpl0-1", "gpl0-2", "gpl0-3"; 437 + samsung,pin-function = <2>; 438 + samsung,pin-pud = <3>; 439 + samsung,pin-drv = <3>; 440 + }; 441 + 442 + sd1_clk: sd1-clk { 443 + samsung,pins = "gpk1-0"; 444 + samsung,pin-function = <2>; 445 + samsung,pin-pud = <0>; 446 + samsung,pin-drv = <3>; 447 + }; 448 + 449 + sd1_cmd: sd1-cmd { 450 + samsung,pins = "gpk1-1"; 451 + samsung,pin-function = <2>; 452 + samsung,pin-pud = <0>; 453 + samsung,pin-drv = <3>; 454 + }; 455 + 456 + sd1_cd: sd1-cd { 457 + samsung,pins = "gpk1-2"; 458 + samsung,pin-function = <2>; 459 + samsung,pin-pud = <3>; 460 + samsung,pin-drv = <3>; 461 + }; 462 + 463 + sd1_bus1: sd1-bus-width1 { 464 + samsung,pins = "gpk1-3"; 465 + samsung,pin-function = <2>; 466 + samsung,pin-pud = <3>; 467 + samsung,pin-drv = <3>; 468 + }; 469 + 470 + sd1_bus4: sd1-bus-width4 { 471 + samsung,pins = "gpk1-4", "gpk1-5", "gpk1-6"; 472 + samsung,pin-function = <2>; 473 + samsung,pin-pud = <3>; 474 + samsung,pin-drv = <3>; 475 + }; 476 + 477 + sd2_clk: sd2-clk { 478 + samsung,pins = "gpk2-0"; 479 + samsung,pin-function = <2>; 480 + samsung,pin-pud = <0>; 481 + samsung,pin-drv = <4>; 482 + }; 483 + 484 + sd2_cmd: sd2-cmd { 485 + samsung,pins = "gpk2-1"; 486 + samsung,pin-function = <2>; 487 + samsung,pin-pud = <0>; 488 + samsung,pin-drv = <4>; 489 + }; 490 + 491 + sd2_cd: sd2-cd { 492 + samsung,pins = "gpk2-2"; 493 + samsung,pin-function = <2>; 494 + samsung,pin-pud = <3>; 495 + samsung,pin-drv = <3>; 496 + }; 497 + 498 + sd2_bus1: sd2-bus-width1 { 499 + samsung,pins = "gpk2-3"; 500 + samsung,pin-function = <2>; 501 + samsung,pin-pud = <3>; 502 + samsung,pin-drv = <4>; 503 + }; 504 + 505 + sd2_bus4: sd2-bus-width4 { 506 + samsung,pins = "gpk2-4", "gpk2-5", "gpk2-6"; 507 + samsung,pin-function = <2>; 508 + samsung,pin-pud = <3>; 509 + samsung,pin-drv = <4>; 510 + }; 511 + 512 + cam_port_b_io: cam-port-b-io { 513 + samsung,pins = "gpm0-0", "gpm0-1", "gpm0-2", "gpm0-3", 514 + "gpm0-4", "gpm0-5", "gpm0-6", "gpm0-7", 515 + "gpm1-0", "gpm1-1", "gpm2-0", "gpm2-1"; 516 + samsung,pin-function = <3>; 517 + samsung,pin-pud = <3>; 518 + samsung,pin-drv = <0>; 519 + }; 520 + 521 + cam_port_b_clk_active: cam-port-b-clk-active { 522 + samsung,pins = "gpm2-2"; 523 + samsung,pin-function = <3>; 524 + samsung,pin-pud = <0>; 525 + samsung,pin-drv = <3>; 526 + }; 527 + 528 + cam_port_b_clk_idle: cam-port-b-clk-idle { 529 + samsung,pins = "gpm2-2"; 530 + samsung,pin-function = <0>; 531 + samsung,pin-pud = <0>; 532 + samsung,pin-drv = <0>; 533 + }; 534 + 535 + fimc_is_i2c0: fimc-is-i2c0 { 536 + samsung,pins = "gpm4-0", "gpm4-1"; 537 + samsung,pin-function = <2>; 538 + samsung,pin-pud = <0>; 539 + samsung,pin-drv = <0>; 540 + }; 541 + 542 + fimc_is_i2c1: fimc-is-i2c1 { 543 + samsung,pins = "gpm4-2", "gpm4-3"; 544 + samsung,pin-function = <2>; 545 + samsung,pin-pud = <0>; 546 + samsung,pin-drv = <0>; 547 + }; 548 + 549 + fimc_is_uart: fimc-is-uart { 550 + samsung,pins = "gpm3-5", "gpm3-7"; 551 + samsung,pin-function = <3>; 552 + samsung,pin-pud = <0>; 553 + samsung,pin-drv = <0>; 554 + }; 555 + }; 556 + 557 + &pinctrl_2 { 558 + gpz: gpz { 559 + gpio-controller; 560 + #gpio-cells = <2>; 561 + 562 + interrupt-controller; 563 + #interrupt-cells = <2>; 564 + }; 565 + 566 + i2s0_bus: i2s0-bus { 567 + samsung,pins = "gpz-0", "gpz-1", "gpz-2", "gpz-3", 568 + "gpz-4", "gpz-5", "gpz-6"; 569 + samsung,pin-function = <2>; 570 + samsung,pin-pud = <0>; 571 + samsung,pin-drv = <0>; 572 + }; 573 + };
+604
arch/arm/boot/dts/exynos4415.dtsi
··· 1 + /* 2 + * Samsung's Exynos4415 SoC device tree source 3 + * 4 + * Copyright (c) 2014 Samsung Electronics Co., Ltd. 5 + * 6 + * Samsung's Exynos4415 SoC device nodes are listed in this file. Exynos4415 7 + * based board files can include this file and provide values for board 8 + * specific bindings. 9 + * 10 + * Note: This file does not include device nodes for all the controllers in 11 + * Exynos4415 SoC. As device tree coverage for Exynos4415 increases, additional 12 + * nodes can be added to this file. 13 + * 14 + * This program is free software; you can redistribute it and/or modify 15 + * it under the terms of the GNU General Public License version 2 as 16 + * published by the Free Software Foundation. 17 + */ 18 + 19 + #include "skeleton.dtsi" 20 + #include <dt-bindings/clock/exynos4415.h> 21 + #include <dt-bindings/clock/exynos-audss-clk.h> 22 + 23 + / { 24 + compatible = "samsung,exynos4415"; 25 + interrupt-parent = <&gic>; 26 + 27 + aliases { 28 + pinctrl0 = &pinctrl_0; 29 + pinctrl1 = &pinctrl_1; 30 + pinctrl2 = &pinctrl_2; 31 + mshc0 = &mshc_0; 32 + mshc1 = &mshc_1; 33 + mshc2 = &mshc_2; 34 + spi0 = &spi_0; 35 + spi1 = &spi_1; 36 + spi2 = &spi_2; 37 + i2c0 = &i2c_0; 38 + i2c1 = &i2c_1; 39 + i2c2 = &i2c_2; 40 + i2c3 = &i2c_3; 41 + i2c4 = &i2c_4; 42 + i2c5 = &i2c_5; 43 + i2c6 = &i2c_6; 44 + i2c7 = &i2c_7; 45 + }; 46 + 47 + cpus { 48 + #address-cells = <1>; 49 + #size-cells = <0>; 50 + 51 + cpu0: cpu@a00 { 52 + device_type = "cpu"; 53 + compatible = "arm,cortex-a9"; 54 + reg = <0xa00>; 55 + clock-frequency = <1600000000>; 56 + }; 57 + 58 + cpu1: cpu@a01 { 59 + device_type = "cpu"; 60 + compatible = "arm,cortex-a9"; 61 + reg = <0xa01>; 62 + clock-frequency = <1600000000>; 63 + }; 64 + 65 + cpu2: cpu@a02 { 66 + device_type = "cpu"; 67 + compatible = "arm,cortex-a9"; 68 + reg = <0xa02>; 69 + clock-frequency = <1600000000>; 70 + }; 71 + 72 + cpu3: cpu@a03 { 73 + device_type = "cpu"; 74 + compatible = "arm,cortex-a9"; 75 + reg = <0xa03>; 76 + clock-frequency = <1600000000>; 77 + }; 78 + }; 79 + 80 + soc: soc { 81 + compatible = "simple-bus"; 82 + #address-cells = <1>; 83 + #size-cells = <1>; 84 + ranges; 85 + 86 + sysram@02020000 { 87 + compatible = "mmio-sram"; 88 + reg = <0x02020000 0x50000>; 89 + #address-cells = <1>; 90 + #size-cells = <1>; 91 + ranges = <0 0x02020000 0x50000>; 92 + 93 + smp-sysram@0 { 94 + compatible = "samsung,exynos4210-sysram"; 95 + reg = <0x0 0x1000>; 96 + }; 97 + 98 + smp-sysram@4f000 { 99 + compatible = "samsung,exynos4210-sysram-ns"; 100 + reg = <0x4f000 0x1000>; 101 + }; 102 + }; 103 + 104 + pinctrl_2: pinctrl@03860000 { 105 + compatible = "samsung,exynos4415-pinctrl"; 106 + reg = <0x03860000 0x1000>; 107 + interrupts = <0 242 0>; 108 + }; 109 + 110 + chipid@10000000 { 111 + compatible = "samsung,exynos4210-chipid"; 112 + reg = <0x10000000 0x100>; 113 + }; 114 + 115 + sysreg_system_controller: syscon@10010000 { 116 + compatible = "samsung,exynos4-sysreg", "syscon"; 117 + reg = <0x10010000 0x400>; 118 + }; 119 + 120 + pmu_system_controller: system-controller@10020000 { 121 + compatible = "samsung,exynos4415-pmu", "syscon"; 122 + reg = <0x10020000 0x4000>; 123 + }; 124 + 125 + mipi_phy: video-phy@10020710 { 126 + compatible = "samsung,s5pv210-mipi-video-phy"; 127 + reg = <0x10020710 8>; 128 + #phy-cells = <1>; 129 + }; 130 + 131 + pd_cam: cam-power-domain@10024000 { 132 + compatible = "samsung,exynos4210-pd"; 133 + reg = <0x10024000 0x20>; 134 + }; 135 + 136 + pd_tv: tv-power-domain@10024020 { 137 + compatible = "samsung,exynos4210-pd"; 138 + reg = <0x10024020 0x20>; 139 + }; 140 + 141 + pd_mfc: mfc-power-domain@10024040 { 142 + compatible = "samsung,exynos4210-pd"; 143 + reg = <0x10024040 0x20>; 144 + }; 145 + 146 + pd_g3d: g3d-power-domain@10024060 { 147 + compatible = "samsung,exynos4210-pd"; 148 + reg = <0x10024060 0x20>; 149 + }; 150 + 151 + pd_lcd0: lcd0-power-domain@10024080 { 152 + compatible = "samsung,exynos4210-pd"; 153 + reg = <0x10024080 0x20>; 154 + }; 155 + 156 + pd_isp0: isp0-power-domain@100240A0 { 157 + compatible = "samsung,exynos4210-pd"; 158 + reg = <0x100240A0 0x20>; 159 + }; 160 + 161 + pd_isp1: isp1-power-domain@100240E0 { 162 + compatible = "samsung,exynos4210-pd"; 163 + reg = <0x100240E0 0x20>; 164 + }; 165 + 166 + cmu: clock-controller@10030000 { 167 + compatible = "samsung,exynos4415-cmu"; 168 + reg = <0x10030000 0x18000>; 169 + #clock-cells = <1>; 170 + }; 171 + 172 + rtc: rtc@10070000 { 173 + compatible = "samsung,exynos3250-rtc"; 174 + reg = <0x10070000 0x100>; 175 + interrupts = <0 73 0>, <0 74 0>; 176 + status = "disabled"; 177 + }; 178 + 179 + mct@10050000 { 180 + compatible = "samsung,exynos4210-mct"; 181 + reg = <0x10050000 0x800>; 182 + interrupts = <0 218 0>, <0 219 0>, <0 220 0>, <0 221 0>, 183 + <0 223 0>, <0 226 0>, <0 227 0>, <0 228 0>; 184 + clocks = <&cmu CLK_FIN_PLL>, <&cmu CLK_MCT>; 185 + clock-names = "fin_pll", "mct"; 186 + }; 187 + 188 + gic: interrupt-controller@10481000 { 189 + compatible = "arm,cortex-a9-gic"; 190 + #interrupt-cells = <3>; 191 + interrupt-controller; 192 + reg = <0x10481000 0x1000>, 193 + <0x10482000 0x1000>, 194 + <0x10484000 0x2000>, 195 + <0x10486000 0x2000>; 196 + interrupts = <1 9 0xf04>; 197 + }; 198 + 199 + l2c: l2-cache-controller@10502000 { 200 + compatible = "arm,pl310-cache"; 201 + reg = <0x10502000 0x1000>; 202 + cache-unified; 203 + cache-level = <2>; 204 + arm,tag-latency = <2 2 1>; 205 + arm,data-latency = <3 2 1>; 206 + arm,double-linefill = <1>; 207 + arm,double-linefill-incr = <0>; 208 + arm,double-linefill-wrap = <1>; 209 + arm,prefetch-drop = <1>; 210 + arm,prefetch-offset = <7>; 211 + }; 212 + 213 + cmu_dmc: clock-controller@105C0000 { 214 + compatible = "samsung,exynos4415-cmu-dmc"; 215 + reg = <0x105C0000 0x3000>; 216 + #clock-cells = <1>; 217 + }; 218 + 219 + pinctrl_1: pinctrl@11000000 { 220 + compatible = "samsung,exynos4415-pinctrl"; 221 + reg = <0x11000000 0x1000>; 222 + interrupts = <0 225 0>; 223 + 224 + wakeup-interrupt-controller { 225 + compatible = "samsung,exynos4210-wakeup-eint"; 226 + interrupt-parent = <&gic>; 227 + interrupts = <0 48 0>; 228 + }; 229 + }; 230 + 231 + pinctrl_0: pinctrl@11400000 { 232 + compatible = "samsung,exynos4415-pinctrl"; 233 + reg = <0x11400000 0x1000>; 234 + interrupts = <0 240 0>; 235 + }; 236 + 237 + hsotg: hsotg@12480000 { 238 + compatible = "samsung,s3c6400-hsotg"; 239 + reg = <0x12480000 0x20000>; 240 + interrupts = <0 141 0>; 241 + clocks = <&cmu CLK_USBDEVICE>; 242 + clock-names = "otg"; 243 + phys = <&exynos_usbphy 0>; 244 + phy-names = "usb2-phy"; 245 + status = "disabled"; 246 + }; 247 + 248 + mshc_0: mshc@12510000 { 249 + compatible = "samsung,exynos5250-dw-mshc"; 250 + reg = <0x12510000 0x1000>; 251 + interrupts = <0 142 0>; 252 + clocks = <&cmu CLK_SDMMC0>, <&cmu CLK_SCLK_MMC0>; 253 + clock-names = "biu", "ciu"; 254 + fifo-depth = <0x80>; 255 + #address-cells = <1>; 256 + #size-cells = <0>; 257 + status = "disabled"; 258 + }; 259 + 260 + mshc_1: mshc@12520000 { 261 + compatible = "samsung,exynos5250-dw-mshc"; 262 + reg = <0x12520000 0x1000>; 263 + interrupts = <0 143 0>; 264 + clocks = <&cmu CLK_SDMMC1>, <&cmu CLK_SCLK_MMC1>; 265 + clock-names = "biu", "ciu"; 266 + fifo-depth = <0x80>; 267 + #address-cells = <1>; 268 + #size-cells = <0>; 269 + status = "disabled"; 270 + }; 271 + 272 + mshc_2: mshc@12530000 { 273 + compatible = "samsung,exynos5250-dw-mshc"; 274 + reg = <0x12530000 0x1000>; 275 + interrupts = <0 144 0>; 276 + clocks = <&cmu CLK_SDMMC2>, <&cmu CLK_SCLK_MMC2>; 277 + clock-names = "biu", "ciu"; 278 + fifo-depth = <0x80>; 279 + #address-cells = <1>; 280 + #size-cells = <0>; 281 + status = "disabled"; 282 + }; 283 + 284 + ehci: ehci@12580000 { 285 + compatible = "samsung,exynos4210-ehci"; 286 + reg = <0x12580000 0x100>; 287 + interrupts = <0 140 0>; 288 + clocks = <&cmu CLK_USBHOST>; 289 + clock-names = "usbhost"; 290 + status = "disabled"; 291 + #address-cells = <1>; 292 + #size-cells = <0>; 293 + port@0 { 294 + reg = <0>; 295 + phys = <&exynos_usbphy 1>; 296 + status = "disabled"; 297 + }; 298 + port@1 { 299 + reg = <1>; 300 + phys = <&exynos_usbphy 2>; 301 + status = "disabled"; 302 + }; 303 + port@2 { 304 + reg = <2>; 305 + phys = <&exynos_usbphy 3>; 306 + status = "disabled"; 307 + }; 308 + }; 309 + 310 + ohci: ohci@12590000 { 311 + compatible = "samsung,exynos4210-ohci"; 312 + reg = <0x12590000 0x100>; 313 + interrupts = <0 140 0>; 314 + clocks = <&cmu CLK_USBHOST>; 315 + clock-names = "usbhost"; 316 + status = "disabled"; 317 + #address-cells = <1>; 318 + #size-cells = <0>; 319 + port@0 { 320 + reg = <0>; 321 + phys = <&exynos_usbphy 1>; 322 + status = "disabled"; 323 + }; 324 + }; 325 + 326 + exynos_usbphy: exynos-usbphy@125B0000 { 327 + compatible = "samsung,exynos4x12-usb2-phy"; 328 + reg = <0x125B0000 0x100>; 329 + samsung,pmureg-phandle = <&pmu_system_controller>; 330 + samsung,sysreg-phandle = <&sysreg_system_controller>; 331 + clocks = <&cmu CLK_USBDEVICE>, <&xusbxti>; 332 + clock-names = "phy", "ref"; 333 + #phy-cells = <1>; 334 + status = "disabled"; 335 + }; 336 + 337 + amba { 338 + compatible = "arm,amba-bus"; 339 + #address-cells = <1>; 340 + #size-cells = <1>; 341 + interrupt-parent = <&gic>; 342 + ranges; 343 + 344 + pdma0: pdma@12680000 { 345 + compatible = "arm,pl330", "arm,primecell"; 346 + reg = <0x12680000 0x1000>; 347 + interrupts = <0 138 0>; 348 + clocks = <&cmu CLK_PDMA0>; 349 + clock-names = "apb_pclk"; 350 + #dma-cells = <1>; 351 + #dma-channels = <8>; 352 + #dma-requests = <32>; 353 + }; 354 + 355 + pdma1: pdma@12690000 { 356 + compatible = "arm,pl330", "arm,primecell"; 357 + reg = <0x12690000 0x1000>; 358 + interrupts = <0 139 0>; 359 + clocks = <&cmu CLK_PDMA1>; 360 + clock-names = "apb_pclk"; 361 + #dma-cells = <1>; 362 + #dma-channels = <8>; 363 + #dma-requests = <32>; 364 + }; 365 + }; 366 + 367 + adc: adc@126C0000 { 368 + compatible = "samsung,exynos3250-adc", 369 + "samsung,exynos-adc-v2"; 370 + reg = <0x126C0000 0x100>, <0x10020718 0x4>; 371 + interrupts = <0 137 0>; 372 + clock-names = "adc", "sclk"; 373 + clocks = <&cmu CLK_TSADC>, <&cmu CLK_SCLK_TSADC>; 374 + #io-channel-cells = <1>; 375 + io-channel-ranges; 376 + status = "disabled"; 377 + }; 378 + 379 + serial_0: serial@13800000 { 380 + compatible = "samsung,exynos4210-uart"; 381 + reg = <0x13800000 0x100>; 382 + interrupts = <0 109 0>; 383 + clocks = <&cmu CLK_UART0>, <&cmu CLK_SCLK_UART0>; 384 + clock-names = "uart", "clk_uart_baud0"; 385 + status = "disabled"; 386 + }; 387 + 388 + serial_1: serial@13810000 { 389 + compatible = "samsung,exynos4210-uart"; 390 + reg = <0x13810000 0x100>; 391 + interrupts = <0 110 0>; 392 + clocks = <&cmu CLK_UART1>, <&cmu CLK_SCLK_UART1>; 393 + clock-names = "uart", "clk_uart_baud0"; 394 + status = "disabled"; 395 + }; 396 + 397 + serial_2: serial@13820000 { 398 + compatible = "samsung,exynos4210-uart"; 399 + reg = <0x13820000 0x100>; 400 + interrupts = <0 111 0>; 401 + clocks = <&cmu CLK_UART2>, <&cmu CLK_SCLK_UART2>; 402 + clock-names = "uart", "clk_uart_baud0"; 403 + status = "disabled"; 404 + }; 405 + 406 + serial_3: serial@13830000 { 407 + compatible = "samsung,exynos4210-uart"; 408 + reg = <0x13830000 0x100>; 409 + interrupts = <0 112 0>; 410 + clocks = <&cmu CLK_UART3>, <&cmu CLK_SCLK_UART3>; 411 + clock-names = "uart", "clk_uart_baud0"; 412 + status = "disabled"; 413 + }; 414 + 415 + i2c_0: i2c@13860000 { 416 + #address-cells = <1>; 417 + #size-cells = <0>; 418 + compatible = "samsung,s3c2440-i2c"; 419 + reg = <0x13860000 0x100>; 420 + interrupts = <0 113 0>; 421 + clocks = <&cmu CLK_I2C0>; 422 + clock-names = "i2c"; 423 + pinctrl-names = "default"; 424 + pinctrl-0 = <&i2c0_bus>; 425 + status = "disabled"; 426 + }; 427 + 428 + i2c_1: i2c@13870000 { 429 + #address-cells = <1>; 430 + #size-cells = <0>; 431 + compatible = "samsung,s3c2440-i2c"; 432 + reg = <0x13870000 0x100>; 433 + interrupts = <0 114 0>; 434 + clocks = <&cmu CLK_I2C1>; 435 + clock-names = "i2c"; 436 + pinctrl-names = "default"; 437 + pinctrl-0 = <&i2c1_bus>; 438 + status = "disabled"; 439 + }; 440 + 441 + i2c_2: i2c@13880000 { 442 + #address-cells = <1>; 443 + #size-cells = <0>; 444 + compatible = "samsung,s3c2440-i2c"; 445 + reg = <0x13880000 0x100>; 446 + interrupts = <0 115 0>; 447 + clocks = <&cmu CLK_I2C2>; 448 + clock-names = "i2c"; 449 + pinctrl-names = "default"; 450 + pinctrl-0 = <&i2c2_bus>; 451 + status = "disabled"; 452 + }; 453 + 454 + i2c_3: i2c@13890000 { 455 + #address-cells = <1>; 456 + #size-cells = <0>; 457 + compatible = "samsung,s3c2440-i2c"; 458 + reg = <0x13890000 0x100>; 459 + interrupts = <0 116 0>; 460 + clocks = <&cmu CLK_I2C3>; 461 + clock-names = "i2c"; 462 + pinctrl-names = "default"; 463 + pinctrl-0 = <&i2c3_bus>; 464 + status = "disabled"; 465 + }; 466 + 467 + i2c_4: i2c@138A0000 { 468 + #address-cells = <1>; 469 + #size-cells = <0>; 470 + compatible = "samsung,s3c2440-i2c"; 471 + reg = <0x138A0000 0x100>; 472 + interrupts = <0 117 0>; 473 + clocks = <&cmu CLK_I2C4>; 474 + clock-names = "i2c"; 475 + pinctrl-names = "default"; 476 + pinctrl-0 = <&i2c4_bus>; 477 + status = "disabled"; 478 + }; 479 + 480 + i2c_5: i2c@138B0000 { 481 + #address-cells = <1>; 482 + #size-cells = <0>; 483 + compatible = "samsung,s3c2440-i2c"; 484 + reg = <0x138B0000 0x100>; 485 + interrupts = <0 118 0>; 486 + clocks = <&cmu CLK_I2C5>; 487 + clock-names = "i2c"; 488 + pinctrl-names = "default"; 489 + pinctrl-0 = <&i2c5_bus>; 490 + status = "disabled"; 491 + }; 492 + 493 + i2c_6: i2c@138C0000 { 494 + #address-cells = <1>; 495 + #size-cells = <0>; 496 + compatible = "samsung,s3c2440-i2c"; 497 + reg = <0x138C0000 0x100>; 498 + interrupts = <0 119 0>; 499 + clocks = <&cmu CLK_I2C6>; 500 + clock-names = "i2c"; 501 + pinctrl-names = "default"; 502 + pinctrl-0 = <&i2c6_bus>; 503 + status = "disabled"; 504 + }; 505 + 506 + i2c_7: i2c@138D0000 { 507 + #address-cells = <1>; 508 + #size-cells = <0>; 509 + compatible = "samsung,s3c2440-i2c"; 510 + reg = <0x138D0000 0x100>; 511 + interrupts = <0 120 0>; 512 + clocks = <&cmu CLK_I2C7>; 513 + clock-names = "i2c"; 514 + pinctrl-names = "default"; 515 + pinctrl-0 = <&i2c7_bus>; 516 + status = "disabled"; 517 + }; 518 + 519 + spi_0: spi@13920000 { 520 + compatible = "samsung,exynos4210-spi"; 521 + reg = <0x13920000 0x100>; 522 + interrupts = <0 121 0>; 523 + dmas = <&pdma0 7>, <&pdma0 6>; 524 + dma-names = "tx", "rx"; 525 + #address-cells = <1>; 526 + #size-cells = <0>; 527 + clocks = <&cmu CLK_SPI0>, <&cmu CLK_SCLK_SPI0>; 528 + clock-names = "spi", "spi_busclk0"; 529 + samsung,spi-src-clk = <0>; 530 + pinctrl-names = "default"; 531 + pinctrl-0 = <&spi0_bus>; 532 + status = "disabled"; 533 + }; 534 + 535 + spi_1: spi@13930000 { 536 + compatible = "samsung,exynos4210-spi"; 537 + reg = <0x13930000 0x100>; 538 + interrupts = <0 122 0>; 539 + dmas = <&pdma1 7>, <&pdma1 6>; 540 + dma-names = "tx", "rx"; 541 + #address-cells = <1>; 542 + #size-cells = <0>; 543 + clocks = <&cmu CLK_SPI1>, <&cmu CLK_SCLK_SPI1>; 544 + clock-names = "spi", "spi_busclk0"; 545 + samsung,spi-src-clk = <0>; 546 + pinctrl-names = "default"; 547 + pinctrl-0 = <&spi1_bus>; 548 + status = "disabled"; 549 + }; 550 + 551 + spi_2: spi@13940000 { 552 + compatible = "samsung,exynos4210-spi"; 553 + reg = <0x13940000 0x100>; 554 + interrupts = <0 123 0>; 555 + dmas = <&pdma0 9>, <&pdma0 8>; 556 + dma-names = "tx", "rx"; 557 + #address-cells = <1>; 558 + #size-cells = <0>; 559 + clocks = <&cmu CLK_SPI2>, <&cmu CLK_SCLK_SPI2>; 560 + clock-names = "spi", "spi_busclk0"; 561 + samsung,spi-src-clk = <0>; 562 + pinctrl-names = "default"; 563 + pinctrl-0 = <&spi2_bus>; 564 + status = "disabled"; 565 + }; 566 + 567 + clock_audss: clock-controller@03810000 { 568 + compatible = "samsung,exynos4210-audss-clock"; 569 + reg = <0x03810000 0x0C>; 570 + #clock-cells = <1>; 571 + }; 572 + 573 + i2s0: i2s@3830000 { 574 + compatible = "samsung,s5pv210-i2s"; 575 + reg = <0x03830000 0x100>; 576 + interrupts = <0 124 0>; 577 + clocks = <&clock_audss EXYNOS_I2S_BUS>, 578 + <&clock_audss EXYNOS_SCLK_I2S>; 579 + clock-names = "iis", "i2s_opclk0"; 580 + dmas = <&pdma1 10>, <&pdma1 9>, <&pdma1 8>; 581 + dma-names = "tx", "rx", "tx-sec"; 582 + pinctrl-names = "default"; 583 + pinctrl-0 = <&i2s0_bus>; 584 + samsung,idma-addr = <0x03000000>; 585 + status = "disabled"; 586 + }; 587 + 588 + pwm: pwm@139D0000 { 589 + compatible = "samsung,exynos4210-pwm"; 590 + reg = <0x139D0000 0x1000>; 591 + interrupts = <0 104 0>, <0 105 0>, <0 106 0>, 592 + <0 107 0>, <0 108 0>; 593 + #pwm-cells = <3>; 594 + status = "disabled"; 595 + }; 596 + 597 + pmu { 598 + compatible = "arm,cortex-a9-pmu"; 599 + interrupts = <0 18 0>, <0 19 0>, <0 20 0>, <0 21 0>; 600 + }; 601 + }; 602 + }; 603 + 604 + #include "exynos4415-pinctrl.dtsi"