xref: /freebsd/sys/contrib/device-tree/src/arm/ti/omap/motorola-mapphone-common.dtsi (revision aa1a8ff2d6dbc51ef058f46f3db5a8bb77967145)
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};
739