mm: fix exec activate_mm vs TLB shootdown and lazy tlb switching race
[linux/fpc-iii.git] / arch / arm / boot / dts / exynos4210-universal_c210.dts
blob0c89ea99de545dd63ba132295758101089eab15b
1 /*
2  * Samsung's Exynos4210 based Universal C210 board device tree source
3  *
4  * Copyright (c) 2012-2013 Samsung Electronics Co., Ltd.
5  *              http://www.samsung.com
6  *
7  * Device tree source file for Samsung's Universal C210 board which is based on
8  * Samsung's Exynos4210 rev0 SoC.
9  *
10  * This program is free software; you can redistribute it and/or modify
11  * it under the terms of the GNU General Public License version 2 as
12  * published by the Free Software Foundation.
15 /dts-v1/;
16 #include "exynos4210.dtsi"
17 #include <dt-bindings/gpio/gpio.h>
19 / {
20         model = "Samsung Universal C210 based on Exynos4210 rev0";
21         compatible = "samsung,universal_c210", "samsung,exynos4210", "samsung,exynos4";
23         memory@40000000 {
24                 device_type = "memory";
25                 reg =  <0x40000000 0x10000000
26                         0x50000000 0x10000000>;
27         };
29         chosen {
30                 bootargs = "console=ttySAC2,115200N8 root=/dev/mmcblk0p5 rw rootwait earlyprintk panic=5 maxcpus=1";
31                 stdout-path = &serial_2;
32         };
34         sysram@02020000 {
35                 smp-sysram@0 {
36                         status = "disabled";
37                 };
39                 smp-sysram@5000 {
40                         compatible = "samsung,exynos4210-sysram";
41                         reg = <0x5000 0x1000>;
42                 };
44                 smp-sysram@1f000 {
45                         status = "disabled";
46                 };
47         };
49         mct@10050000 {
50                 compatible = "none";
51         };
53         fixed-rate-clocks {
54                 xxti {
55                         compatible = "samsung,clock-xxti";
56                         clock-frequency = <0>;
57                 };
59                 xusbxti {
60                         compatible = "samsung,clock-xusbxti";
61                         clock-frequency = <24000000>;
62                 };
63         };
65         vemmc_reg: voltage-regulator {
66                 compatible = "regulator-fixed";
67                 regulator-name = "VMEM_VDD_2_8V";
68                 regulator-min-microvolt = <2800000>;
69                 regulator-max-microvolt = <2800000>;
70                 gpio = <&gpe1 3 GPIO_ACTIVE_HIGH>;
71                 enable-active-high;
72         };
74         gpio-keys {
75                 compatible = "gpio-keys";
77                 vol-up-key {
78                         gpios = <&gpx2 0 GPIO_ACTIVE_LOW>;
79                         linux,code = <115>;
80                         label = "volume up";
81                         debounce-interval = <1>;
82                 };
84                 vol-down-key {
85                         gpios = <&gpx2 1 GPIO_ACTIVE_LOW>;
86                         linux,code = <114>;
87                         label = "volume down";
88                         debounce-interval = <1>;
89                 };
91                 config-key {
92                         gpios = <&gpx2 2 GPIO_ACTIVE_LOW>;
93                         linux,code = <171>;
94                         label = "config";
95                         debounce-interval = <1>;
96                         wakeup-source;
97                 };
99                 camera-key {
100                         gpios = <&gpx2 3 GPIO_ACTIVE_LOW>;
101                         linux,code = <212>;
102                         label = "camera";
103                         debounce-interval = <1>;
104                 };
106                 power-key {
107                         gpios = <&gpx2 7 GPIO_ACTIVE_LOW>;
108                         linux,code = <116>;
109                         label = "power";
110                         debounce-interval = <1>;
111                         wakeup-source;
112                 };
114                 ok-key {
115                         gpios = <&gpx3 5 GPIO_ACTIVE_LOW>;
116                         linux,code = <352>;
117                         label = "ok";
118                         debounce-interval = <1>;
119                 };
120         };
122         tsp_reg: voltage-regulator {
123                 compatible = "regulator-fixed";
124                 regulator-name = "TSP_2_8V";
125                 regulator-min-microvolt = <2800000>;
126                 regulator-max-microvolt = <2800000>;
127                 gpio = <&gpe2 3 GPIO_ACTIVE_HIGH>;
128                 enable-active-high;
129         };
131         spi-lcd {
132                 compatible = "spi-gpio";
133                 #address-cells = <1>;
134                 #size-cells = <0>;
136                 gpio-sck = <&gpy3 1 GPIO_ACTIVE_HIGH>;
137                 gpio-mosi = <&gpy3 3 GPIO_ACTIVE_HIGH>;
138                 num-chipselects = <1>;
139                 cs-gpios = <&gpy4 3 GPIO_ACTIVE_HIGH>;
141                 lcd@0 {
142                         compatible = "samsung,ld9040";
143                         reg = <0>;
144                         vdd3-supply = <&ldo7_reg>;
145                         vci-supply = <&ldo17_reg>;
146                         reset-gpios = <&gpy4 5 GPIO_ACTIVE_HIGH>;
147                         spi-max-frequency = <1200000>;
148                         spi-cpol;
149                         spi-cpha;
150                         power-on-delay = <10>;
151                         reset-delay = <10>;
152                         panel-width-mm = <90>;
153                         panel-height-mm = <154>;
154                         display-timings {
155                                 timing {
156                                         clock-frequency = <23492370>;
157                                         hactive = <480>;
158                                         vactive = <800>;
159                                         hback-porch = <16>;
160                                         hfront-porch = <16>;
161                                         vback-porch = <2>;
162                                         vfront-porch = <28>;
163                                         hsync-len = <2>;
164                                         vsync-len = <1>;
165                                         hsync-active = <0>;
166                                         vsync-active = <0>;
167                                         de-active = <0>;
168                                         pixelclk-active = <0>;
169                                 };
170                         };
171                         port {
172                                 lcd_ep: endpoint {
173                                         remote-endpoint = <&fimd_dpi_ep>;
174                                 };
175                         };
176                 };
177         };
179         camera {
180                 status = "okay";
182                 pinctrl-names = "default";
183                 pinctrl-0 = <>;
185                 fimc_0: fimc@11800000 {
186                         status = "okay";
187                         assigned-clocks = <&clock CLK_MOUT_FIMC0>,
188                                         <&clock CLK_SCLK_FIMC0>;
189                         assigned-clock-parents = <&clock CLK_SCLK_MPLL>;
190                         assigned-clock-rates = <0>, <160000000>;
191                 };
193                 fimc_1: fimc@11810000 {
194                         status = "okay";
195                         assigned-clocks = <&clock CLK_MOUT_FIMC1>,
196                                         <&clock CLK_SCLK_FIMC1>;
197                         assigned-clock-parents = <&clock CLK_SCLK_MPLL>;
198                         assigned-clock-rates = <0>, <160000000>;
199                 };
201                 fimc_2: fimc@11820000 {
202                         status = "okay";
203                         assigned-clocks = <&clock CLK_MOUT_FIMC2>,
204                                         <&clock CLK_SCLK_FIMC2>;
205                         assigned-clock-parents = <&clock CLK_SCLK_MPLL>;
206                         assigned-clock-rates = <0>, <160000000>;
207                 };
209                 fimc_3: fimc@11830000 {
210                         status = "okay";
211                         assigned-clocks = <&clock CLK_MOUT_FIMC3>,
212                                         <&clock CLK_SCLK_FIMC3>;
213                         assigned-clock-parents = <&clock CLK_SCLK_MPLL>;
214                         assigned-clock-rates = <0>, <160000000>;
215                 };
216         };
218         hdmi_en: voltage-regulator-hdmi-5v {
219                 compatible = "regulator-fixed";
220                 regulator-name = "HDMI_5V";
221                 regulator-min-microvolt = <5000000>;
222                 regulator-max-microvolt = <5000000>;
223                 gpio = <&gpe0 1 GPIO_ACTIVE_HIGH>;
224                 enable-active-high;
225         };
227         hdmi_ddc: i2c-ddc {
228                 compatible = "i2c-gpio";
229                 gpios = <&gpe4 2 GPIO_ACTIVE_HIGH &gpe4 3 GPIO_ACTIVE_HIGH>;
230                 i2c-gpio,delay-us = <100>;
231                 #address-cells = <1>;
232                 #size-cells = <0>;
234                 pinctrl-0 = <&i2c_ddc_bus>;
235                 pinctrl-names = "default";
236                 status = "okay";
237         };
240 &cpu0 {
241         cpu0-supply = <&vdd_arm_reg>;
244 &ehci {
245         status = "okay";
246         port@0 {
247                 status = "okay";
248         };
251 &exynos_usbphy {
252         status = "okay";
253         vbus-supply = <&safeout1_reg>;
256 &fimd {
257         pinctrl-0 = <&lcd_clk>, <&lcd_data24>;
258         pinctrl-names = "default";
259         status = "okay";
260         samsung,invert-vden;
261         samsung,invert-vclk;
262         #address-cells = <1>;
263         #size-cells = <0>;
264         port@3 {
265                 reg = <3>;
266                 fimd_dpi_ep: endpoint {
267                         remote-endpoint = <&lcd_ep>;
268                 };
269         };
272 &hdmi {
273         hpd-gpios = <&gpx3 7 GPIO_ACTIVE_HIGH>;
274         pinctrl-names = "default";
275         pinctrl-0 = <&hdmi_hpd>;
276         hdmi-en-supply = <&hdmi_en>;
277         vdd-supply = <&ldo3_reg>;
278         vdd_osc-supply = <&ldo4_reg>;
279         vdd_pll-supply = <&ldo3_reg>;
280         ddc = <&hdmi_ddc>;
281         status = "okay";
284 &hsotg {
285         vusb_d-supply = <&ldo3_reg>;
286         vusb_a-supply = <&ldo8_reg>;
287         dr_mode = "peripheral";
288         status = "okay";
291 &i2c_3 {
292         samsung,i2c-sda-delay = <100>;
293         samsung,i2c-slave-addr = <0x10>;
294         samsung,i2c-max-bus-freq = <100000>;
295         pinctrl-0 = <&i2c3_bus>;
296         pinctrl-names = "default";
297         status = "okay";
299         tsp@4a {
300                 /* TBD: Atmel maXtouch touchscreen */
301                 reg = <0x4a>;
302         };
305 &i2c_5 {
306         samsung,i2c-sda-delay = <100>;
307         samsung,i2c-slave-addr = <0x10>;
308         samsung,i2c-max-bus-freq = <100000>;
309         pinctrl-0 = <&i2c5_bus>;
310         pinctrl-names = "default";
311         status = "okay";
313         vdd_arm_reg: pmic@60 {
314                 compatible = "maxim,max8952";
315                 reg = <0x60>;
317                 max8952,vid-gpios = <&gpx0 3 GPIO_ACTIVE_HIGH>,
318                                     <&gpx0 4 GPIO_ACTIVE_HIGH>;
319                 max8952,default-mode = <0>;
320                 max8952,dvs-mode-microvolt = <1250000>, <1200000>,
321                                                 <1050000>, <950000>;
322                 max8952,sync-freq = <0>;
323                 max8952,ramp-speed = <0>;
325                 regulator-name = "vdd_arm";
326                 regulator-min-microvolt = <770000>;
327                 regulator-max-microvolt = <1400000>;
328                 regulator-always-on;
329                 regulator-boot-on;
330         };
332         pmic@66 {
333                 compatible = "national,lp3974";
334                 reg = <0x66>;
336                 max8998,pmic-buck1-default-dvs-idx = <0>;
337                 max8998,pmic-buck1-dvs-gpios = <&gpx0 5 GPIO_ACTIVE_HIGH>,
338                                                 <&gpx0 6 GPIO_ACTIVE_HIGH>;
339                 max8998,pmic-buck1-dvs-voltage = <1100000>, <1000000>,
340                                                 <1100000>, <1000000>;
342                 max8998,pmic-buck2-default-dvs-idx = <0>;
343                 max8998,pmic-buck2-dvs-gpio = <&gpe2 0 GPIO_ACTIVE_HIGH>;
344                 max8998,pmic-buck2-dvs-voltage = <1200000>, <1100000>;
346                 regulators {
347                         ldo2_reg: LDO2 {
348                                 regulator-name = "VALIVE_1.2V";
349                                 regulator-min-microvolt = <1200000>;
350                                 regulator-max-microvolt = <1200000>;
351                                 regulator-always-on;
352                         };
354                         ldo3_reg: LDO3 {
355                                 regulator-name = "VUSB+MIPI_1.1V";
356                                 regulator-min-microvolt = <1100000>;
357                                 regulator-max-microvolt = <1100000>;
358                                 regulator-always-on;
359                         };
361                         ldo4_reg: LDO4 {
362                                 regulator-name = "VADC_3.3V";
363                                 regulator-min-microvolt = <3300000>;
364                                 regulator-max-microvolt = <3300000>;
365                         };
367                         ldo5_reg: LDO5 {
368                                 regulator-name = "VTF_2.8V";
369                                 regulator-min-microvolt = <2800000>;
370                                 regulator-max-microvolt = <2800000>;
371                         };
373                         ldo6_reg: LDO6 {
374                                 regulator-name = "LDO6";
375                                 regulator-min-microvolt = <2000000>;
376                                 regulator-max-microvolt = <2000000>;
377                         };
379                         ldo7_reg: LDO7 {
380                                 regulator-name = "VLCD+VMIPI_1.8V";
381                                 regulator-min-microvolt = <1800000>;
382                                 regulator-max-microvolt = <1800000>;
383                         };
385                         ldo8_reg: LDO8 {
386                                 regulator-name = "VUSB+VDAC_3.3V";
387                                 regulator-min-microvolt = <3300000>;
388                                 regulator-max-microvolt = <3300000>;
389                                 regulator-always-on;
390                         };
392                         ldo9_reg: LDO9 {
393                                 regulator-name = "VCC_2.8V";
394                                 regulator-min-microvolt = <2800000>;
395                                 regulator-max-microvolt = <2800000>;
396                                 regulator-always-on;
397                         };
399                         ldo10_reg: LDO10 {
400                                 regulator-name = "VPLL_1.1V";
401                                 regulator-min-microvolt = <1100000>;
402                                 regulator-max-microvolt = <1100000>;
403                                 regulator-boot-on;
404                                 regulator-always-on;
405                         };
407                         ldo11_reg: LDO11 {
408                                 regulator-name = "CAM_AF_3.3V";
409                                 regulator-min-microvolt = <3300000>;
410                                 regulator-max-microvolt = <3300000>;
411                         };
413                         ldo12_reg: LDO12 {
414                                 regulator-name = "PS_2.8V";
415                                 regulator-min-microvolt = <2800000>;
416                                 regulator-max-microvolt = <2800000>;
417                         };
419                         ldo13_reg: LDO13 {
420                                 regulator-name = "VHIC_1.2V";
421                                 regulator-min-microvolt = <1200000>;
422                                 regulator-max-microvolt = <1200000>;
423                         };
425                         ldo14_reg: LDO14 {
426                                 regulator-name = "CAM_I_HOST_1.8V";
427                                 regulator-min-microvolt = <1800000>;
428                                 regulator-max-microvolt = <1800000>;
429                         };
431                         ldo15_reg: LDO15 {
432                                 regulator-name = "CAM_S_DIG+FM33_CORE_1.2V";
433                                 regulator-min-microvolt = <1200000>;
434                                 regulator-max-microvolt = <1200000>;
435                         };
437                         ldo16_reg: LDO16 {
438                                 regulator-name = "CAM_S_ANA_2.8V";
439                                 regulator-min-microvolt = <2800000>;
440                                 regulator-max-microvolt = <2800000>;
441                         };
443                         ldo17_reg: LDO17 {
444                                 regulator-name = "VCC_3.0V_LCD";
445                                 regulator-min-microvolt = <3000000>;
446                                 regulator-max-microvolt = <3000000>;
447                         };
449                         buck1_reg: BUCK1 {
450                                 regulator-name = "VINT_1.1V";
451                                 regulator-min-microvolt = <750000>;
452                                 regulator-max-microvolt = <1500000>;
453                                 regulator-boot-on;
454                                 regulator-always-on;
455                         };
457                         buck2_reg: BUCK2 {
458                                 regulator-name = "VG3D_1.1V";
459                                 regulator-min-microvolt = <750000>;
460                                 regulator-max-microvolt = <1500000>;
461                                 regulator-boot-on;
462                         };
464                         buck3_reg: BUCK3 {
465                                 regulator-name = "VCC_1.8V";
466                                 regulator-min-microvolt = <1800000>;
467                                 regulator-max-microvolt = <1800000>;
468                                 regulator-always-on;
469                         };
471                         buck4_reg: BUCK4 {
472                                 regulator-name = "VMEM_1.2V";
473                                 regulator-min-microvolt = <1200000>;
474                                 regulator-max-microvolt = <1200000>;
475                                 regulator-always-on;
476                         };
478                         ap32khz_reg: EN32KHz-AP {
479                                 regulator-name = "32KHz AP";
480                                 regulator-always-on;
481                         };
483                         cp32khz_reg: EN32KHz-CP {
484                                 regulator-name = "32KHz CP";
485                         };
487                         vichg_reg: ENVICHG {
488                                 regulator-name = "VICHG";
489                         };
491                         safeout1_reg: ESAFEOUT1 {
492                                 regulator-name = "SAFEOUT1";
493                         };
495                         safeout2_reg: ESAFEOUT2 {
496                                 regulator-name = "SAFEOUT2";
497                                 regulator-boot-on;
498                         };
499                 };
500         };
503 &i2c_8 {
504         status = "okay";
507 &mdma1 {
508         reg = <0x12840000 0x1000>;
511 &mixer {
512         status = "okay";
515 &ohci {
516         status = "okay";
517         port@0 {
518                 status = "okay";
519         };
522 &pinctrl_1 {
523         hdmi_hpd: hdmi-hpd {
524                 samsung,pins = "gpx3-7";
525                 samsung,pin-pud = <EXYNOS_PIN_PULL_NONE>;
526         };
529 &pinctrl_0 {
530         i2c_ddc_bus: i2c-ddc-bus {
531                 samsung,pins = "gpe4-2", "gpe4-3";
532                 samsung,pin-function = <EXYNOS_PIN_FUNC_2>;
533                 samsung,pin-pud = <EXYNOS_PIN_PULL_UP>;
534                 samsung,pin-drv = <EXYNOS4_PIN_DRV_LV1>;
535         };
538 &pwm {
539         compatible = "samsung,s5p6440-pwm";
540         status = "okay";
543 &sdhci_0 {
544         bus-width = <8>;
545         non-removable;
546         pinctrl-0 = <&sd0_clk &sd0_cmd &sd0_bus8>;
547         pinctrl-names = "default";
548         vmmc-supply = <&vemmc_reg>;
549         status = "okay";
552 &sdhci_2 {
553         bus-width = <4>;
554         pinctrl-0 = <&sd2_clk &sd2_cmd &sd2_bus4>;
555         pinctrl-names = "default";
556         vmmc-supply = <&ldo5_reg>;
557         cd-gpios = <&gpx3 4 GPIO_ACTIVE_HIGH>;
558         cd-inverted;
559         status = "okay";
562 &serial_0 {
563         status = "okay";
564         /delete-property/dmas;
565         /delete-property/dma-names;
568 &serial_1 {
569         status = "okay";
570         /delete-property/dmas;
571         /delete-property/dma-names;
574 &serial_2 {
575         status = "okay";
576         /delete-property/dmas;
577         /delete-property/dma-names;
580 &serial_3 {
581         status = "okay";
582         /delete-property/dmas;
583         /delete-property/dma-names;