2 * Copyright (C) 2013 Pavel Machek <pavel@ucw.cz>
3 * Copyright 2013 Aaro Koskinen <aaro.koskinen@iki.fi>
5 * This program is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License version 2 (or later) as
7 * published by the Free Software Foundation.
12 #include "omap34xx-hs.dtsi"
16 compatible = "nokia,omap3-n900", "ti,omap3";
25 device_type = "memory";
26 reg = <0x80000000 0x10000000>; /* 256 MB */
30 compatible = "gpio-keys";
33 label = "Camera Lens Cover";
34 gpios = <&gpio4 14 GPIO_ACTIVE_LOW>; /* 110 */
35 linux,input-type = <5>; /* EV_SW */
36 linux,code = <0x09>; /* SW_CAMERA_LENS_COVER */
41 label = "Camera Focus";
42 gpios = <&gpio3 4 GPIO_ACTIVE_LOW>; /* 68 */
43 linux,code = <0x210>; /* KEY_CAMERA_FOCUS */
48 label = "Camera Capture";
49 gpios = <&gpio3 5 GPIO_ACTIVE_LOW>; /* 69 */
50 linux,code = <0xd4>; /* KEY_CAMERA */
55 label = "Lock Button";
56 gpios = <&gpio4 17 GPIO_ACTIVE_LOW>; /* 113 */
57 linux,code = <0x98>; /* KEY_SCREENLOCK */
62 label = "Keypad Slide";
63 gpios = <&gpio3 7 GPIO_ACTIVE_LOW>; /* 71 */
64 linux,input-type = <5>; /* EV_SW */
65 linux,code = <0x0a>; /* SW_KEYPAD_SLIDE */
70 label = "Proximity Sensor";
71 gpios = <&gpio3 25 GPIO_ACTIVE_HIGH>; /* 89 */
72 linux,input-type = <5>; /* EV_SW */
73 linux,code = <0x0b>; /* SW_FRONT_PROXIMITY */
80 pinctrl-names = "default";
82 uart2_pins: pinmux_uart2_pins {
83 pinctrl-single,pins = <
84 0x14a (PIN_INPUT | MUX_MODE0) /* uart2_rx */
85 0x148 (PIN_OUTPUT | MUX_MODE0) /* uart2_tx */
89 uart3_pins: pinmux_uart3_pins {
90 pinctrl-single,pins = <
91 0x16e (PIN_INPUT | MUX_MODE0) /* uart3_rx */
92 0x170 (PIN_OUTPUT | MUX_MODE0) /* uart3_tx */
96 i2c1_pins: pinmux_i2c1_pins {
97 pinctrl-single,pins = <
98 0x18a (PIN_INPUT_PULLUP | MUX_MODE0) /* i2c1_scl */
99 0x18c (PIN_INPUT_PULLUP | MUX_MODE0) /* i2c1_sda */
103 i2c2_pins: pinmux_i2c2_pins {
104 pinctrl-single,pins = <
105 0x18e (PIN_INPUT_PULLUP | MUX_MODE0) /* i2c2_scl */
106 0x190 (PIN_INPUT_PULLUP | MUX_MODE0) /* i2c2_sda */
110 i2c3_pins: pinmux_i2c3_pins {
111 pinctrl-single,pins = <
112 0x192 (PIN_INPUT_PULLUP | MUX_MODE0) /* i2c3_scl */
113 0x194 (PIN_INPUT_PULLUP | MUX_MODE0) /* i2c3_sda */
117 mmc1_pins: pinmux_mmc1_pins {
118 pinctrl-single,pins = <
119 0x114 (PIN_INPUT_PULLUP | MUX_MODE0) /* sdmmc1_clk */
120 0x116 (PIN_INPUT_PULLUP | MUX_MODE0) /* sdmmc1_cmd */
121 0x118 (PIN_INPUT_PULLUP | MUX_MODE0) /* sdmmc1_dat0 */
122 0x11a (PIN_INPUT_PULLUP | MUX_MODE0) /* sdmmc1_dat1 */
123 0x11c (PIN_INPUT_PULLUP | MUX_MODE0) /* sdmmc1_dat2 */
124 0x11e (PIN_INPUT_PULLUP | MUX_MODE0) /* sdmmc1_dat3 */
128 mmc2_pins: pinmux_mmc2_pins {
129 pinctrl-single,pins = <
130 0x128 (PIN_INPUT_PULLUP | MUX_MODE0) /* sdmmc2_clk */
131 0x12a (PIN_INPUT_PULLUP | MUX_MODE0) /* sdmmc2_cmd */
132 0x12c (PIN_INPUT_PULLUP | MUX_MODE0) /* sdmmc2_dat0 */
133 0x12e (PIN_INPUT_PULLUP | MUX_MODE0) /* sdmmc2_dat1 */
134 0x130 (PIN_INPUT_PULLUP | MUX_MODE0) /* sdmmc2_dat2 */
135 0x132 (PIN_INPUT_PULLUP | MUX_MODE0) /* sdmmc2_dat3 */
136 0x134 (PIN_INPUT_PULLUP | MUX_MODE0) /* sdmmc2_dat4 */
137 0x136 (PIN_INPUT_PULLUP | MUX_MODE0) /* sdmmc2_dat5 */
138 0x138 (PIN_INPUT_PULLUP | MUX_MODE0) /* sdmmc2_dat6 */
139 0x13a (PIN_INPUT_PULLUP | MUX_MODE0) /* sdmmc2_dat7 */
143 display_pins: pinmux_display_pins {
144 pinctrl-single,pins = <
145 0x0d4 (PIN_OUTPUT | MUX_MODE4) /* RX51_LCD_RESET_GPIO */
151 pinctrl-names = "default";
152 pinctrl-0 = <&i2c1_pins>;
154 clock-frequency = <2200000>;
158 interrupts = <7>; /* SYS_NIRQ cascaded to intc */
159 interrupt-parent = <&intc>;
163 #include "twl4030.dtsi"
164 #include "twl4030_omap3.dtsi"
167 regulator-name = "V28";
168 regulator-min-microvolt = <2800000>;
169 regulator-max-microvolt = <2800000>;
170 regulator-always-on; /* due battery cover sensor */
174 regulator-name = "VCSI";
175 regulator-min-microvolt = <1800000>;
176 regulator-max-microvolt = <1800000>;
180 regulator-name = "VMMC2_30";
181 regulator-min-microvolt = <2800000>;
182 regulator-max-microvolt = <3000000>;
186 regulator-name = "VCAM_ANA_28";
187 regulator-min-microvolt = <2800000>;
188 regulator-max-microvolt = <2800000>;
192 regulator-name = "VMMC1";
193 regulator-min-microvolt = <1850000>;
194 regulator-max-microvolt = <3150000>;
198 regulator-name = "V28_A";
199 regulator-min-microvolt = <2800000>;
200 regulator-max-microvolt = <3000000>;
201 regulator-always-on; /* due VIO leak to AIC34 VDDs */
205 regulator-name = "VPLL";
206 regulator-min-microvolt = <1800000>;
207 regulator-max-microvolt = <1800000>;
212 regulator-name = "VSDI_CSI";
213 regulator-min-microvolt = <1800000>;
214 regulator-max-microvolt = <1800000>;
219 regulator-name = "VMMC2_IO_18";
220 regulator-min-microvolt = <1800000>;
221 regulator-max-microvolt = <1800000>;
225 regulator-name = "VIO";
226 regulator-min-microvolt = <1800000>;
227 regulator-max-microvolt = <1800000>;
232 regulator-name = "VINTANA1";
233 /* fixed to 1500000 */
238 regulator-name = "VINTANA2";
239 regulator-min-microvolt = <2750000>;
240 regulator-max-microvolt = <2750000>;
245 regulator-name = "VINTDIG";
246 /* fixed to 1500000 */
252 compatible = "ti,twl4030-audio";
253 ti,enable-vibra = <1>;
259 ti,pulldowns = <0x03ff3f>; /* BIT(0..5) | BIT(8..17) */
263 pinctrl-names = "default";
264 pinctrl-0 = <&i2c2_pins>;
266 clock-frequency = <100000>;
268 tlv320aic3x: tlv320aic3x@18 {
269 compatible = "ti,tlv320aic3x";
271 gpio-reset = <&gpio2 28 GPIO_ACTIVE_HIGH>; /* 60 */
273 0 /* AIC3X_GPIO1_FUNC_DISABLED */
274 5 /* AIC3X_GPIO2_FUNC_DIGITAL_MIC_INPUT */
277 AVDD-supply = <&vmmc2>;
278 DRVDD-supply = <&vmmc2>;
279 IOVDD-supply = <&vio>;
280 DVDD-supply = <&vio>;
283 tlv320aic3x_aux: tlv320aic3x@19 {
284 compatible = "ti,tlv320aic3x";
286 gpio-reset = <&gpio2 28 GPIO_ACTIVE_HIGH>; /* 60 */
288 AVDD-supply = <&vmmc2>;
289 DRVDD-supply = <&vmmc2>;
290 IOVDD-supply = <&vio>;
291 DVDD-supply = <&vio>;
295 compatible = "national,lp5523";
297 clock-mode = /bits/ 8 <0>; /* LP55XX_CLOCK_AUTO */
298 enable-gpio = <&gpio2 9 GPIO_ACTIVE_HIGH>; /* 41 */
301 chan-name = "lp5523:kb1";
302 led-cur = /bits/ 8 <50>;
303 max-cur = /bits/ 8 <100>;
307 chan-name = "lp5523:kb2";
308 led-cur = /bits/ 8 <50>;
309 max-cur = /bits/ 8 <100>;
313 chan-name = "lp5523:kb3";
314 led-cur = /bits/ 8 <50>;
315 max-cur = /bits/ 8 <100>;
319 chan-name = "lp5523:kb4";
320 led-cur = /bits/ 8 <50>;
321 max-cur = /bits/ 8 <100>;
325 chan-name = "lp5523:b";
326 led-cur = /bits/ 8 <50>;
327 max-cur = /bits/ 8 <100>;
331 chan-name = "lp5523:g";
332 led-cur = /bits/ 8 <50>;
333 max-cur = /bits/ 8 <100>;
337 chan-name = "lp5523:r";
338 led-cur = /bits/ 8 <50>;
339 max-cur = /bits/ 8 <100>;
343 chan-name = "lp5523:kb5";
344 led-cur = /bits/ 8 <50>;
345 max-cur = /bits/ 8 <100>;
349 chan-name = "lp5523:kb6";
350 led-cur = /bits/ 8 <50>;
351 max-cur = /bits/ 8 <100>;
355 bq27200: bq27200@55 {
356 compatible = "ti,bq27200";
362 pinctrl-names = "default";
363 pinctrl-0 = <&i2c3_pins>;
365 clock-frequency = <400000>;
369 pinctrl-names = "default";
370 pinctrl-0 = <&mmc1_pins>;
371 vmmc-supply = <&vmmc1>;
373 cd-gpios = <&gpio6 0 GPIO_ACTIVE_HIGH>; /* 160 */
376 /* most boards use vaux3, only some old versions use vmmc2 instead */
378 pinctrl-names = "default";
379 pinctrl-0 = <&mmc2_pins>;
380 vmmc-supply = <&vaux3>;
381 vmmc_aux-supply = <&vsim>;
391 ranges = <0 0 0x04000000 0x10000000>; /* 256MB */
393 /* gpio-irq for dma: 65 */
396 #address-cells = <1>;
398 reg = <0 0 0x10000000>;
402 gpmc,burst-length = <16>;
406 gpmc,device-width = <2>; /* GPMC_DEVWIDTH_16BIT */
407 gpmc,mux-add-data = <2>; /* GPMC_MUX_AD */
409 gpmc,cs-rd-off-ns = <87>;
410 gpmc,cs-wr-off-ns = <87>;
411 gpmc,adv-on-ns = <0>;
412 gpmc,adv-rd-off-ns = <10>;
413 gpmc,adv-wr-off-ns = <10>;
414 gpmc,oe-on-ns = <15>;
415 gpmc,oe-off-ns = <87>;
417 gpmc,we-off-ns = <87>;
418 gpmc,rd-cycle-ns = <112>;
419 gpmc,wr-cycle-ns = <112>;
420 gpmc,access-ns = <81>;
421 gpmc,page-burst-access-ns = <15>;
422 gpmc,bus-turnaround-ns = <0>;
423 gpmc,cycle2cycle-delay-ns = <0>;
424 gpmc,wait-monitoring-ns = <0>;
425 gpmc,clk-activation-ns = <5>;
426 gpmc,wr-data-mux-bus-ns = <30>;
427 gpmc,wr-access-ns = <81>;
428 gpmc,sync-clk-ps = <15000>;
431 * MTD partition table corresponding to Nokia's
432 * Maemo 5 (Fremantle) release.
435 label = "bootloader";
436 reg = <0x00000000 0x00020000>;
441 reg = <0x00020000 0x00060000>;
445 reg = <0x00080000 0x00040000>;
449 reg = <0x000c0000 0x00200000>;
453 reg = <0x002c0000 0x00200000>;
457 reg = <0x004c0000 0x0fb40000>;
464 * For some reason, touchscreen is necessary for screen to work at
465 * all on real hw. It works well without it on emulator.
467 * Also... order in the device tree actually matters here.
470 compatible = "tsc2005";
471 spi-max-frequency = <6000000>;
475 compatible = "acx565akm";
476 spi-max-frequency = <6000000>;
479 pinctrl-names = "default";
480 pinctrl-0 = <&display_pins>;
485 interface-type = <0>;
486 usb-phy = <&usb2_phy>;
488 phy-names = "usb2-phy";
498 pinctrl-names = "default";
499 pinctrl-0 = <&uart2_pins>;
503 pinctrl-names = "default";
504 pinctrl-0 = <&uart3_pins>;