2 * SAMSUNG EXYNOS5250 SoC device tree source
4 * Copyright (c) 2012 Samsung Electronics Co., Ltd.
5 * http://www.samsung.com
7 * SAMSUNG EXYNOS5250 SoC device nodes are listed in this file.
8 * EXYNOS5250 based board files can include this file and provide
9 * values for board specfic bindings.
11 * Note: This file does not include device nodes for all the controllers in
12 * EXYNOS5250 SoC. As device tree coverage for EXYNOS5250 increases,
13 * additional nodes can be added to this file.
15 * This program is free software; you can redistribute it and/or modify
16 * it under the terms of the GNU General Public License version 2 as
17 * published by the Free Software Foundation.
20 #include <dt-bindings/clock/exynos5250.h>
21 #include "exynos5.dtsi"
22 #include "exynos5250-pinctrl.dtsi"
24 #include <dt-bindings/clock/exynos-audss-clk.h>
27 compatible = "samsung,exynos5250", "samsung,exynos5";
51 pinctrl0 = &pinctrl_0;
52 pinctrl1 = &pinctrl_1;
53 pinctrl2 = &pinctrl_2;
54 pinctrl3 = &pinctrl_3;
63 compatible = "arm,cortex-a15";
65 clock-frequency = <1700000000>;
69 compatible = "arm,cortex-a15";
71 clock-frequency = <1700000000>;
76 compatible = "mmio-sram";
77 reg = <0x02020000 0x30000>;
80 ranges = <0 0x02020000 0x30000>;
83 compatible = "samsung,exynos4210-sysram";
88 compatible = "samsung,exynos4210-sysram-ns";
89 reg = <0x2f000 0x1000>;
93 pd_gsc: gsc-power-domain@10044000 {
94 compatible = "samsung,exynos4210-pd";
95 reg = <0x10044000 0x20>;
98 pd_mfc: mfc-power-domain@10044040 {
99 compatible = "samsung,exynos4210-pd";
100 reg = <0x10044040 0x20>;
103 clock: clock-controller@10010000 {
104 compatible = "samsung,exynos5250-clock";
105 reg = <0x10010000 0x30000>;
109 clock_audss: audss-clock-controller@3810000 {
110 compatible = "samsung,exynos5250-audss-clock";
111 reg = <0x03810000 0x0C>;
113 clocks = <&clock CLK_FIN_PLL>, <&clock CLK_FOUT_EPLL>,
114 <&clock CLK_SCLK_AUDIO0>, <&clock CLK_DIV_PCM0>;
115 clock-names = "pll_ref", "pll_in", "sclk_audio", "sclk_pcm_in";
119 compatible = "arm,armv7-timer";
120 interrupts = <1 13 0xf08>,
124 /* Unfortunately we need this since some versions of U-Boot
125 * on Exynos don't set the CNTFRQ register, so we need the
128 clock-frequency = <24000000>;
132 compatible = "samsung,exynos4210-mct";
133 reg = <0x101C0000 0x800>;
134 interrupt-controller;
135 #interrups-cells = <2>;
136 interrupt-parent = <&mct_map>;
137 interrupts = <0 0>, <1 0>, <2 0>, <3 0>,
139 clocks = <&clock CLK_FIN_PLL>, <&clock CLK_MCT>;
140 clock-names = "fin_pll", "mct";
143 #interrupt-cells = <2>;
144 #address-cells = <0>;
146 interrupt-map = <0x0 0 &combiner 23 3>,
147 <0x1 0 &combiner 23 4>,
148 <0x2 0 &combiner 25 2>,
149 <0x3 0 &combiner 25 3>,
150 <0x4 0 &gic 0 120 0>,
151 <0x5 0 &gic 0 121 0>;
156 compatible = "arm,cortex-a15-pmu";
157 interrupt-parent = <&combiner>;
158 interrupts = <1 2>, <22 4>;
161 pinctrl_0: pinctrl@11400000 {
162 compatible = "samsung,exynos5250-pinctrl";
163 reg = <0x11400000 0x1000>;
164 interrupts = <0 46 0>;
166 wakup_eint: wakeup-interrupt-controller {
167 compatible = "samsung,exynos4210-wakeup-eint";
168 interrupt-parent = <&gic>;
169 interrupts = <0 32 0>;
173 pinctrl_1: pinctrl@13400000 {
174 compatible = "samsung,exynos5250-pinctrl";
175 reg = <0x13400000 0x1000>;
176 interrupts = <0 45 0>;
179 pinctrl_2: pinctrl@10d10000 {
180 compatible = "samsung,exynos5250-pinctrl";
181 reg = <0x10d10000 0x1000>;
182 interrupts = <0 50 0>;
185 pinctrl_3: pinctrl@03860000 {
186 compatible = "samsung,exynos5250-pinctrl";
187 reg = <0x03860000 0x1000>;
188 interrupts = <0 47 0>;
191 pmu_system_controller: system-controller@10040000 {
192 compatible = "samsung,exynos5250-pmu", "syscon";
193 reg = <0x10040000 0x5000>;
197 compatible = "samsung,exynos5250-wdt";
198 reg = <0x101D0000 0x100>;
199 interrupts = <0 42 0>;
200 clocks = <&clock CLK_WDT>;
201 clock-names = "watchdog";
202 samsung,syscon-phandle = <&pmu_system_controller>;
206 compatible = "samsung,exynos5250-g2d";
207 reg = <0x10850000 0x1000>;
208 interrupts = <0 91 0>;
209 clocks = <&clock CLK_G2D>;
210 clock-names = "fimg2d";
214 compatible = "samsung,mfc-v6";
215 reg = <0x11000000 0x10000>;
216 interrupts = <0 96 0>;
217 samsung,power-domain = <&pd_mfc>;
218 clocks = <&clock CLK_MFC>;
223 clocks = <&clock CLK_RTC>;
229 compatible = "samsung,exynos5250-tmu";
230 reg = <0x10060000 0x100>;
231 interrupts = <0 65 0>;
232 clocks = <&clock CLK_TMU>;
233 clock-names = "tmu_apbif";
237 clocks = <&clock CLK_UART0>, <&clock CLK_SCLK_UART0>;
238 clock-names = "uart", "clk_uart_baud0";
242 clocks = <&clock CLK_UART1>, <&clock CLK_SCLK_UART1>;
243 clock-names = "uart", "clk_uart_baud0";
247 clocks = <&clock CLK_UART2>, <&clock CLK_SCLK_UART2>;
248 clock-names = "uart", "clk_uart_baud0";
252 clocks = <&clock CLK_UART3>, <&clock CLK_SCLK_UART3>;
253 clock-names = "uart", "clk_uart_baud0";
257 compatible = "snps,dwc-ahci";
258 samsung,sata-freq = <66>;
259 reg = <0x122F0000 0x1ff>;
260 interrupts = <0 115 0>;
261 clocks = <&clock CLK_SATA>, <&clock CLK_SCLK_SATA>;
262 clock-names = "sata", "sclk_sata";
264 phy-names = "sata-phy";
268 sata_phy: sata-phy@12170000 {
269 compatible = "samsung,exynos5250-sata-phy";
270 reg = <0x12170000 0x1ff>;
271 clocks = <&clock 287>;
272 clock-names = "sata_phyctrl";
274 samsung,syscon-phandle = <&pmu_system_controller>;
278 i2c_0: i2c@12C60000 {
279 compatible = "samsung,s3c2440-i2c";
280 reg = <0x12C60000 0x100>;
281 interrupts = <0 56 0>;
282 #address-cells = <1>;
284 clocks = <&clock CLK_I2C0>;
286 pinctrl-names = "default";
287 pinctrl-0 = <&i2c0_bus>;
291 i2c_1: i2c@12C70000 {
292 compatible = "samsung,s3c2440-i2c";
293 reg = <0x12C70000 0x100>;
294 interrupts = <0 57 0>;
295 #address-cells = <1>;
297 clocks = <&clock CLK_I2C1>;
299 pinctrl-names = "default";
300 pinctrl-0 = <&i2c1_bus>;
304 i2c_2: i2c@12C80000 {
305 compatible = "samsung,s3c2440-i2c";
306 reg = <0x12C80000 0x100>;
307 interrupts = <0 58 0>;
308 #address-cells = <1>;
310 clocks = <&clock CLK_I2C2>;
312 pinctrl-names = "default";
313 pinctrl-0 = <&i2c2_bus>;
317 i2c_3: i2c@12C90000 {
318 compatible = "samsung,s3c2440-i2c";
319 reg = <0x12C90000 0x100>;
320 interrupts = <0 59 0>;
321 #address-cells = <1>;
323 clocks = <&clock CLK_I2C3>;
325 pinctrl-names = "default";
326 pinctrl-0 = <&i2c3_bus>;
330 i2c_4: i2c@12CA0000 {
331 compatible = "samsung,s3c2440-i2c";
332 reg = <0x12CA0000 0x100>;
333 interrupts = <0 60 0>;
334 #address-cells = <1>;
336 clocks = <&clock CLK_I2C4>;
338 pinctrl-names = "default";
339 pinctrl-0 = <&i2c4_bus>;
343 i2c_5: i2c@12CB0000 {
344 compatible = "samsung,s3c2440-i2c";
345 reg = <0x12CB0000 0x100>;
346 interrupts = <0 61 0>;
347 #address-cells = <1>;
349 clocks = <&clock CLK_I2C5>;
351 pinctrl-names = "default";
352 pinctrl-0 = <&i2c5_bus>;
356 i2c_6: i2c@12CC0000 {
357 compatible = "samsung,s3c2440-i2c";
358 reg = <0x12CC0000 0x100>;
359 interrupts = <0 62 0>;
360 #address-cells = <1>;
362 clocks = <&clock CLK_I2C6>;
364 pinctrl-names = "default";
365 pinctrl-0 = <&i2c6_bus>;
369 i2c_7: i2c@12CD0000 {
370 compatible = "samsung,s3c2440-i2c";
371 reg = <0x12CD0000 0x100>;
372 interrupts = <0 63 0>;
373 #address-cells = <1>;
375 clocks = <&clock CLK_I2C7>;
377 pinctrl-names = "default";
378 pinctrl-0 = <&i2c7_bus>;
382 i2c_8: i2c@12CE0000 {
383 compatible = "samsung,s3c2440-hdmiphy-i2c";
384 reg = <0x12CE0000 0x1000>;
385 interrupts = <0 64 0>;
386 #address-cells = <1>;
388 clocks = <&clock CLK_I2C_HDMI>;
393 i2c_9: i2c@121D0000 {
394 compatible = "samsung,exynos5-sata-phy-i2c";
395 reg = <0x121D0000 0x100>;
396 #address-cells = <1>;
398 clocks = <&clock CLK_SATA_PHYI2C>;
403 spi_0: spi@12d20000 {
404 compatible = "samsung,exynos4210-spi";
406 reg = <0x12d20000 0x100>;
407 interrupts = <0 66 0>;
410 dma-names = "tx", "rx";
411 #address-cells = <1>;
413 clocks = <&clock CLK_SPI0>, <&clock CLK_SCLK_SPI0>;
414 clock-names = "spi", "spi_busclk0";
415 pinctrl-names = "default";
416 pinctrl-0 = <&spi0_bus>;
419 spi_1: spi@12d30000 {
420 compatible = "samsung,exynos4210-spi";
422 reg = <0x12d30000 0x100>;
423 interrupts = <0 67 0>;
426 dma-names = "tx", "rx";
427 #address-cells = <1>;
429 clocks = <&clock CLK_SPI1>, <&clock CLK_SCLK_SPI1>;
430 clock-names = "spi", "spi_busclk0";
431 pinctrl-names = "default";
432 pinctrl-0 = <&spi1_bus>;
435 spi_2: spi@12d40000 {
436 compatible = "samsung,exynos4210-spi";
438 reg = <0x12d40000 0x100>;
439 interrupts = <0 68 0>;
442 dma-names = "tx", "rx";
443 #address-cells = <1>;
445 clocks = <&clock CLK_SPI2>, <&clock CLK_SCLK_SPI2>;
446 clock-names = "spi", "spi_busclk0";
447 pinctrl-names = "default";
448 pinctrl-0 = <&spi2_bus>;
451 mmc_0: mmc@12200000 {
452 compatible = "samsung,exynos5250-dw-mshc";
453 interrupts = <0 75 0>;
454 #address-cells = <1>;
456 reg = <0x12200000 0x1000>;
457 clocks = <&clock CLK_SDMMC0>, <&clock CLK_SCLK_MMC0>;
458 clock-names = "biu", "ciu";
463 mmc_1: mmc@12210000 {
464 compatible = "samsung,exynos5250-dw-mshc";
465 interrupts = <0 76 0>;
466 #address-cells = <1>;
468 reg = <0x12210000 0x1000>;
469 clocks = <&clock CLK_SDMMC1>, <&clock CLK_SCLK_MMC1>;
470 clock-names = "biu", "ciu";
475 mmc_2: mmc@12220000 {
476 compatible = "samsung,exynos5250-dw-mshc";
477 interrupts = <0 77 0>;
478 #address-cells = <1>;
480 reg = <0x12220000 0x1000>;
481 clocks = <&clock CLK_SDMMC2>, <&clock CLK_SCLK_MMC2>;
482 clock-names = "biu", "ciu";
487 mmc_3: mmc@12230000 {
488 compatible = "samsung,exynos5250-dw-mshc";
489 reg = <0x12230000 0x1000>;
490 interrupts = <0 78 0>;
491 #address-cells = <1>;
493 clocks = <&clock CLK_SDMMC3>, <&clock CLK_SCLK_MMC3>;
494 clock-names = "biu", "ciu";
500 compatible = "samsung,s5pv210-i2s";
502 reg = <0x03830000 0x100>;
506 dma-names = "tx", "rx", "tx-sec";
507 clocks = <&clock_audss EXYNOS_I2S_BUS>,
508 <&clock_audss EXYNOS_I2S_BUS>,
509 <&clock_audss EXYNOS_SCLK_I2S>;
510 clock-names = "iis", "i2s_opclk0", "i2s_opclk1";
511 samsung,idma-addr = <0x03000000>;
512 pinctrl-names = "default";
513 pinctrl-0 = <&i2s0_bus>;
517 compatible = "samsung,s3c6410-i2s";
519 reg = <0x12D60000 0x100>;
522 dma-names = "tx", "rx";
523 clocks = <&clock CLK_I2S1>, <&clock CLK_DIV_I2S1>;
524 clock-names = "iis", "i2s_opclk0";
525 pinctrl-names = "default";
526 pinctrl-0 = <&i2s1_bus>;
530 compatible = "samsung,s3c6410-i2s";
532 reg = <0x12D70000 0x100>;
535 dma-names = "tx", "rx";
536 clocks = <&clock CLK_I2S2>, <&clock CLK_DIV_I2S2>;
537 clock-names = "iis", "i2s_opclk0";
538 pinctrl-names = "default";
539 pinctrl-0 = <&i2s2_bus>;
543 compatible = "samsung,exynos5250-dwusb3";
544 clocks = <&clock CLK_USB3>;
545 clock-names = "usbdrd30";
546 #address-cells = <1>;
551 compatible = "synopsys,dwc3";
552 reg = <0x12000000 0x10000>;
553 interrupts = <0 72 0>;
554 usb-phy = <&usb2_phy &usb3_phy>;
558 usb3_phy: usbphy@12100000 {
559 compatible = "samsung,exynos5250-usb3phy";
560 reg = <0x12100000 0x100>;
561 clocks = <&clock CLK_FIN_PLL>, <&clock CLK_USB3>;
562 clock-names = "ext_xtal", "usbdrd30";
563 #address-cells = <1>;
568 reg = <0x10040704 0x8>;
572 usbdrd_phy: phy@12100000 {
573 compatible = "samsung,exynos5250-usbdrd-phy";
574 reg = <0x12100000 0x100>;
575 clocks = <&clock CLK_USB3>, <&clock CLK_FIN_PLL>;
576 clock-names = "phy", "ref";
577 samsung,pmu-syscon = <&pmu_system_controller>;
582 compatible = "samsung,exynos4210-ehci";
583 reg = <0x12110000 0x100>;
584 interrupts = <0 71 0>;
586 clocks = <&clock CLK_USB2>;
587 clock-names = "usbhost";
591 compatible = "samsung,exynos4210-ohci";
592 reg = <0x12120000 0x100>;
593 interrupts = <0 71 0>;
595 clocks = <&clock CLK_USB2>;
596 clock-names = "usbhost";
599 usb2_phy: usbphy@12130000 {
600 compatible = "samsung,exynos5250-usb2phy";
601 reg = <0x12130000 0x100>;
602 clocks = <&clock CLK_FIN_PLL>, <&clock CLK_USB2>;
603 clock-names = "ext_xtal", "usbhost";
604 #address-cells = <1>;
609 reg = <0x10040704 0x8>,
615 compatible = "samsung,exynos4210-pwm";
616 reg = <0x12dd0000 0x100>;
617 samsung,pwm-outputs = <0>, <1>, <2>, <3>;
619 clocks = <&clock CLK_PWM>;
620 clock-names = "timers";
624 #address-cells = <1>;
626 compatible = "arm,amba-bus";
627 interrupt-parent = <&gic>;
630 pdma0: pdma@121A0000 {
631 compatible = "arm,pl330", "arm,primecell";
632 reg = <0x121A0000 0x1000>;
633 interrupts = <0 34 0>;
634 clocks = <&clock CLK_PDMA0>;
635 clock-names = "apb_pclk";
638 #dma-requests = <32>;
641 pdma1: pdma@121B0000 {
642 compatible = "arm,pl330", "arm,primecell";
643 reg = <0x121B0000 0x1000>;
644 interrupts = <0 35 0>;
645 clocks = <&clock CLK_PDMA1>;
646 clock-names = "apb_pclk";
649 #dma-requests = <32>;
652 mdma0: mdma@10800000 {
653 compatible = "arm,pl330", "arm,primecell";
654 reg = <0x10800000 0x1000>;
655 interrupts = <0 33 0>;
656 clocks = <&clock CLK_MDMA0>;
657 clock-names = "apb_pclk";
663 mdma1: mdma@11C10000 {
664 compatible = "arm,pl330", "arm,primecell";
665 reg = <0x11C10000 0x1000>;
666 interrupts = <0 124 0>;
667 clocks = <&clock CLK_MDMA1>;
668 clock-names = "apb_pclk";
675 gsc_0: gsc@13e00000 {
676 compatible = "samsung,exynos5-gsc";
677 reg = <0x13e00000 0x1000>;
678 interrupts = <0 85 0>;
679 samsung,power-domain = <&pd_gsc>;
680 clocks = <&clock CLK_GSCL0>;
681 clock-names = "gscl";
684 gsc_1: gsc@13e10000 {
685 compatible = "samsung,exynos5-gsc";
686 reg = <0x13e10000 0x1000>;
687 interrupts = <0 86 0>;
688 samsung,power-domain = <&pd_gsc>;
689 clocks = <&clock CLK_GSCL1>;
690 clock-names = "gscl";
693 gsc_2: gsc@13e20000 {
694 compatible = "samsung,exynos5-gsc";
695 reg = <0x13e20000 0x1000>;
696 interrupts = <0 87 0>;
697 samsung,power-domain = <&pd_gsc>;
698 clocks = <&clock CLK_GSCL2>;
699 clock-names = "gscl";
702 gsc_3: gsc@13e30000 {
703 compatible = "samsung,exynos5-gsc";
704 reg = <0x13e30000 0x1000>;
705 interrupts = <0 88 0>;
706 samsung,power-domain = <&pd_gsc>;
707 clocks = <&clock CLK_GSCL3>;
708 clock-names = "gscl";
712 compatible = "samsung,exynos4212-hdmi";
713 reg = <0x14530000 0x70000>;
714 interrupts = <0 95 0>;
715 clocks = <&clock CLK_HDMI>, <&clock CLK_SCLK_HDMI>,
716 <&clock CLK_SCLK_PIXEL>, <&clock CLK_SCLK_HDMIPHY>,
717 <&clock CLK_MOUT_HDMI>;
718 clock-names = "hdmi", "sclk_hdmi", "sclk_pixel",
719 "sclk_hdmiphy", "mout_hdmi";
723 compatible = "samsung,exynos5250-mixer";
724 reg = <0x14450000 0x10000>;
725 interrupts = <0 94 0>;
726 clocks = <&clock CLK_MIXER>, <&clock CLK_SCLK_HDMI>;
727 clock-names = "mixer", "sclk_hdmi";
730 dp_phy: video-phy@10040720 {
731 compatible = "samsung,exynos5250-dp-video-phy";
732 reg = <0x10040720 4>;
736 dp-controller@145B0000 {
737 clocks = <&clock CLK_DP>;
744 clocks = <&clock CLK_SCLK_FIMD1>, <&clock CLK_FIMD1>;
745 clock-names = "sclk_fimd", "fimd";
749 compatible = "samsung,exynos-adc-v1";
750 reg = <0x12D10000 0x100>, <0x10040718 0x4>;
751 interrupts = <0 106 0>;
752 clocks = <&clock CLK_ADC>;
754 #io-channel-cells = <1>;
760 compatible = "samsung,exynos4210-secss";
761 reg = <0x10830000 0x10000>;
762 interrupts = <0 112 0>;
763 clocks = <&clock 348>;
764 clock-names = "secss";