]> git.ipfire.org Git - thirdparty/kernel/stable.git/blob - arch/arm/boot/dts/ti/omap/motorola-mapphone-common.dtsi
Merge tag 'kvm-x86-misc-6.7' of https://github.com/kvm-x86/linux into HEAD
[thirdparty/kernel/stable.git] / arch / arm / boot / dts / ti / omap / motorola-mapphone-common.dtsi
1 // SPDX-License-Identifier: GPL-2.0-only
2 /dts-v1/;
3
4 #include <dt-bindings/input/input.h>
5 #include "omap443x.dtsi"
6 #include "motorola-cpcap-mapphone.dtsi"
7
8 / {
9 chosen {
10 stdout-path = &uart3;
11 };
12
13 aliases {
14 display0 = &lcd0;
15 display1 = &hdmi0;
16 };
17
18 /*
19 * We seem to have only 1021 MB accessible, 1021 - 1022 is locked,
20 * then 1023 - 1024 seems to contain mbm.
21 */
22 memory {
23 device_type = "memory";
24 reg = <0x80000000 0x3fd00000>; /* 1021 MB */
25 };
26
27 /* Poweroff GPIO probably connected to CPCAP */
28 gpio-poweroff {
29 compatible = "gpio-poweroff";
30 pinctrl-0 = <&poweroff_gpio>;
31 pinctrl-names = "default";
32 gpios = <&gpio2 18 GPIO_ACTIVE_LOW>; /* gpio50 */
33 };
34
35 hdmi0: connector {
36 compatible = "hdmi-connector";
37 pinctrl-0 = <&hdmi_hpd_gpio>;
38 pinctrl-names = "default";
39 label = "hdmi";
40 type = "d";
41
42 hpd-gpios = <&gpio2 31 GPIO_ACTIVE_HIGH>; /* gpio63 */
43
44 port {
45 hdmi_connector_in: endpoint {
46 remote-endpoint = <&hdmi_out>;
47 };
48 };
49 };
50
51 /*
52 * HDMI 5V regulator probably sourced from battery. Let's keep
53 * keep this as always enabled for HDMI to work until we've
54 * figured what the encoder chip is.
55 */
56 hdmi_regulator: regulator-hdmi {
57 compatible = "regulator-fixed";
58 regulator-name = "hdmi";
59 regulator-min-microvolt = <5000000>;
60 regulator-max-microvolt = <5000000>;
61 gpio = <&gpio2 27 GPIO_ACTIVE_HIGH>; /* gpio59 */
62 enable-active-high;
63 regulator-always-on;
64 };
65
66 /* FS USB Host PHY on port 1 for mdm6600 */
67 fsusb1_phy: usb-phy@1 {
68 compatible = "motorola,mapphone-mdm6600";
69 pinctrl-0 = <&usb_mdm6600_pins>;
70 pinctrl-names = "default";
71 enable-gpios = <&gpio3 31 GPIO_ACTIVE_LOW>; /* gpio_95 */
72 power-gpios = <&gpio2 22 GPIO_ACTIVE_HIGH>; /* gpio_54 */
73 reset-gpios = <&gpio2 17 GPIO_ACTIVE_HIGH>; /* gpio_49 */
74 /* mode: gpio_148 gpio_149 */
75 motorola,mode-gpios = <&gpio5 20 GPIO_ACTIVE_HIGH>,
76 <&gpio5 21 GPIO_ACTIVE_HIGH>;
77 /* cmd: gpio_103 gpio_104 gpio_142 */
78 motorola,cmd-gpios = <&gpio4 7 GPIO_ACTIVE_HIGH>,
79 <&gpio4 8 GPIO_ACTIVE_HIGH>,
80 <&gpio5 14 GPIO_ACTIVE_HIGH>;
81 /* status: gpio_52 gpio_53 gpio_55 */
82 motorola,status-gpios = <&gpio2 20 GPIO_ACTIVE_HIGH>,
83 <&gpio2 21 GPIO_ACTIVE_HIGH>,
84 <&gpio2 23 GPIO_ACTIVE_HIGH>;
85 #phy-cells = <0>;
86 };
87
88 /* HS USB host TLL nop-phy on port 2 for w3glte */
89 hsusb2_phy: usb-phy@2 {
90 compatible = "usb-nop-xceiv";
91 #phy-cells = <0>;
92 };
93
94 /* LCD regulator from sw5 source */
95 lcd_regulator: regulator-lcd {
96 compatible = "regulator-fixed";
97 regulator-name = "lcd";
98 regulator-min-microvolt = <5050000>;
99 regulator-max-microvolt = <5050000>;
100 gpio = <&gpio4 0 GPIO_ACTIVE_HIGH>; /* gpio96 */
101 enable-active-high;
102 vin-supply = <&sw5>;
103 };
104
105 /* This is probably coming straight from the battery.. */
106 wl12xx_vmmc: regulator-wl12xx {
107 compatible = "regulator-fixed";
108 regulator-name = "vwl1271";
109 regulator-min-microvolt = <1650000>;
110 regulator-max-microvolt = <1650000>;
111 gpio = <&gpio3 30 GPIO_ACTIVE_HIGH>; /* gpio94 */
112 startup-delay-us = <70000>;
113 enable-active-high;
114 };
115
116 soundcard {
117 compatible = "audio-graph-card";
118 label = "Mapphone Audio";
119
120 widgets =
121 "Speaker", "Earpiece",
122 "Speaker", "Loudspeaker",
123 "Headphone", "Headphone Jack",
124 "Microphone", "Internal Mic";
125
126 routing =
127 "Earpiece", "EP",
128 "Loudspeaker", "SPKR",
129 "Headphone Jack", "HSL",
130 "Headphone Jack", "HSR",
131 "MICR", "Internal Mic";
132
133 dais = <&mcbsp2_port>, <&mcbsp3_port>;
134 };
135
136 pwm8: pwm-8 {
137 pinctrl-names = "default";
138 pinctrl-0 = <&vibrator_direction_pin>;
139
140 compatible = "ti,omap-dmtimer-pwm";
141 #pwm-cells = <3>;
142 ti,timers = <&timer8>;
143 ti,clock-source = <0x01>;
144 };
145
146 pwm9: pwm-9 {
147 pinctrl-names = "default";
148 pinctrl-0 = <&vibrator_enable_pin>;
149
150 compatible = "ti,omap-dmtimer-pwm";
151 #pwm-cells = <3>;
152 ti,timers = <&timer9>;
153 ti,clock-source = <0x01>;
154 };
155
156 vibrator {
157 compatible = "pwm-vibrator";
158 pwms = <&pwm9 0 10000000 0>, <&pwm8 0 10000000 0>;
159 pwm-names = "enable", "direction";
160 direction-duty-cycle-ns = <10000000>;
161 };
162
163 backlight: backlight {
164 compatible = "led-backlight";
165
166 leds = <&backlight_led>;
167 brightness-levels = <31 63 95 127 159 191 223 255>;
168 default-brightness-level = <6>;
169 };
170 };
171
172 &cpu_thermal {
173 polling-delay = <10000>; /* milliseconds */
174 };
175
176 &cpu_alert0 {
177 temperature = <80000>; /* millicelsius */
178 };
179
180 &cpu0 {
181 /*
182 * Note that the 1.2GiHz mode is enabled for all SoC variants for
183 * the Motorola Android Linux v3.0.8 based kernel.
184 */
185 operating-points = <
186 /* kHz uV */
187 300000 1025000
188 600000 1200000
189 800000 1313000
190 1008000 1375000
191 1200000 1375000
192 >;
193 };
194
195 &dss {
196 status = "okay";
197 };
198
199 &dsi1 {
200 status = "okay";
201 vdd-supply = <&vcsi>;
202
203 port {
204 dsi1_out_ep: endpoint {
205 remote-endpoint = <&lcd0_in>;
206 lanes = <0 1 2 3 4 5>;
207 };
208 };
209
210 lcd0: panel@0 {
211 compatible = "motorola,droid4-panel", "panel-dsi-cm";
212 reg = <0>;
213 label = "lcd0";
214 vddi-supply = <&lcd_regulator>;
215 reset-gpios = <&gpio4 5 GPIO_ACTIVE_HIGH>; /* gpio101 */
216
217 backlight = <&backlight>;
218
219 width-mm = <50>;
220 height-mm = <89>;
221 rotation = <90>;
222
223 panel-timing {
224 clock-frequency = <0>; /* Calculated by dsi */
225
226 hback-porch = <2>;
227 hactive = <540>;
228 hfront-porch = <0>;
229 hsync-len = <2>;
230
231 vback-porch = <1>;
232 vactive = <960>;
233 vfront-porch = <0>;
234 vsync-len = <1>;
235
236 hsync-active = <0>;
237 vsync-active = <0>;
238 de-active = <1>;
239 pixelclk-active = <1>;
240 };
241
242 port {
243 lcd0_in: endpoint {
244 remote-endpoint = <&dsi1_out_ep>;
245 };
246 };
247 };
248 };
249
250 &hdmi {
251 status = "okay";
252 pinctrl-0 = <&dss_hdmi_pins>;
253 pinctrl-names = "default";
254 vdda-supply = <&vdac>;
255
256 port {
257 hdmi_out: endpoint {
258 remote-endpoint = <&hdmi_connector_in>;
259 lanes = <1 0 3 2 5 4 7 6>;
260 };
261 };
262 };
263
264 /* Battery NVRAM on 1-wire handled by w1_ds250x driver */
265 &hdqw1w {
266 pinctrl-0 = <&hdq_pins>;
267 pinctrl-names = "default";
268 ti,mode = "1w";
269 };
270
271 &i2c1 {
272 tmp105@48 {
273 compatible = "ti,tmp105";
274 reg = <0x48>;
275 pinctrl-0 = <&tmp105_irq>;
276 pinctrl-names = "default";
277 /* kpd_row0.gpio_178 */
278 interrupts-extended = <&gpio6 18 IRQ_TYPE_EDGE_FALLING
279 &omap4_pmx_core 0x14e>;
280 interrupt-names = "irq", "wakeup";
281 wakeup-source;
282 };
283 };
284
285 &mmc1 {
286 vmmc-supply = <&vwlan2>;
287 bus-width = <4>;
288 cd-gpios = <&gpio6 16 GPIO_ACTIVE_LOW>; /* gpio176 */
289 };
290
291 &mmc2 {
292 vmmc-supply = <&vsdio>;
293 bus-width = <8>;
294 ti,non-removable;
295 };
296
297 &mmc3 {
298 pinctrl-names = "default";
299 pinctrl-0 = <&mmc3_pins>;
300 vmmc-supply = <&wl12xx_vmmc>;
301 /* uart2_tx.sdmmc3_dat1 pad as wakeirq */
302 interrupts-extended = <&wakeupgen GIC_SPI 94 IRQ_TYPE_LEVEL_HIGH
303 &omap4_pmx_core 0xde>;
304 interrupt-names = "irq", "wakeup";
305 non-removable;
306 bus-width = <4>;
307 cap-power-off-card;
308 keep-power-in-suspend;
309
310 #address-cells = <1>;
311 #size-cells = <0>;
312 wlcore: wlcore@2 {
313 compatible = "ti,wl1285";
314 reg = <2>;
315 /* gpio_100 with gpmc_wait2 pad as wakeirq */
316 interrupts-extended = <&gpio4 4 IRQ_TYPE_LEVEL_HIGH>,
317 <&omap4_pmx_core 0x4e>;
318 interrupt-names = "irq", "wakeup";
319 ref-clock-frequency = <26000000>;
320 tcxo-clock-frequency = <26000000>;
321 };
322 };
323
324 &i2c2 {
325 touchscreen@4a {
326 compatible = "atmel,maxtouch";
327 reg = <0x4a>;
328 pinctrl-names = "default";
329 pinctrl-0 = <&touchscreen_pins>;
330
331 reset-gpios = <&gpio6 13 GPIO_ACTIVE_LOW>; /* gpio173 */
332
333 /* gpio_183 with sys_nirq2 pad as wakeup */
334 interrupts-extended = <&gpio6 23 IRQ_TYPE_LEVEL_LOW>,
335 <&omap4_pmx_core 0x160>;
336 interrupt-names = "irq", "wakeup";
337 wakeup-source;
338 };
339
340 isl29030@44 {
341 compatible = "isil,isl29030";
342 reg = <0x44>;
343
344 pinctrl-names = "default";
345 pinctrl-0 = <&als_proximity_pins>;
346
347 interrupt-parent = <&gpio6>;
348 interrupts = <17 IRQ_TYPE_LEVEL_LOW>; /* gpio177 */
349 };
350 };
351
352 &omap4_pmx_core {
353
354 /* hdmi_hpd.gpio_63 */
355 hdmi_hpd_gpio: hdmi-hpd-pins {
356 pinctrl-single,pins = <
357 OMAP4_IOPAD(0x098, PIN_INPUT | MUX_MODE3)
358 >;
359 };
360
361 hdq_pins: hdq-pins {
362 pinctrl-single,pins = <
363 /* 0x4a100120 hdq_sio.hdq_sio aa27 */
364 OMAP4_IOPAD(0x120, PIN_INPUT | MUX_MODE0)
365 >;
366 };
367
368 /* hdmi_cec.hdmi_cec, hdmi_scl.hdmi_scl, hdmi_sda.hdmi_sda */
369 dss_hdmi_pins: dss-hdmi-pins {
370 pinctrl-single,pins = <
371 OMAP4_IOPAD(0x09a, PIN_INPUT | MUX_MODE0)
372 OMAP4_IOPAD(0x09c, PIN_INPUT | MUX_MODE0)
373 OMAP4_IOPAD(0x09e, PIN_INPUT | MUX_MODE0)
374 >;
375 };
376
377 /*
378 * Android uses PIN_OFF_INPUT_PULLDOWN | PIN_INPUT_PULLUP | MUX_MODE3
379 * for gpio_100, but the internal pull makes wlan flakey on some
380 * devices. Off mode value should be tested if we have off mode working
381 * later on.
382 */
383 mmc3_pins: mmc3-pins {
384 pinctrl-single,pins = <
385 /* 0x4a10008e gpmc_wait2.gpio_100 d23 */
386 OMAP4_IOPAD(0x08e, PIN_INPUT | MUX_MODE3)
387
388 /* 0x4a100102 abe_mcbsp1_dx.sdmmc3_dat2 ab25 */
389 OMAP4_IOPAD(0x102, PIN_INPUT_PULLUP | MUX_MODE1)
390
391 /* 0x4a100104 abe_mcbsp1_fsx.sdmmc3_dat3 ac27 */
392 OMAP4_IOPAD(0x104, PIN_INPUT_PULLUP | MUX_MODE1)
393
394 /* 0x4a100118 uart2_cts.sdmmc3_clk ab26 */
395 OMAP4_IOPAD(0x118, PIN_INPUT | MUX_MODE1)
396
397 /* 0x4a10011a uart2_rts.sdmmc3_cmd ab27 */
398 OMAP4_IOPAD(0x11a, PIN_INPUT_PULLUP | MUX_MODE1)
399
400 /* 0x4a10011c uart2_rx.sdmmc3_dat0 aa25 */
401 OMAP4_IOPAD(0x11c, PIN_INPUT_PULLUP | MUX_MODE1)
402
403 /* 0x4a10011e uart2_tx.sdmmc3_dat1 aa26 */
404 OMAP4_IOPAD(0x11e, PIN_INPUT_PULLUP | MUX_MODE1)
405 >;
406 };
407
408 /* gpmc_ncs0.gpio_50 */
409 poweroff_gpio: poweroff-pins {
410 pinctrl-single,pins = <
411 OMAP4_IOPAD(0x074, PIN_OUTPUT_PULLUP | MUX_MODE3)
412 >;
413 };
414
415 /* kpd_row0.gpio_178 */
416 tmp105_irq: tmp105-irq-pins {
417 pinctrl-single,pins = <
418 OMAP4_IOPAD(0x18e, PIN_INPUT_PULLUP | MUX_MODE3)
419 >;
420 };
421
422 usb_gpio_mux_sel1: usb-gpio-mux-sel1-pins {
423 /* gpio_60 */
424 pinctrl-single,pins = <
425 OMAP4_IOPAD(0x088, PIN_OUTPUT | MUX_MODE3)
426 >;
427 };
428
429 touchscreen_pins: touchscreen-pins {
430 pinctrl-single,pins = <
431 OMAP4_IOPAD(0x180, PIN_OUTPUT | MUX_MODE3)
432 OMAP4_IOPAD(0x1a0, PIN_INPUT_PULLUP | MUX_MODE3)
433 >;
434 };
435
436 als_proximity_pins: als-proximity-pins {
437 pinctrl-single,pins = <
438 OMAP4_IOPAD(0x18c, PIN_INPUT_PULLUP | MUX_MODE3)
439 >;
440 };
441
442 usb_mdm6600_pins: usb-mdm6600-pins {
443 pinctrl-single,pins = <
444 /* enable 0x4a1000d8 usbb1_ulpitll_dat7.gpio_95 ag16 */
445 OMAP4_IOPAD(0x0d8, PIN_INPUT | MUX_MODE3)
446
447 /* power 0x4a10007c gpmc_nwp.gpio_54 c25 */
448 OMAP4_IOPAD(0x07c, PIN_OUTPUT | MUX_MODE3)
449
450 /* reset 0x4a100072 gpmc_a25.gpio_49 d20 */
451 OMAP4_IOPAD(0x072, PIN_OUTPUT | MUX_MODE3)
452
453 /* mode0/bpwake 0x4a10014e sdmmc5_dat1.gpio_148 af4 */
454 OMAP4_IOPAD(0x14e, PIN_OUTPUT | MUX_MODE3)
455
456 /* mode1/apwake 0x4a100150 sdmmc5_dat2.gpio_149 ag3 */
457 OMAP4_IOPAD(0x150, PIN_OFF_OUTPUT_LOW | PIN_INPUT | MUX_MODE3)
458
459 /* status0 0x4a10007e gpmc_clk.gpio_55 b22 */
460 OMAP4_IOPAD(0x07e, PIN_INPUT | MUX_MODE3)
461
462 /* status1 0x4a10007a gpmc_ncs3.gpio_53 c22 */
463 OMAP4_IOPAD(0x07a, PIN_INPUT | MUX_MODE3)
464
465 /* status2 0x4a100078 gpmc_ncs2.gpio_52 d21 */
466 OMAP4_IOPAD(0x078, PIN_INPUT | MUX_MODE3)
467
468 /* cmd0 0x4a100094 gpmc_ncs6.gpio_103 c24 */
469 OMAP4_IOPAD(0x094, PIN_OUTPUT | MUX_MODE3)
470
471 /* cmd1 0x4a100096 gpmc_ncs7.gpio_104 d24 */
472 OMAP4_IOPAD(0x096, PIN_OUTPUT | MUX_MODE3)
473
474 /* cmd2 0x4a100142 uart3_rts_sd.gpio_142 f28 */
475 OMAP4_IOPAD(0x142, PIN_OUTPUT | MUX_MODE3)
476 >;
477 };
478
479 usb_ulpi_pins: usb-ulpi-pins {
480 pinctrl-single,pins = <
481 OMAP4_IOPAD(0x196, MUX_MODE7)
482 OMAP4_IOPAD(0x198, MUX_MODE7)
483 OMAP4_IOPAD(0x1b2, PIN_INPUT_PULLUP | MUX_MODE0)
484 OMAP4_IOPAD(0x1b4, PIN_INPUT_PULLUP | MUX_MODE0)
485 OMAP4_IOPAD(0x1b6, PIN_INPUT_PULLUP | MUX_MODE0)
486 OMAP4_IOPAD(0x1b8, PIN_INPUT_PULLUP | MUX_MODE0)
487 OMAP4_IOPAD(0x1ba, PIN_INPUT_PULLUP | MUX_MODE0)
488 OMAP4_IOPAD(0x1bc, PIN_INPUT_PULLUP | MUX_MODE0)
489 OMAP4_IOPAD(0x1be, PIN_INPUT_PULLUP | MUX_MODE0)
490 OMAP4_IOPAD(0x1c0, PIN_INPUT_PULLUP | MUX_MODE0)
491 OMAP4_IOPAD(0x1c2, PIN_INPUT_PULLUP | MUX_MODE0)
492 OMAP4_IOPAD(0x1c4, PIN_INPUT_PULLUP | MUX_MODE0)
493 OMAP4_IOPAD(0x1c6, PIN_INPUT_PULLUP | MUX_MODE0)
494 OMAP4_IOPAD(0x1c8, PIN_INPUT_PULLUP | MUX_MODE0)
495 >;
496 };
497
498 /* usb0_otg_dp and usb0_otg_dm */
499 usb_utmi_pins: usb-utmi-pins {
500 pinctrl-single,pins = <
501 OMAP4_IOPAD(0x196, PIN_INPUT | MUX_MODE0)
502 OMAP4_IOPAD(0x198, PIN_INPUT | MUX_MODE0)
503 OMAP4_IOPAD(0x1b2, PIN_INPUT_PULLUP | MUX_MODE7)
504 OMAP4_IOPAD(0x1b4, PIN_INPUT_PULLUP | MUX_MODE7)
505 OMAP4_IOPAD(0x1b6, PIN_INPUT_PULLUP | MUX_MODE7)
506 OMAP4_IOPAD(0x1b8, PIN_INPUT_PULLUP | MUX_MODE7)
507 OMAP4_IOPAD(0x1ba, PIN_INPUT_PULLUP | MUX_MODE7)
508 OMAP4_IOPAD(0x1bc, PIN_INPUT_PULLUP | MUX_MODE7)
509 OMAP4_IOPAD(0x1be, PIN_INPUT_PULLUP | MUX_MODE7)
510 OMAP4_IOPAD(0x1c0, PIN_INPUT_PULLUP | MUX_MODE7)
511 OMAP4_IOPAD(0x1c2, PIN_INPUT_PULLUP | MUX_MODE7)
512 OMAP4_IOPAD(0x1c4, PIN_INPUT_PULLUP | MUX_MODE7)
513 OMAP4_IOPAD(0x1c6, PIN_INPUT_PULLUP | MUX_MODE7)
514 OMAP4_IOPAD(0x1c8, PIN_INPUT_PULLUP | MUX_MODE7)
515 >;
516 };
517
518 /*
519 * Note that the v3.0.8 stock userspace dynamically remuxes uart1
520 * rts pin probably for PM purposes to PIN_INPUT_PULLUP | MUX_MODE7
521 * when not used. If needed, we can add rts pin remux later based
522 * on power measurements.
523 */
524 uart1_pins: uart1-pins {
525 pinctrl-single,pins = <
526 /* 0x4a10013c mcspi1_cs2.uart1_cts ag23 */
527 OMAP4_IOPAD(0x13c, PIN_INPUT_PULLUP | MUX_MODE1)
528
529 /* 0x4a10013e mcspi1_cs3.uart1_rts ah23 */
530 OMAP4_IOPAD(0x13e, MUX_MODE1)
531
532 /* 0x4a100140 uart3_cts_rctx.uart1_tx f27 */
533 OMAP4_IOPAD(0x140, PIN_OUTPUT | MUX_MODE1)
534
535 /* 0x4a1001ca dpm_emu14.uart1_rx aa3 */
536 OMAP4_IOPAD(0x1ca, PIN_INPUT_PULLUP | MUX_MODE2)
537 >;
538 };
539
540 /* uart3_tx_irtx and uart3_rx_irrx */
541 uart3_pins: uart3-pins {
542 pinctrl-single,pins = <
543 OMAP4_IOPAD(0x196, MUX_MODE7)
544 OMAP4_IOPAD(0x198, MUX_MODE7)
545 OMAP4_IOPAD(0x1b2, PIN_INPUT_PULLUP | MUX_MODE7)
546 OMAP4_IOPAD(0x1b4, PIN_INPUT_PULLUP | MUX_MODE7)
547 OMAP4_IOPAD(0x1b6, PIN_INPUT_PULLUP | MUX_MODE7)
548 OMAP4_IOPAD(0x1b8, PIN_INPUT_PULLUP | MUX_MODE7)
549 OMAP4_IOPAD(0x1ba, MUX_MODE2)
550 OMAP4_IOPAD(0x1bc, PIN_INPUT | MUX_MODE2)
551 OMAP4_IOPAD(0x1be, PIN_INPUT_PULLUP | MUX_MODE7)
552 OMAP4_IOPAD(0x1c0, PIN_INPUT_PULLUP | MUX_MODE7)
553 OMAP4_IOPAD(0x1c2, PIN_INPUT_PULLUP | MUX_MODE7)
554 OMAP4_IOPAD(0x1c4, PIN_INPUT_PULLUP | MUX_MODE7)
555 OMAP4_IOPAD(0x1c6, PIN_INPUT_PULLUP | MUX_MODE7)
556 OMAP4_IOPAD(0x1c8, PIN_INPUT_PULLUP | MUX_MODE7)
557 >;
558 };
559
560 uart4_pins: uart4-pins {
561 pinctrl-single,pins = <
562 OMAP4_IOPAD(0x15c, PIN_INPUT | MUX_MODE0) /* uart4_rx */
563 OMAP4_IOPAD(0x15e, PIN_OUTPUT | MUX_MODE0) /* uart4_tx */
564 OMAP4_IOPAD(0x110, PIN_INPUT_PULLUP | MUX_MODE5) /* uart4_cts */
565 OMAP4_IOPAD(0x112, PIN_OUTPUT_PULLUP | MUX_MODE5) /* uart4_rts */
566 >;
567 };
568
569 mcbsp2_pins: mcbsp2-pins {
570 pinctrl-single,pins = <
571 OMAP4_IOPAD(0x0f6, PIN_INPUT | MUX_MODE0) /* abe_mcbsp2_clkx */
572 OMAP4_IOPAD(0x0f8, PIN_INPUT | MUX_MODE0) /* abe_mcbsp2_dr */
573 OMAP4_IOPAD(0x0fa, PIN_OUTPUT | MUX_MODE0) /* abe_mcbsp2_dx */
574 OMAP4_IOPAD(0x0fc, PIN_INPUT | MUX_MODE0) /* abe_mcbsp2_fsx */
575 >;
576 };
577
578 mcbsp3_pins: mcbsp3-pins {
579 pinctrl-single,pins = <
580 OMAP4_IOPAD(0x106, PIN_INPUT | MUX_MODE1) /* abe_mcbsp3_dr */
581 OMAP4_IOPAD(0x108, PIN_OUTPUT | MUX_MODE1) /* abe_mcbsp3_dx */
582 OMAP4_IOPAD(0x10a, PIN_INPUT | MUX_MODE1) /* abe_mcbsp3_clkx */
583 OMAP4_IOPAD(0x10c, PIN_INPUT | MUX_MODE1) /* abe_mcbsp3_fsx */
584 >;
585 };
586
587 vibrator_direction_pin: vibrator-direction-pins {
588 pinctrl-single,pins = <
589 OMAP4_IOPAD(0x1ce, PIN_OUTPUT | MUX_MODE1) /* dmtimer8_pwm_evt (gpio_27) */
590 >;
591 };
592
593 vibrator_enable_pin: vibrator-enable-pins {
594 pinctrl-single,pins = <
595 OMAP4_IOPAD(0X1d0, PIN_OUTPUT | MUX_MODE1) /* dmtimer9_pwm_evt (gpio_28) */
596 >;
597 };
598 };
599
600 &omap4_pmx_wkup {
601 usb_gpio_mux_sel2: usb-gpio-mux-sel2-pins {
602 /* gpio_wk0 */
603 pinctrl-single,pins = <
604 OMAP4_IOPAD(0x040, PIN_OUTPUT_PULLDOWN | MUX_MODE3)
605 >;
606 };
607 };
608
609 /* RNG is used by secure mode and not accessible */
610 &rng_target {
611 status = "disabled";
612 };
613
614 /* Configure pwm clock source for timers 8 & 9 */
615 &timer8 {
616 assigned-clocks = <&abe_clkctrl OMAP4_TIMER8_CLKCTRL 24>;
617 assigned-clock-parents = <&sys_32k_ck>;
618 };
619
620 &timer9 {
621 assigned-clocks = <&l4_per_clkctrl OMAP4_TIMER9_CLKCTRL 24>;
622 assigned-clock-parents = <&sys_32k_ck>;
623 };
624
625 /*
626 * The uart1 port is wired to mdm6600 with rts and cts. The modem uses gpio_149
627 * for wake-up events for both the USB PHY and the UART. We can use gpio_149
628 * pad as the shared wakeirq for the UART rather than the RX or CTS pad as we
629 * have gpio_149 trigger before the UART transfer starts.
630 */
631 &uart1 {
632 pinctrl-names = "default";
633 pinctrl-0 = <&uart1_pins>;
634 interrupts-extended = <&wakeupgen GIC_SPI 72 IRQ_TYPE_LEVEL_HIGH
635 &omap4_pmx_core 0x110>;
636 uart-has-rtscts;
637 current-speed = <115200>;
638 };
639
640 &uart3 {
641 interrupts-extended = <&wakeupgen GIC_SPI 74 IRQ_TYPE_LEVEL_HIGH
642 &omap4_pmx_core 0x17c>;
643 overrun-throttle-ms = <500>;
644 };
645
646 &uart4 {
647 pinctrl-names = "default";
648 pinctrl-0 = <&uart4_pins>;
649
650 bluetooth {
651 compatible = "ti,wl1285-st";
652 enable-gpios = <&gpio6 14 GPIO_ACTIVE_HIGH>; /* gpio 174 */
653 max-speed = <3686400>;
654 };
655 };
656
657 &usbhsohci {
658 phys = <&fsusb1_phy>;
659 phy-names = "usb";
660 };
661
662 &usbhsehci {
663 phys = <&hsusb2_phy>;
664 };
665
666 &usbhshost {
667 port1-mode = "ohci-phy-4pin-dpdm";
668 port2-mode = "ehci-tll";
669 };
670
671 /* Internal UTMI+ PHY used for OTG, CPCAP ULPI PHY for detection and charger */
672 &usb_otg_hs {
673 interface-type = <1>;
674 mode = <3>;
675
676 /*
677 * Max 300 mA steps based on similar PMIC MC13783UG.pdf "Table 10-4.
678 * VBUS Regulator Main Characteristics". Binding uses 2 mA units.
679 */
680 power = <150>;
681 };
682
683 &i2c4 {
684 ak8975: magnetometer@c {
685 compatible = "asahi-kasei,ak8975";
686 reg = <0x0c>;
687
688 vdd-supply = <&vhvio>;
689
690 interrupt-parent = <&gpio6>;
691 interrupts = <15 IRQ_TYPE_EDGE_RISING>; /* gpio175 */
692
693 rotation-matrix = "-1", "0", "0",
694 "0", "1", "0",
695 "0", "0", "-1";
696
697 };
698 };
699
700 &mcbsp2 {
701 #sound-dai-cells = <0>;
702 pinctrl-names = "default";
703 pinctrl-0 = <&mcbsp2_pins>;
704 status = "okay";
705
706 mcbsp2_port: port {
707 cpu_dai2: endpoint {
708 dai-format = "i2s";
709 remote-endpoint = <&cpcap_audio_codec0>;
710 frame-master = <&cpcap_audio_codec0>;
711 bitclock-master = <&cpcap_audio_codec0>;
712 };
713 };
714 };
715
716 &mcbsp3 {
717 #sound-dai-cells = <0>;
718 pinctrl-names = "default";
719 pinctrl-0 = <&mcbsp3_pins>;
720 status = "okay";
721
722 mcbsp3_port: port {
723 cpu_dai3: endpoint {
724 dai-format = "dsp_a";
725 frame-master = <&cpcap_audio_codec1>;
726 bitclock-master = <&cpcap_audio_codec1>;
727 remote-endpoint = <&cpcap_audio_codec1>;
728 };
729 };
730 };
731
732 &cpcap_audio_codec0 {
733 remote-endpoint = <&cpu_dai2>;
734 };
735
736 &cpcap_audio_codec1 {
737 remote-endpoint = <&cpu_dai3>;
738 };