]> git.karo-electronics.de Git - karo-tx-linux.git/blob - arch/arm/boot/dts/logicpd-torpedo-37xx-devkit.dts
ARM: dts: LogicPD Torpedo: Add SPI EEPROM
[karo-tx-linux.git] / arch / arm / boot / dts / logicpd-torpedo-37xx-devkit.dts
1 /*
2  * This program is free software; you can redistribute it and/or modify
3  * it under the terms of the GNU General Public License version 2 as
4  * published by the Free Software Foundation.
5  */
6
7 /dts-v1/;
8
9 #include "omap36xx.dtsi"
10 #include "logicpd-torpedo-som.dtsi"
11 #include "omap-gpmc-smsc9221.dtsi"
12
13 / {
14         model = "LogicPD Zoom DM3730 Torpedo Development Kit";
15         compatible = "logicpd,dm3730-torpedo-devkit", "ti,omap3630", "ti,omap3";
16
17         gpio_keys {
18                 compatible = "gpio-keys";
19                 pinctrl-names = "default";
20                 pinctrl-0 = <&gpio_key_pins &gpio_key_pins_wkup>;
21
22                 sysboot2 {
23                         label = "sysboot2";
24                         gpios = <&gpio1 2 GPIO_ACTIVE_LOW>;     /* gpio2 */
25                         linux,code = <BTN_0>;
26                         wakeup-source;
27                 };
28
29                 sysboot5 {
30                         label = "sysboot5";
31                         gpios = <&gpio1 7 GPIO_ACTIVE_LOW>;     /* gpio7 */
32                         linux,code = <BTN_1>;
33                         wakeup-source;
34                 };
35
36                 gpio1 {
37                         label = "gpio1";
38                         gpios = <&gpio6 21 GPIO_ACTIVE_LOW>;    /* gpio181 */
39                         linux,code = <BTN_2>;
40                         wakeup-source;
41                 };
42
43                 gpio2 {
44                         label = "gpio2";
45                         gpios = <&gpio6 18 GPIO_ACTIVE_LOW>;    /* gpio178 */
46                         linux,code = <BTN_3>;
47                         wakeup-source;
48                 };
49         };
50
51         sound {
52                 compatible = "ti,omap-twl4030";
53                 ti,model = "omap3logic";
54                 ti,mcbsp = <&mcbsp2>;
55         };
56
57         leds {
58                 compatible = "gpio-leds";
59                 pinctrl-names = "default";
60                 pinctrl-0 = <&led_pins>;
61
62                 led1 {
63                         label = "led1";
64                         gpios = <&gpio6 20 GPIO_ACTIVE_HIGH>;   /* gpio180 */
65                         linux,default-trigger = "cpu0";
66                 };
67
68                 led2 {
69                         label = "led2";
70                         gpios = <&gpio6 19 GPIO_ACTIVE_HIGH>;   /* gpio179 */
71                         linux,default-trigger = "none";
72                 };
73         };
74 };
75
76 &vaux1 {
77         regulator-min-microvolt = <3000000>;
78         regulator-max-microvolt = <3000000>;
79 };
80
81 &vaux4 {
82         regulator-min-microvolt = <1800000>;
83         regulator-max-microvolt = <1800000>;
84 };
85
86 &mcbsp2 {
87         status = "okay";
88 };
89
90 &charger {
91         ti,bb-uvolt = <3200000>;
92         ti,bb-uamp = <150>;
93 };
94
95 &gpmc {
96         ranges = <1 0 0x08000000 0x1000000>;    /* CS1: 16MB for LAN9221 */
97
98         ethernet@gpmc {
99                 pinctrl-names = "default";
100                 pinctrl-0 = <&lan9221_pins>;
101                 interrupt-parent = <&gpio5>;
102                 interrupts = <1 IRQ_TYPE_LEVEL_LOW>;            /* gpio129 */
103                 reg = <1 0 0xff>;
104         };
105 };
106
107 &vpll2 {
108         regulator-always-on;
109 };
110
111 &dss {
112         status = "ok";
113         vdds_dsi-supply = <&vpll2>;
114         vdda_video-supply = <&video_reg>;
115         pinctrl-names = "default";
116         pinctrl-0 = <&dss_dpi_pins1>;
117         port {
118                 dpi_out: endpoint {
119                         remote-endpoint = <&lcd_in>;
120                         data-lines = <16>;
121                 };
122         };
123 };
124
125 / {
126         aliases {
127                 display0 = &lcd0;
128         };
129
130         video_reg: video_reg {
131                 pinctrl-names = "default";
132                 pinctrl-0 = <&panel_pwr_pins>;
133                 compatible = "regulator-fixed";
134                 regulator-name = "fixed-supply";
135                 regulator-min-microvolt = <3300000>;
136                 regulator-max-microvolt = <3300000>;
137                 gpio = <&gpio5 27 GPIO_ACTIVE_HIGH>;    /* gpio155, lcd INI */
138         };
139
140         lcd0: display@0 {
141                 compatible = "panel-dpi";
142                 label = "15";
143                 status = "okay";
144                 /* default-on; */
145                 pinctrl-names = "default";
146
147                 port {
148                         lcd_in: endpoint {
149                                 remote-endpoint = <&dpi_out>;
150                         };
151                 };
152
153                 panel-timing {
154                         clock-frequency = <9000000>;
155                         hactive = <480>;
156                         vactive = <272>;
157                         hfront-porch = <3>;
158                         hback-porch = <2>;
159                         hsync-len = <42>;
160                         vback-porch = <3>;
161                         vfront-porch = <4>;
162                         vsync-len = <11>;
163                         hsync-active = <0>;
164                         vsync-active = <0>;
165                         de-active = <1>;
166                         pixelclk-active = <1>;
167                 };
168         };
169
170         bl: backlight {
171                 compatible = "gpio-backlight";
172                 pinctrl-names = "default";
173                 pinctrl-0 = <&backlight_pins>;
174
175                 gpios = <&gpio5 26 GPIO_ACTIVE_HIGH>, /* gpio_154 */
176                         <&gpio2 24 GPIO_ACTIVE_HIGH>; /* gpio_56 */
177                 default-on;
178         };
179 };
180
181 &mmc1 {
182         interrupts-extended = <&intc 83 &omap3_pmx_core 0x11a>;
183         pinctrl-names = "default";
184         pinctrl-0 = <&mmc1_pins &mmc1_cd>;
185         cd-gpios = <&gpio4 31 IRQ_TYPE_LEVEL_LOW>;              /* gpio127 */
186         vmmc-supply = <&vmmc1>;
187         bus-width = <4>;
188         cap-power-off-card;
189 };
190
191 &omap3_pmx_core {
192         gpio_key_pins: pinmux_gpio_key_pins {
193                 pinctrl-single,pins = <
194                         OMAP3_CORE1_IOPAD(0x21d6, PIN_INPUT_PULLUP | MUX_MODE4) /* mcspi2_clk.gpio_178 */
195                         OMAP3_CORE1_IOPAD(0x21dc, PIN_INPUT_PULLUP | MUX_MODE4) /* mcspi2_cs0.gpio_181 */
196                 >;
197         };
198
199         led_pins: pinmux_led_pins {
200                 pinctrl-single,pins = <
201                         OMAP3_CORE1_IOPAD(0x21d8, PIN_OUTPUT | MUX_MODE4)       /* gpio_179 */
202                         OMAP3_CORE1_IOPAD(0x21da, PIN_OUTPUT | MUX_MODE4)       /* gpio_180 */
203                 >;
204         };
205
206         mmc1_pins: pinmux_mmc1_pins {
207                 pinctrl-single,pins = <
208                         OMAP3_CORE1_IOPAD(0x2144, PIN_OUTPUT | MUX_MODE0)       /* sdmmc1_clk.sdmmc1_clk */
209                         OMAP3_CORE1_IOPAD(0x2146, PIN_INPUT | MUX_MODE0)        /* sdmmc1_cmd.sdmmc1_cmd */
210                         OMAP3_CORE1_IOPAD(0x2148, PIN_INPUT | MUX_MODE0)        /* sdmmc1_dat0.sdmmc1_dat0 */
211                         OMAP3_CORE1_IOPAD(0x214a, PIN_INPUT | MUX_MODE0)        /* sdmmc1_dat1.sdmmc1_dat1 */
212                         OMAP3_CORE1_IOPAD(0x214c, PIN_INPUT | MUX_MODE0)        /* sdmmc1_dat2.sdmmc1_dat2 */
213                         OMAP3_CORE1_IOPAD(0x214e, PIN_INPUT | MUX_MODE0)        /* sdmmc1_dat3.sdmmc1_dat3 */
214                 >;
215         };
216
217         tsc2004_pins: pinmux_tsc2004_pins {
218                 pinctrl-single,pins = <
219                         OMAP3_CORE1_IOPAD(0x2186, PIN_INPUT | MUX_MODE4)        /* mcbsp4_dr.gpio_153 */
220                 >;
221         };
222
223         backlight_pins: pinmux_backlight_pins {
224                 pinctrl-single,pins = <
225                         OMAP3_CORE1_IOPAD(0x20B8, PIN_OUTPUT | PIN_OFF_OUTPUT_LOW | MUX_MODE4)       /* gpmc_ncs5.gpio_56 */
226                         OMAP3_CORE1_IOPAD(0x2188, PIN_OUTPUT | PIN_OFF_OUTPUT_LOW | MUX_MODE4)       /* mcbsp4_dx.gpio_154 */
227                 >;
228         };
229
230         isp_pins: pinmux_isp_pins {
231                 pinctrl-single,pins = <
232                         OMAP3_CORE1_IOPAD(0x210c, PIN_INPUT | MUX_MODE0)   /* cam_hs.cam_hs */
233                         OMAP3_CORE1_IOPAD(0x210e, PIN_INPUT | MUX_MODE0)   /* cam_vs.cam_vs */
234                         OMAP3_CORE1_IOPAD(0x2110, PIN_INPUT | MUX_MODE0)   /* cam_xclka.cam_xclka */
235                         OMAP3_CORE1_IOPAD(0x2112, PIN_INPUT | MUX_MODE0)   /* cam_pclk.cam_pclk */
236
237                         OMAP3_CORE1_IOPAD(0x2114, PIN_INPUT | MUX_MODE0)   /* cam_d0.cam_d0 */
238                         OMAP3_CORE1_IOPAD(0x2116, PIN_INPUT | MUX_MODE0)   /* cam_d1.cam_d1 */
239                         OMAP3_CORE1_IOPAD(0x2118, PIN_INPUT | MUX_MODE0)   /* cam_d2.cam_d2 */
240                         OMAP3_CORE1_IOPAD(0x211c, PIN_INPUT | MUX_MODE0)   /* cam_d3.cam_d3 */
241                         OMAP3_CORE1_IOPAD(0x211e, PIN_INPUT | MUX_MODE0)   /* cam_d4.cam_d4 */
242                         OMAP3_CORE1_IOPAD(0x2120, PIN_INPUT | MUX_MODE0)   /* cam_d5.cam_d5 */
243                         OMAP3_CORE1_IOPAD(0x2122, PIN_INPUT | MUX_MODE0)   /* cam_d6.cam_d6 */
244                         OMAP3_CORE1_IOPAD(0x2124, PIN_INPUT | MUX_MODE0)   /* cam_d7.cam_d7 */
245                 >;
246         };
247
248         panel_pwr_pins: pinmux_panel_pwr_pins {
249                 pinctrl-single,pins = <
250                         OMAP3_CORE1_IOPAD(0x218a, PIN_OUTPUT | PIN_OFF_OUTPUT_LOW | MUX_MODE4)       /* mcbsp4_fs.gpio_155 */
251                 >;
252         };
253
254         dss_dpi_pins1: pinmux_dss_dpi_pins1 {
255                 pinctrl-single,pins = <
256                         OMAP3_CORE1_IOPAD(0x20d4, PIN_OUTPUT_PULLDOWN | PIN_OFF_OUTPUT_LOW | MUX_MODE0)   /* dss_pclk.dss_pclk */
257                         OMAP3_CORE1_IOPAD(0x20d6, PIN_OUTPUT_PULLDOWN | PIN_OFF_OUTPUT_LOW | MUX_MODE0)   /* dss_hsync.dss_hsync */
258                         OMAP3_CORE1_IOPAD(0x20d8, PIN_OUTPUT_PULLDOWN | PIN_OFF_OUTPUT_LOW | MUX_MODE0)   /* dss_vsync.dss_vsync */
259                         OMAP3_CORE1_IOPAD(0x20da, PIN_OUTPUT_PULLDOWN | PIN_OFF_OUTPUT_LOW | MUX_MODE0)   /* dss_acbias.dss_acbias */
260
261                         OMAP3_CORE1_IOPAD(0x20e8, PIN_OUTPUT_PULLDOWN | PIN_OFF_OUTPUT_LOW | MUX_MODE0)   /* dss_data6.dss_data6 */
262                         OMAP3_CORE1_IOPAD(0x20ea, PIN_OUTPUT_PULLDOWN | PIN_OFF_OUTPUT_LOW | MUX_MODE0)   /* dss_data7.dss_data7 */
263                         OMAP3_CORE1_IOPAD(0x20ec, PIN_OUTPUT_PULLDOWN | PIN_OFF_OUTPUT_LOW | MUX_MODE0)   /* dss_data8.dss_data8 */
264                         OMAP3_CORE1_IOPAD(0x20ee, PIN_OUTPUT_PULLDOWN | PIN_OFF_OUTPUT_LOW | MUX_MODE0)   /* dss_data9.dss_data9 */
265                         OMAP3_CORE1_IOPAD(0x20f0, PIN_OUTPUT_PULLDOWN | PIN_OFF_OUTPUT_LOW | MUX_MODE0)   /* dss_data10.dss_data10 */
266                         OMAP3_CORE1_IOPAD(0x20f2, PIN_OUTPUT_PULLDOWN | PIN_OFF_OUTPUT_LOW | MUX_MODE0)   /* dss_data11.dss_data11 */
267                         OMAP3_CORE1_IOPAD(0x20f4, PIN_OUTPUT_PULLDOWN | PIN_OFF_OUTPUT_LOW | MUX_MODE0)   /* dss_data12.dss_data12 */
268                         OMAP3_CORE1_IOPAD(0x20f6, PIN_OUTPUT_PULLDOWN | PIN_OFF_OUTPUT_LOW | MUX_MODE0)   /* dss_data13.dss_data13 */
269                         OMAP3_CORE1_IOPAD(0x20f8, PIN_OUTPUT_PULLDOWN | PIN_OFF_OUTPUT_LOW | MUX_MODE0)   /* dss_data14.dss_data14 */
270                         OMAP3_CORE1_IOPAD(0x20fa, PIN_OUTPUT_PULLDOWN | PIN_OFF_OUTPUT_LOW | MUX_MODE0)   /* dss_data15.dss_data15 */
271                         OMAP3_CORE1_IOPAD(0x20fc, PIN_OUTPUT_PULLDOWN | PIN_OFF_OUTPUT_LOW | MUX_MODE0)   /* dss_data16.dss_data16 */
272                         OMAP3_CORE1_IOPAD(0x20fe, PIN_OUTPUT_PULLDOWN | PIN_OFF_OUTPUT_LOW | MUX_MODE0)   /* dss_data17.dss_data17 */
273
274                         OMAP3_CORE1_IOPAD(0x2100, PIN_OUTPUT_PULLDOWN | PIN_OFF_OUTPUT_LOW | MUX_MODE3)   /* dss_data18.dss_data0 */
275                         OMAP3_CORE1_IOPAD(0x2102, PIN_OUTPUT_PULLDOWN | PIN_OFF_OUTPUT_LOW | MUX_MODE3)   /* dss_data19.dss_data1 */
276                         OMAP3_CORE1_IOPAD(0x2104, PIN_OUTPUT_PULLDOWN | PIN_OFF_OUTPUT_LOW | MUX_MODE3)   /* dss_data20.dss_data2 */
277                         OMAP3_CORE1_IOPAD(0x2106, PIN_OUTPUT_PULLDOWN | PIN_OFF_OUTPUT_LOW | MUX_MODE3)   /* dss_data21.dss_data3 */
278                         OMAP3_CORE1_IOPAD(0x2108, PIN_OUTPUT_PULLDOWN | PIN_OFF_OUTPUT_LOW | MUX_MODE3)   /* dss_data22.dss_data4 */
279                         OMAP3_CORE1_IOPAD(0x210a, PIN_OUTPUT_PULLDOWN | PIN_OFF_OUTPUT_LOW | MUX_MODE3)   /* dss_data23.dss_data5 */
280                 >;
281         };
282 };
283
284 &omap3_pmx_wkup {
285         gpio_key_pins_wkup: pinmux_gpio_key_pins_wkup {
286                 pinctrl-single,pins = <
287                         OMAP3_WKUP_IOPAD(0x2a0a, PIN_INPUT_PULLUP | MUX_MODE4)  /* sys_boot0.gpio_2 */
288                         OMAP3_WKUP_IOPAD(0x2a14, PIN_INPUT_PULLUP | MUX_MODE4)  /* sys_boot5.gpio_7 */
289                 >;
290         };
291
292         lan9221_pins: pinmux_lan9221_pins {
293                 pinctrl-single,pins = <
294                         OMAP3_WKUP_IOPAD(0x2a5a, PIN_INPUT | MUX_MODE4)         /* reserved.gpio_129 */
295                 >;
296         };
297
298         mmc1_cd: pinmux_mmc1_cd {
299                 pinctrl-single,pins = <
300                         OMAP3_WKUP_IOPAD(0x2a54, PIN_INPUT_PULLUP | MUX_MODE4)  /* reserved.gpio_127 */
301                 >;
302         };
303 };
304
305 &i2c2 {
306         mt9p031@48 {
307                 compatible = "aptina,mt9p031";
308                 reg = <0x48>;
309                 clocks = <&isp 0>;
310                 vaa-supply = <&vaux4>;
311                 vdd-supply = <&vaux4>;
312                 vdd_io-supply = <&vaux4>;
313                 port {
314                         mt9p031_out: endpoint {
315                                 input-clock-frequency = <24000000>;
316                                 pixel-clock-frequency = <72000000>;
317                                 remote-endpoint = <&ccdc_ep>;
318                         };
319                 };
320         };
321 };
322
323 &i2c3 {
324         touchscreen: tsc2004@48 {
325                 compatible = "ti,tsc2004";
326                 reg = <0x48>;
327                 vio-supply = <&vaux1>;
328                 pinctrl-names = "default";
329                 pinctrl-0 = <&tsc2004_pins>;
330                 interrupts-extended = <&gpio5 25 IRQ_TYPE_EDGE_RISING>; /* gpio 153 */
331
332                 touchscreen-fuzz-x = <4>;
333                 touchscreen-fuzz-y = <7>;
334                 touchscreen-fuzz-pressure = <2>;
335                 touchscreen-size-x = <4096>;
336                 touchscreen-size-y = <4096>;
337                 touchscreen-max-pressure = <2048>;
338
339                 ti,x-plate-ohms = <280>;
340                 ti,esd-recovery-timeout-ms = <8000>;
341         };
342 };
343
344 &mcspi1 {
345         at25@0 {
346                 compatible = "atmel,at25";
347                 reg = <0>;
348                 spi-max-frequency = <5000000>;
349                 spi-cpha;
350                 spi-cpol;
351
352                 pagesize = <64>;
353                 size = <32768>;
354                 address-width = <16>;
355         };
356 };
357
358 &isp {
359         pinctrl-names = "default";
360         pinctrl-0 = <&isp_pins>;
361         ports {
362                 port@0 {
363                         reg = <0>;
364                         ccdc_ep: endpoint {
365                                 remote-endpoint = <&mt9p031_out>;
366                                 bus-width = <8>;
367                                 hsync-active = <1>;
368                                 vsync-active = <1>;
369                                 pclk-sample = <0>;
370                         };
371                 };
372         };
373 };
374
375 &uart1 {
376         interrupts-extended = <&intc 72 &omap3_pmx_core OMAP3_UART1_RX>;
377 };
378
379 /* Wired to the tps65950 on the SOM, only the USB connector is on the devkit */
380 &usb_otg_hs {
381         interface-type = <0>;
382         usb-phy = <&usb2_phy>;
383         phys = <&usb2_phy>;
384         phy-names = "usb2-phy";
385         mode = <3>;
386         power = <50>;
387 };