blob: a9a55304e31aa81674c7f32445a09522a40a0c2f [file] [log] [blame]
Thomas Abraham0561cea2011-11-02 19:31:15 +09001/*
2 * Samsung's Exynos4210 SoC device tree source
3 *
4 * Copyright (c) 2010-2011 Samsung Electronics Co., Ltd.
5 * http://www.samsung.com
6 * Copyright (c) 2010-2011 Linaro Ltd.
7 * www.linaro.org
8 *
9 * Samsung's Exynos4210 SoC device nodes are listed in this file. Exynos4210
10 * based board files can include this file and provide values for board specfic
11 * bindings.
12 *
13 * Note: This file does not include device nodes for all the controllers in
14 * Exynos4210 SoC. As device tree coverage for Exynos4210 increases, additional
15 * nodes can be added to this file.
16 *
17 * This program is free software; you can redistribute it and/or modify
18 * it under the terms of the GNU General Public License version 2 as
19 * published by the Free Software Foundation.
20*/
21
Padmavathi Venna37992792013-06-18 00:02:08 +090022#include "exynos4.dtsi"
23#include "exynos4210-pinctrl.dtsi"
Lukasz Majewski9843a222015-01-30 08:26:03 +090024#include "exynos4-cpu-thermal.dtsi"
Thomas Abraham0561cea2011-11-02 19:31:15 +090025
26/ {
Sachin Kamat8bdb31b2014-03-21 02:17:22 +090027 compatible = "samsung,exynos4210", "samsung,exynos4";
Thomas Abraham0561cea2011-11-02 19:31:15 +090028
Thomas Abraham4980c392012-07-14 10:45:32 +090029 aliases {
Thomas Abraham87711d82012-09-07 06:14:26 +090030 pinctrl0 = &pinctrl_0;
31 pinctrl1 = &pinctrl_1;
32 pinctrl2 = &pinctrl_2;
Thomas Abraham4980c392012-07-14 10:45:32 +090033 };
34
Bartlomiej Zolnierkiewicze5409202014-09-25 17:40:14 +090035 cpus {
36 #address-cells = <1>;
37 #size-cells = <0>;
38
Lukasz Majewskibf4a0be2015-01-30 08:26:02 +090039 cpu0: cpu@900 {
Bartlomiej Zolnierkiewicze5409202014-09-25 17:40:14 +090040 device_type = "cpu";
41 compatible = "arm,cortex-a9";
42 reg = <0x900>;
Lukasz Majewskibf4a0be2015-01-30 08:26:02 +090043 cooling-min-level = <4>;
44 cooling-max-level = <2>;
45 #cooling-cells = <2>; /* min followed by max */
Bartlomiej Zolnierkiewicze5409202014-09-25 17:40:14 +090046 };
47
48 cpu@901 {
49 device_type = "cpu";
50 compatible = "arm,cortex-a9";
51 reg = <0x901>;
52 };
53 };
54
Krzysztof Kozlowski9c412212015-05-13 19:24:35 +090055 sysram: sysram@02020000 {
Sachin Kamatb3205de2014-05-13 07:13:44 +090056 compatible = "mmio-sram";
57 reg = <0x02020000 0x20000>;
58 #address-cells = <1>;
59 #size-cells = <1>;
60 ranges = <0 0x02020000 0x20000>;
61
62 smp-sysram@0 {
63 compatible = "samsung,exynos4210-sysram";
64 reg = <0x0 0x1000>;
65 };
66
67 smp-sysram@1f000 {
68 compatible = "samsung,exynos4210-sysram-ns";
69 reg = <0x1f000 0x1000>;
70 };
71 };
72
Tomasz Figa91d88f02012-11-22 00:22:09 +090073 pd_lcd1: lcd1-power-domain@10023CA0 {
74 compatible = "samsung,exynos4210-pd";
75 reg = <0x10023CA0 0x20>;
Marek Szyprowski0da65872015-01-24 13:16:15 +090076 #power-domain-cells = <0>;
Tomasz Figa91d88f02012-11-22 00:22:09 +090077 };
78
Tomasz Figa56b60b82015-01-08 07:54:34 +010079 l2c: l2-cache-controller@10502000 {
80 compatible = "arm,pl310-cache";
81 reg = <0x10502000 0x1000>;
82 cache-unified;
83 cache-level = <2>;
84 arm,tag-latency = <2 2 1>;
85 arm,data-latency = <2 2 1>;
86 };
87
Krzysztof Kozlowski9c412212015-05-13 19:24:35 +090088 mct: mct@10050000 {
Thomas Abrahambbd97002013-03-09 16:12:35 +090089 compatible = "samsung,exynos4210-mct";
90 reg = <0x10050000 0x800>;
Thomas Abrahambbd97002013-03-09 16:12:35 +090091 interrupt-parent = <&mct_map>;
Tomasz Figa84ee1c152013-12-19 03:17:49 +090092 interrupts = <0>, <1>, <2>, <3>, <4>, <5>;
Andrzej Hajda1c75a782014-02-26 09:53:30 +090093 clocks = <&clock CLK_FIN_PLL>, <&clock CLK_MCT>;
Thomas Abraham7ad34332013-03-09 17:11:38 +090094 clock-names = "fin_pll", "mct";
Thomas Abrahambbd97002013-03-09 16:12:35 +090095
96 mct_map: mct-map {
Tomasz Figa84ee1c152013-12-19 03:17:49 +090097 #interrupt-cells = <1>;
Thomas Abrahambbd97002013-03-09 16:12:35 +090098 #address-cells = <0>;
99 #size-cells = <0>;
Tomasz Figa84ee1c152013-12-19 03:17:49 +0900100 interrupt-map = <0 &gic 0 57 0>,
101 <1 &gic 0 69 0>,
102 <2 &combiner 12 6>,
103 <3 &combiner 12 7>,
104 <4 &gic 0 42 0>,
105 <5 &gic 0 48 0>;
Thomas Abrahambbd97002013-03-09 16:12:35 +0900106 };
107 };
108
Lee Jonese7787aed2013-08-06 03:04:43 +0900109 clock: clock-controller@10030000 {
Thomas Abrahamd8bafc82013-03-09 17:11:33 +0900110 compatible = "samsung,exynos4210-clock";
111 reg = <0x10030000 0x20000>;
112 #clock-cells = <1>;
113 };
114
Thomas Abraham87711d82012-09-07 06:14:26 +0900115 pinctrl_0: pinctrl@11400000 {
Kukjin Kimb533c862013-01-02 16:05:42 -0800116 compatible = "samsung,exynos4210-pinctrl";
Thomas Abraham87711d82012-09-07 06:14:26 +0900117 reg = <0x11400000 0x1000>;
118 interrupts = <0 47 0>;
Thomas Abraham87711d82012-09-07 06:14:26 +0900119 };
120
121 pinctrl_1: pinctrl@11000000 {
Kukjin Kimb533c862013-01-02 16:05:42 -0800122 compatible = "samsung,exynos4210-pinctrl";
Thomas Abraham87711d82012-09-07 06:14:26 +0900123 reg = <0x11000000 0x1000>;
124 interrupts = <0 46 0>;
Thomas Abraham87711d82012-09-07 06:14:26 +0900125
126 wakup_eint: wakeup-interrupt-controller {
127 compatible = "samsung,exynos4210-wakeup-eint";
128 interrupt-parent = <&gic>;
Tomasz Figaa04b07c2012-10-11 10:11:18 +0200129 interrupts = <0 32 0>;
Thomas Abraham87711d82012-09-07 06:14:26 +0900130 };
131 };
132
133 pinctrl_2: pinctrl@03860000 {
Kukjin Kimb533c862013-01-02 16:05:42 -0800134 compatible = "samsung,exynos4210-pinctrl";
Thomas Abraham87711d82012-09-07 06:14:26 +0900135 reg = <0x03860000 0x1000>;
136 };
137
Lukasz Majewski9843a222015-01-30 08:26:03 +0900138 tmu: tmu@100C0000 {
Amit Daniel Kachhap8d4155d2012-10-29 21:18:01 +0900139 compatible = "samsung,exynos4210-tmu";
140 interrupt-parent = <&combiner>;
141 reg = <0x100C0000 0x100>;
142 interrupts = <2 4>;
Andrzej Hajda1c75a782014-02-26 09:53:30 +0900143 clocks = <&clock CLK_TMU_APBIF>;
Sachin Kamate6199af2013-04-23 23:20:19 +0900144 clock-names = "tmu_apbif";
Lukasz Majewski9843a222015-01-30 08:26:03 +0900145 samsung,tmu_gain = <15>;
146 samsung,tmu_reference_voltage = <7>;
Sachin Kamate6199af2013-04-23 23:20:19 +0900147 status = "disabled";
Amit Daniel Kachhap8d4155d2012-10-29 21:18:01 +0900148 };
Sachin Kamat66d302a2013-04-04 13:48:45 +0900149
Lukasz Majewski9843a222015-01-30 08:26:03 +0900150 thermal-zones {
151 cpu_thermal: cpu-thermal {
152 polling-delay-passive = <0>;
153 polling-delay = <0>;
154 thermal-sensors = <&tmu 0>;
155
156 trips {
157 cpu_alert0: cpu-alert-0 {
158 temperature = <85000>; /* millicelsius */
159 };
160 cpu_alert1: cpu-alert-1 {
161 temperature = <100000>; /* millicelsius */
162 };
163 cpu_alert2: cpu-alert-2 {
164 temperature = <110000>; /* millicelsius */
165 };
166 };
167 };
168 };
169
Krzysztof Kozlowski9c412212015-05-13 19:24:35 +0900170 g2d: g2d@12800000 {
Sachin Kamat66d302a2013-04-04 13:48:45 +0900171 compatible = "samsung,s5pv210-g2d";
172 reg = <0x12800000 0x1000>;
173 interrupts = <0 89 0>;
Andrzej Hajda1c75a782014-02-26 09:53:30 +0900174 clocks = <&clock CLK_SCLK_FIMG2D>, <&clock CLK_G2D>;
Sachin Kamat37bf5792013-06-10 17:52:24 +0900175 clock-names = "sclk_fimg2d", "fimg2d";
Sachin Kamat66d302a2013-04-04 13:48:45 +0900176 status = "disabled";
177 };
Sylwester Nawrocki54a88962013-08-06 02:49:45 +0900178
179 camera {
Andrzej Hajda1c75a782014-02-26 09:53:30 +0900180 clocks = <&clock CLK_SCLK_CAM0>, <&clock CLK_SCLK_CAM1>,
181 <&clock CLK_PIXELASYNCM0>, <&clock CLK_PIXELASYNCM1>;
Sylwester Nawrocki54a88962013-08-06 02:49:45 +0900182 clock-names = "sclk_cam0", "sclk_cam1", "pxl_async0", "pxl_async1";
183
184 fimc_0: fimc@11800000 {
185 samsung,pix-limits = <4224 8192 1920 4224>;
186 samsung,mainscaler-ext;
187 samsung,cam-if;
188 };
189
190 fimc_1: fimc@11810000 {
191 samsung,pix-limits = <4224 8192 1920 4224>;
192 samsung,mainscaler-ext;
193 samsung,cam-if;
194 };
195
196 fimc_2: fimc@11820000 {
197 samsung,pix-limits = <4224 8192 1920 4224>;
198 samsung,mainscaler-ext;
199 samsung,lcd-wb;
200 };
201
202 fimc_3: fimc@11830000 {
203 samsung,pix-limits = <1920 8192 1366 1920>;
204 samsung,rotators = <0>;
205 samsung,mainscaler-ext;
206 samsung,lcd-wb;
207 };
208 };
Chanwoo Choi30e0e472015-02-04 08:10:58 +0900209
Marek Szyprowskied80d4c2015-02-04 23:44:16 +0900210 mixer: mixer@12C10000 {
211 clock-names = "mixer", "hdmi", "sclk_hdmi", "vp", "mout_mixer",
212 "sclk_mixer";
213 clocks = <&clock CLK_MIXER>, <&clock CLK_HDMI>,
214 <&clock CLK_SCLK_HDMI>, <&clock CLK_VP>,
215 <&clock CLK_MOUT_MIXER>, <&clock CLK_SCLK_MIXER>;
216 };
217
Chanwoo Choi30e0e472015-02-04 08:10:58 +0900218 ppmu_lcd1: ppmu_lcd1@12240000 {
219 compatible = "samsung,exynos-ppmu";
220 reg = <0x12240000 0x2000>;
221 clocks = <&clock CLK_PPMULCD1>;
222 clock-names = "ppmu";
223 status = "disabled";
224 };
Thomas Abraham0561cea2011-11-02 19:31:15 +0900225};
Krzysztof Kozlowski070bb0f2015-04-06 17:06:44 +0200226
227&gic {
228 cpu-offset = <0x8000>;
229};
230
231&combiner {
232 samsung,combiner-nr = <16>;
233 interrupts = <0 0 0>, <0 1 0>, <0 2 0>, <0 3 0>,
234 <0 4 0>, <0 5 0>, <0 6 0>, <0 7 0>,
235 <0 8 0>, <0 9 0>, <0 10 0>, <0 11 0>,
236 <0 12 0>, <0 13 0>, <0 14 0>, <0 15 0>;
237};
238
239&pmu_system_controller {
240 clock-names = "clkout0", "clkout1", "clkout2", "clkout3",
241 "clkout4", "clkout8", "clkout9";
242 clocks = <&clock CLK_OUT_DMC>, <&clock CLK_OUT_TOP>,
243 <&clock CLK_OUT_LEFTBUS>, <&clock CLK_OUT_RIGHTBUS>,
244 <&clock CLK_OUT_CPU>, <&clock CLK_XXTI>, <&clock CLK_XUSBXTI>;
245 #clock-cells = <1>;
246};