blob: 79c1881226778e56772abab679e0a063d9d074ee [file] [log] [blame]
Pavel Macheka4d4b152013-08-13 15:36:36 +02001/*
2 * Copyright (C) 2013 Pavel Machek <pavel@ucw.cz>
3 * Copyright 2013 Aaro Koskinen <aaro.koskinen@iki.fi>
4 *
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.
8 */
9
10/dts-v1/;
11
Tony Lindgrenf2e2c9d2013-12-06 14:20:17 -080012#include "omap34xx-hs.dtsi"
Pavel Macheka4d4b152013-08-13 15:36:36 +020013
14/ {
15 model = "Nokia N900";
16 compatible = "nokia,omap3-n900", "ti,omap3";
17
18 cpus {
19 cpu@0 {
20 cpu0-supply = <&vcc>;
21 };
22 };
23
24 memory {
25 device_type = "memory";
26 reg = <0x80000000 0x10000000>; /* 256 MB */
27 };
28
Sebastian Reichel3931c8392013-10-23 00:49:34 +020029 gpio_keys {
30 compatible = "gpio-keys";
31
32 camera_lens_cover {
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 */
37 gpio-key,wakeup;
38 };
39
40 camera_focus {
41 label = "Camera Focus";
42 gpios = <&gpio3 4 GPIO_ACTIVE_LOW>; /* 68 */
43 linux,code = <0x210>; /* KEY_CAMERA_FOCUS */
44 gpio-key,wakeup;
45 };
46
47 camera_capture {
48 label = "Camera Capture";
49 gpios = <&gpio3 5 GPIO_ACTIVE_LOW>; /* 69 */
50 linux,code = <0xd4>; /* KEY_CAMERA */
51 gpio-key,wakeup;
52 };
53
54 lock_button {
55 label = "Lock Button";
56 gpios = <&gpio4 17 GPIO_ACTIVE_LOW>; /* 113 */
57 linux,code = <0x98>; /* KEY_SCREENLOCK */
58 gpio-key,wakeup;
59 };
60
61 keypad_slide {
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 */
66 gpio-key,wakeup;
67 };
68
69 proximity_sensor {
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 */
74 };
75 };
76
Pavel Macheka4d4b152013-08-13 15:36:36 +020077};
78
Sebastian Reichelac888a82013-10-23 00:49:30 +020079&omap3_pmx_core {
80 pinctrl-names = "default";
81
Sebastian Reichel7a89eec2013-10-23 00:49:32 +020082 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 */
86 >;
87 };
88
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 */
93 >;
94 };
95
Sebastian Reichelac888a82013-10-23 00:49:30 +020096 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 */
100 >;
101 };
102
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 */
107 >;
108 };
109
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 */
114 >;
115 };
Sebastian Reichelf1751cf2013-10-23 00:49:33 +0200116
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 */
125 >;
126 };
Sebastian Reicheld1e6f512013-10-23 00:49:40 +0200127
Tony Lindgrenedd5eb42013-11-25 14:23:45 -0800128 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 */
140 >;
141 };
142
Sebastian Reicheld1e6f512013-10-23 00:49:40 +0200143 display_pins: pinmux_display_pins {
144 pinctrl-single,pins = <
145 0x0d4 (PIN_OUTPUT | MUX_MODE4) /* RX51_LCD_RESET_GPIO */
146 >;
147 };
Sebastian Reichelac888a82013-10-23 00:49:30 +0200148};
149
Pavel Macheka4d4b152013-08-13 15:36:36 +0200150&i2c1 {
Sebastian Reichelac888a82013-10-23 00:49:30 +0200151 pinctrl-names = "default";
152 pinctrl-0 = <&i2c1_pins>;
153
Pavel Macheka4d4b152013-08-13 15:36:36 +0200154 clock-frequency = <2200000>;
155
156 twl: twl@48 {
157 reg = <0x48>;
158 interrupts = <7>; /* SYS_NIRQ cascaded to intc */
159 interrupt-parent = <&intc>;
160 };
161};
162
163#include "twl4030.dtsi"
Sebastian Reichelac888a82013-10-23 00:49:30 +0200164#include "twl4030_omap3.dtsi"
Pavel Macheka4d4b152013-08-13 15:36:36 +0200165
Sebastian Reichel9cdbbad2013-10-23 00:49:38 +0200166&vaux1 {
167 regulator-name = "V28";
168 regulator-min-microvolt = <2800000>;
169 regulator-max-microvolt = <2800000>;
170 regulator-always-on; /* due battery cover sensor */
171};
172
173&vaux2 {
174 regulator-name = "VCSI";
175 regulator-min-microvolt = <1800000>;
176 regulator-max-microvolt = <1800000>;
177};
178
179&vaux3 {
180 regulator-name = "VMMC2_30";
181 regulator-min-microvolt = <2800000>;
182 regulator-max-microvolt = <3000000>;
183};
184
185&vaux4 {
186 regulator-name = "VCAM_ANA_28";
187 regulator-min-microvolt = <2800000>;
188 regulator-max-microvolt = <2800000>;
189};
190
191&vmmc1 {
192 regulator-name = "VMMC1";
193 regulator-min-microvolt = <1850000>;
194 regulator-max-microvolt = <3150000>;
195};
196
197&vmmc2 {
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 */
202};
203
204&vpll1 {
205 regulator-name = "VPLL";
206 regulator-min-microvolt = <1800000>;
207 regulator-max-microvolt = <1800000>;
208 regulator-always-on;
209};
210
211&vpll2 {
212 regulator-name = "VSDI_CSI";
213 regulator-min-microvolt = <1800000>;
214 regulator-max-microvolt = <1800000>;
215 regulator-always-on;
216};
217
218&vsim {
219 regulator-name = "VMMC2_IO_18";
220 regulator-min-microvolt = <1800000>;
221 regulator-max-microvolt = <1800000>;
222};
223
224&vio {
225 regulator-name = "VIO";
226 regulator-min-microvolt = <1800000>;
227 regulator-max-microvolt = <1800000>;
228
229};
230
231&vintana1 {
232 regulator-name = "VINTANA1";
233 /* fixed to 1500000 */
234 regulator-always-on;
235};
236
237&vintana2 {
238 regulator-name = "VINTANA2";
239 regulator-min-microvolt = <2750000>;
240 regulator-max-microvolt = <2750000>;
241 regulator-always-on;
242};
243
244&vintdig {
245 regulator-name = "VINTDIG";
246 /* fixed to 1500000 */
247 regulator-always-on;
248};
249
Sebastian Reichel06ba7a62013-10-23 00:49:35 +0200250&twl {
251 twl_audio: audio {
252 compatible = "ti,twl4030-audio";
253 ti,enable-vibra = <1>;
254 };
255};
256
Sebastian Reichel85c215f2014-01-11 22:16:59 +0100257&twl_keypad {
258 linux,keymap = < 0x00000010 /* KEY_Q */
259 0x00010018 /* KEY_O */
260 0x00020019 /* KEY_P */
261 0x00030033 /* KEY_COMMA */
262 0x0004000e /* KEY_BACKSPACE */
263 0x0006001e /* KEY_A */
264 0x0007001f /* KEY_S */
265
266 0x01000011 /* KEY_W */
267 0x01010020 /* KEY_D */
268 0x01020021 /* KEY_F */
269 0x01030022 /* KEY_G */
270 0x01040023 /* KEY_H */
271 0x01050024 /* KEY_J */
272 0x01060025 /* KEY_K */
273 0x01070026 /* KEY_L */
274
275 0x02000012 /* KEY_E */
276 0x02010034 /* KEY_DOT */
277 0x02020067 /* KEY_UP */
278 0x0203001c /* KEY_ENTER */
279 0x0205002c /* KEY_Z */
280 0x0206002d /* KEY_X */
281 0x0207002e /* KEY_C */
282 0x02080043 /* KEY_F9 */
283
284 0x03000013 /* KEY_R */
285 0x0301002f /* KEY_V */
286 0x03020030 /* KEY_B */
287 0x03030031 /* KEY_N */
288 0x03040032 /* KEY_M */
289 0x03050039 /* KEY_SPACE */
290 0x03060039 /* KEY_SPACE */
291 0x03070069 /* KEY_LEFT */
292
293 0x04000014 /* KEY_T */
294 0x0401006c /* KEY_DOWN */
295 0x0402006a /* KEY_RIGHT */
296 0x0404001d /* KEY_LEFTCTRL */
297 0x04050064 /* KEY_RIGHTALT */
298 0x0406002a /* KEY_LEFTSHIFT */
299 0x04080044 /* KEY_F10 */
300
301 0x05000015 /* KEY_Y */
302 0x05080057 /* KEY_F11 */
303
304 0x06000016 /* KEY_U */
305
306 0x07000017 /* KEY_I */
307 0x07010041 /* KEY_F7 */
308 0x07020042 /* KEY_F8 */
309 >;
310};
311
Pavel Macheka4d4b152013-08-13 15:36:36 +0200312&twl_gpio {
313 ti,pullups = <0x0>;
314 ti,pulldowns = <0x03ff3f>; /* BIT(0..5) | BIT(8..17) */
315};
316
317&i2c2 {
Sebastian Reichelac888a82013-10-23 00:49:30 +0200318 pinctrl-names = "default";
319 pinctrl-0 = <&i2c2_pins>;
320
Sebastian Reichel48fc9862013-10-23 00:49:31 +0200321 clock-frequency = <100000>;
Sebastian Reichelb2b9b252013-10-23 00:49:36 +0200322
Sebastian Reichel14e3e292013-10-23 00:49:41 +0200323 tlv320aic3x: tlv320aic3x@18 {
324 compatible = "ti,tlv320aic3x";
325 reg = <0x18>;
326 gpio-reset = <&gpio2 28 GPIO_ACTIVE_HIGH>; /* 60 */
327 ai3x-gpio-func = <
328 0 /* AIC3X_GPIO1_FUNC_DISABLED */
329 5 /* AIC3X_GPIO2_FUNC_DIGITAL_MIC_INPUT */
330 >;
331
332 AVDD-supply = <&vmmc2>;
333 DRVDD-supply = <&vmmc2>;
334 IOVDD-supply = <&vio>;
335 DVDD-supply = <&vio>;
336 };
337
338 tlv320aic3x_aux: tlv320aic3x@19 {
339 compatible = "ti,tlv320aic3x";
340 reg = <0x19>;
341 gpio-reset = <&gpio2 28 GPIO_ACTIVE_HIGH>; /* 60 */
342
343 AVDD-supply = <&vmmc2>;
344 DRVDD-supply = <&vmmc2>;
345 IOVDD-supply = <&vio>;
346 DVDD-supply = <&vio>;
347 };
348
Sebastian Reichel12f2f872014-01-11 22:17:00 +0100349 tsl2563: tsl2563@29 {
350 compatible = "amstaos,tsl2563";
351 reg = <0x29>;
352
353 amstaos,cover-comp-gain = <16>;
354 };
355
Sebastian Reichela0bf1f32013-10-23 00:49:42 +0200356 lp5523: lp5523@32 {
357 compatible = "national,lp5523";
358 reg = <0x32>;
359 clock-mode = /bits/ 8 <0>; /* LP55XX_CLOCK_AUTO */
360 enable-gpio = <&gpio2 9 GPIO_ACTIVE_HIGH>; /* 41 */
361
362 chan0 {
363 chan-name = "lp5523:kb1";
364 led-cur = /bits/ 8 <50>;
365 max-cur = /bits/ 8 <100>;
366 };
367
368 chan1 {
369 chan-name = "lp5523:kb2";
370 led-cur = /bits/ 8 <50>;
371 max-cur = /bits/ 8 <100>;
372 };
373
374 chan2 {
375 chan-name = "lp5523:kb3";
376 led-cur = /bits/ 8 <50>;
377 max-cur = /bits/ 8 <100>;
378 };
379
380 chan3 {
381 chan-name = "lp5523:kb4";
382 led-cur = /bits/ 8 <50>;
383 max-cur = /bits/ 8 <100>;
384 };
385
386 chan4 {
387 chan-name = "lp5523:b";
388 led-cur = /bits/ 8 <50>;
389 max-cur = /bits/ 8 <100>;
390 };
391
392 chan5 {
393 chan-name = "lp5523:g";
394 led-cur = /bits/ 8 <50>;
395 max-cur = /bits/ 8 <100>;
396 };
397
398 chan6 {
399 chan-name = "lp5523:r";
400 led-cur = /bits/ 8 <50>;
401 max-cur = /bits/ 8 <100>;
402 };
403
404 chan7 {
405 chan-name = "lp5523:kb5";
406 led-cur = /bits/ 8 <50>;
407 max-cur = /bits/ 8 <100>;
408 };
409
410 chan8 {
411 chan-name = "lp5523:kb6";
412 led-cur = /bits/ 8 <50>;
413 max-cur = /bits/ 8 <100>;
414 };
415 };
416
Sebastian Reichelb2b9b252013-10-23 00:49:36 +0200417 bq27200: bq27200@55 {
418 compatible = "ti,bq27200";
419 reg = <0x55>;
420 };
Pavel Macheka4d4b152013-08-13 15:36:36 +0200421};
422
423&i2c3 {
Sebastian Reichelac888a82013-10-23 00:49:30 +0200424 pinctrl-names = "default";
425 pinctrl-0 = <&i2c3_pins>;
426
Sebastian Reichel48fc9862013-10-23 00:49:31 +0200427 clock-frequency = <400000>;
Pavel Macheka4d4b152013-08-13 15:36:36 +0200428};
429
430&mmc1 {
Sebastian Reichelf1751cf2013-10-23 00:49:33 +0200431 pinctrl-names = "default";
432 pinctrl-0 = <&mmc1_pins>;
433 vmmc-supply = <&vmmc1>;
434 bus-width = <4>;
435 cd-gpios = <&gpio6 0 GPIO_ACTIVE_HIGH>; /* 160 */
Pavel Macheka4d4b152013-08-13 15:36:36 +0200436};
437
Tony Lindgrenedd5eb42013-11-25 14:23:45 -0800438/* most boards use vaux3, only some old versions use vmmc2 instead */
Pavel Macheka4d4b152013-08-13 15:36:36 +0200439&mmc2 {
Tony Lindgrenedd5eb42013-11-25 14:23:45 -0800440 pinctrl-names = "default";
441 pinctrl-0 = <&mmc2_pins>;
442 vmmc-supply = <&vaux3>;
443 vmmc_aux-supply = <&vsim>;
444 bus-width = <8>;
445 non-removable;
Pavel Macheka4d4b152013-08-13 15:36:36 +0200446};
447
448&mmc3 {
449 status = "disabled";
450};
451
Sebastian Reichel8699d2d2013-10-23 00:49:39 +0200452&gpmc {
453 ranges = <0 0 0x04000000 0x10000000>; /* 256MB */
454
455 /* gpio-irq for dma: 65 */
456
457 onenand@0,0 {
458 #address-cells = <1>;
459 #size-cells = <1>;
460 reg = <0 0 0x10000000>;
461
462 gpmc,sync-read;
463 gpmc,sync-write;
464 gpmc,burst-length = <16>;
465 gpmc,burst-read;
466 gpmc,burst-wrap;
467 gpmc,burst-write;
468 gpmc,device-width = <2>; /* GPMC_DEVWIDTH_16BIT */
469 gpmc,mux-add-data = <2>; /* GPMC_MUX_AD */
470 gpmc,cs-on-ns = <0>;
471 gpmc,cs-rd-off-ns = <87>;
472 gpmc,cs-wr-off-ns = <87>;
473 gpmc,adv-on-ns = <0>;
474 gpmc,adv-rd-off-ns = <10>;
475 gpmc,adv-wr-off-ns = <10>;
476 gpmc,oe-on-ns = <15>;
477 gpmc,oe-off-ns = <87>;
478 gpmc,we-on-ns = <0>;
479 gpmc,we-off-ns = <87>;
480 gpmc,rd-cycle-ns = <112>;
481 gpmc,wr-cycle-ns = <112>;
482 gpmc,access-ns = <81>;
483 gpmc,page-burst-access-ns = <15>;
484 gpmc,bus-turnaround-ns = <0>;
485 gpmc,cycle2cycle-delay-ns = <0>;
486 gpmc,wait-monitoring-ns = <0>;
487 gpmc,clk-activation-ns = <5>;
488 gpmc,wr-data-mux-bus-ns = <30>;
489 gpmc,wr-access-ns = <81>;
490 gpmc,sync-clk-ps = <15000>;
491
492 /*
493 * MTD partition table corresponding to Nokia's
494 * Maemo 5 (Fremantle) release.
495 */
496 partition@0 {
497 label = "bootloader";
498 reg = <0x00000000 0x00020000>;
499 read-only;
500 };
501 partition@1 {
502 label = "config";
503 reg = <0x00020000 0x00060000>;
504 };
505 partition@2 {
506 label = "log";
507 reg = <0x00080000 0x00040000>;
508 };
509 partition@3 {
510 label = "kernel";
511 reg = <0x000c0000 0x00200000>;
512 };
513 partition@4 {
514 label = "initfs";
515 reg = <0x002c0000 0x00200000>;
516 };
517 partition@5 {
518 label = "rootfs";
519 reg = <0x004c0000 0x0fb40000>;
520 };
521 };
522};
523
Pavel Macheka4d4b152013-08-13 15:36:36 +0200524&mcspi1 {
525 /*
526 * For some reason, touchscreen is necessary for screen to work at
527 * all on real hw. It works well without it on emulator.
528 *
529 * Also... order in the device tree actually matters here.
530 */
531 tsc2005@0 {
532 compatible = "tsc2005";
533 spi-max-frequency = <6000000>;
534 reg = <0>;
535 };
536 mipid@2 {
537 compatible = "acx565akm";
538 spi-max-frequency = <6000000>;
539 reg = <2>;
Sebastian Reicheld1e6f512013-10-23 00:49:40 +0200540
541 pinctrl-names = "default";
542 pinctrl-0 = <&display_pins>;
Pavel Macheka4d4b152013-08-13 15:36:36 +0200543 };
544};
545
546&usb_otg_hs {
547 interface-type = <0>;
548 usb-phy = <&usb2_phy>;
Roger Quadrosd2afcf02013-10-07 16:28:13 +0300549 phys = <&usb2_phy>;
550 phy-names = "usb2-phy";
Pavel Macheka4d4b152013-08-13 15:36:36 +0200551 mode = <2>;
552 power = <50>;
553};
Sebastian Reichel7a89eec2013-10-23 00:49:32 +0200554
555&uart1 {
556 status = "disabled";
557};
558
559&uart2 {
560 pinctrl-names = "default";
561 pinctrl-0 = <&uart2_pins>;
562};
563
564&uart3 {
565 pinctrl-names = "default";
566 pinctrl-0 = <&uart3_pins>;
567};