Add the rt linux 4.1.3-rt3 as base
[kvmfornfv.git] / kernel / arch / arm / boot / dts / exynos4210.dtsi
1 /*
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
22 #include "exynos4.dtsi"
23 #include "exynos4210-pinctrl.dtsi"
24 #include "exynos4-cpu-thermal.dtsi"
25
26 / {
27         compatible = "samsung,exynos4210", "samsung,exynos4";
28
29         aliases {
30                 pinctrl0 = &pinctrl_0;
31                 pinctrl1 = &pinctrl_1;
32                 pinctrl2 = &pinctrl_2;
33         };
34
35         cpus {
36                 #address-cells = <1>;
37                 #size-cells = <0>;
38
39                 cpu0: cpu@900 {
40                         device_type = "cpu";
41                         compatible = "arm,cortex-a9";
42                         reg = <0x900>;
43                         cooling-min-level = <4>;
44                         cooling-max-level = <2>;
45                         #cooling-cells = <2>; /* min followed by max */
46                 };
47
48                 cpu@901 {
49                         device_type = "cpu";
50                         compatible = "arm,cortex-a9";
51                         reg = <0x901>;
52                 };
53         };
54
55         pmu_system_controller: system-controller@10020000 {
56                 clock-names = "clkout0", "clkout1", "clkout2", "clkout3",
57                                 "clkout4", "clkout8", "clkout9";
58                 clocks = <&clock CLK_OUT_DMC>, <&clock CLK_OUT_TOP>,
59                         <&clock CLK_OUT_LEFTBUS>, <&clock CLK_OUT_RIGHTBUS>,
60                         <&clock CLK_OUT_CPU>, <&clock CLK_XXTI>,
61                         <&clock CLK_XUSBXTI>;
62                 #clock-cells = <1>;
63         };
64
65         sysram@02020000 {
66                 compatible = "mmio-sram";
67                 reg = <0x02020000 0x20000>;
68                 #address-cells = <1>;
69                 #size-cells = <1>;
70                 ranges = <0 0x02020000 0x20000>;
71
72                 smp-sysram@0 {
73                         compatible = "samsung,exynos4210-sysram";
74                         reg = <0x0 0x1000>;
75                 };
76
77                 smp-sysram@1f000 {
78                         compatible = "samsung,exynos4210-sysram-ns";
79                         reg = <0x1f000 0x1000>;
80                 };
81         };
82
83         pd_lcd1: lcd1-power-domain@10023CA0 {
84                 compatible = "samsung,exynos4210-pd";
85                 reg = <0x10023CA0 0x20>;
86                 #power-domain-cells = <0>;
87         };
88
89         l2c: l2-cache-controller@10502000 {
90                 compatible = "arm,pl310-cache";
91                 reg = <0x10502000 0x1000>;
92                 cache-unified;
93                 cache-level = <2>;
94                 arm,tag-latency = <2 2 1>;
95                 arm,data-latency = <2 2 1>;
96         };
97
98         gic: interrupt-controller@10490000 {
99                 cpu-offset = <0x8000>;
100         };
101
102         combiner: interrupt-controller@10440000 {
103                 samsung,combiner-nr = <16>;
104                 interrupts = <0 0 0>, <0 1 0>, <0 2 0>, <0 3 0>,
105                              <0 4 0>, <0 5 0>, <0 6 0>, <0 7 0>,
106                              <0 8 0>, <0 9 0>, <0 10 0>, <0 11 0>,
107                              <0 12 0>, <0 13 0>, <0 14 0>, <0 15 0>;
108         };
109
110         mct@10050000 {
111                 compatible = "samsung,exynos4210-mct";
112                 reg = <0x10050000 0x800>;
113                 interrupt-parent = <&mct_map>;
114                 interrupts = <0>, <1>, <2>, <3>, <4>, <5>;
115                 clocks = <&clock CLK_FIN_PLL>, <&clock CLK_MCT>;
116                 clock-names = "fin_pll", "mct";
117
118                 mct_map: mct-map {
119                         #interrupt-cells = <1>;
120                         #address-cells = <0>;
121                         #size-cells = <0>;
122                         interrupt-map = <0 &gic 0 57 0>,
123                                         <1 &gic 0 69 0>,
124                                         <2 &combiner 12 6>,
125                                         <3 &combiner 12 7>,
126                                         <4 &gic 0 42 0>,
127                                         <5 &gic 0 48 0>;
128                 };
129         };
130
131         clock: clock-controller@10030000 {
132                 compatible = "samsung,exynos4210-clock";
133                 reg = <0x10030000 0x20000>;
134                 #clock-cells = <1>;
135         };
136
137         pinctrl_0: pinctrl@11400000 {
138                 compatible = "samsung,exynos4210-pinctrl";
139                 reg = <0x11400000 0x1000>;
140                 interrupts = <0 47 0>;
141         };
142
143         pinctrl_1: pinctrl@11000000 {
144                 compatible = "samsung,exynos4210-pinctrl";
145                 reg = <0x11000000 0x1000>;
146                 interrupts = <0 46 0>;
147
148                 wakup_eint: wakeup-interrupt-controller {
149                         compatible = "samsung,exynos4210-wakeup-eint";
150                         interrupt-parent = <&gic>;
151                         interrupts = <0 32 0>;
152                 };
153         };
154
155         pinctrl_2: pinctrl@03860000 {
156                 compatible = "samsung,exynos4210-pinctrl";
157                 reg = <0x03860000 0x1000>;
158         };
159
160         tmu: tmu@100C0000 {
161                 compatible = "samsung,exynos4210-tmu";
162                 interrupt-parent = <&combiner>;
163                 reg = <0x100C0000 0x100>;
164                 interrupts = <2 4>;
165                 clocks = <&clock CLK_TMU_APBIF>;
166                 clock-names = "tmu_apbif";
167                 samsung,tmu_gain = <15>;
168                 samsung,tmu_reference_voltage = <7>;
169                 status = "disabled";
170         };
171
172         thermal-zones {
173                 cpu_thermal: cpu-thermal {
174                         polling-delay-passive = <0>;
175                         polling-delay = <0>;
176                         thermal-sensors = <&tmu 0>;
177
178                         trips {
179                               cpu_alert0: cpu-alert-0 {
180                                       temperature = <85000>; /* millicelsius */
181                               };
182                               cpu_alert1: cpu-alert-1 {
183                                       temperature = <100000>; /* millicelsius */
184                               };
185                               cpu_alert2: cpu-alert-2 {
186                                       temperature = <110000>; /* millicelsius */
187                               };
188                         };
189                 };
190         };
191
192         g2d@12800000 {
193                 compatible = "samsung,s5pv210-g2d";
194                 reg = <0x12800000 0x1000>;
195                 interrupts = <0 89 0>;
196                 clocks = <&clock CLK_SCLK_FIMG2D>, <&clock CLK_G2D>;
197                 clock-names = "sclk_fimg2d", "fimg2d";
198                 status = "disabled";
199         };
200
201         camera {
202                 clocks = <&clock CLK_SCLK_CAM0>, <&clock CLK_SCLK_CAM1>,
203                          <&clock CLK_PIXELASYNCM0>, <&clock CLK_PIXELASYNCM1>;
204                 clock-names = "sclk_cam0", "sclk_cam1", "pxl_async0", "pxl_async1";
205
206                 fimc_0: fimc@11800000 {
207                         samsung,pix-limits = <4224 8192 1920 4224>;
208                         samsung,mainscaler-ext;
209                         samsung,cam-if;
210                 };
211
212                 fimc_1: fimc@11810000 {
213                         samsung,pix-limits = <4224 8192 1920 4224>;
214                         samsung,mainscaler-ext;
215                         samsung,cam-if;
216                 };
217
218                 fimc_2: fimc@11820000 {
219                         samsung,pix-limits = <4224 8192 1920 4224>;
220                         samsung,mainscaler-ext;
221                         samsung,lcd-wb;
222                 };
223
224                 fimc_3: fimc@11830000 {
225                         samsung,pix-limits = <1920 8192 1366 1920>;
226                         samsung,rotators = <0>;
227                         samsung,mainscaler-ext;
228                         samsung,lcd-wb;
229                 };
230         };
231
232         mixer: mixer@12C10000 {
233                 clock-names = "mixer", "hdmi", "sclk_hdmi", "vp", "mout_mixer",
234                         "sclk_mixer";
235                 clocks = <&clock CLK_MIXER>, <&clock CLK_HDMI>,
236                         <&clock CLK_SCLK_HDMI>, <&clock CLK_VP>,
237                         <&clock CLK_MOUT_MIXER>, <&clock CLK_SCLK_MIXER>;
238         };
239
240         ppmu_lcd1: ppmu_lcd1@12240000 {
241                 compatible = "samsung,exynos-ppmu";
242                 reg = <0x12240000 0x2000>;
243                 clocks = <&clock CLK_PPMULCD1>;
244                 clock-names = "ppmu";
245                 status = "disabled";
246         };
247 };