]>
Commit | Line | Data |
---|---|---|
d2912cb1 | 1 | // SPDX-License-Identifier: GPL-2.0-only |
295e98c6 BC |
2 | /* |
3 | * Copyright (C) 2011 Texas Instruments Incorporated - http://www.ti.com/ | |
295e98c6 BC |
4 | */ |
5 | /dts-v1/; | |
6 | ||
98ef7957 | 7 | #include "omap36xx.dtsi" |
295e98c6 BC |
8 | |
9 | / { | |
642f12b4 | 10 | model = "TI OMAP3 BeagleBoard xM"; |
016c12d2 | 11 | compatible = "ti,omap3-beagle-xm", "ti,omap36xx", "ti,omap3"; |
295e98c6 | 12 | |
a134be34 NM |
13 | cpus { |
14 | cpu@0 { | |
15 | cpu0-supply = <&vcc>; | |
16 | }; | |
17 | }; | |
18 | ||
81777ff9 | 19 | memory@80000000 { |
295e98c6 BC |
20 | device_type = "memory"; |
21 | reg = <0x80000000 0x20000000>; /* 512 MB */ | |
22 | }; | |
a60be2fe | 23 | |
9955a9e5 TV |
24 | aliases { |
25 | display0 = &dvi0; | |
26 | display1 = &tv0; | |
055d31de | 27 | ethernet = ðernet; |
9955a9e5 TV |
28 | }; |
29 | ||
bcddb927 PU |
30 | /* fixed 26MHz oscillator */ |
31 | hfclk_26m: oscillator { | |
32 | #clock-cells = <0>; | |
33 | compatible = "fixed-clock"; | |
34 | clock-frequency = <26000000>; | |
35 | }; | |
36 | ||
a60be2fe FV |
37 | leds { |
38 | compatible = "gpio-leds"; | |
1c1737e5 BC |
39 | |
40 | heartbeat { | |
41 | label = "beagleboard::usr0"; | |
6d624eab | 42 | gpios = <&gpio5 22 GPIO_ACTIVE_HIGH>; /* 150 -> D6 LED */ |
1c1737e5 BC |
43 | linux,default-trigger = "heartbeat"; |
44 | }; | |
45 | ||
46 | mmc { | |
47 | label = "beagleboard::usr1"; | |
6d624eab | 48 | gpios = <&gpio5 21 GPIO_ACTIVE_HIGH>; /* 149 -> D7 LED */ |
1c1737e5 BC |
49 | linux,default-trigger = "mmc0"; |
50 | }; | |
a60be2fe | 51 | }; |
2c195f9c | 52 | |
2c09c60c PU |
53 | pwmleds { |
54 | compatible = "pwm-leds"; | |
55 | ||
56 | pmu_stat { | |
57 | label = "beagleboard::pmu_stat"; | |
58 | pwms = <&twl_pwmled 1 7812500>; | |
59 | max-brightness = <127>; | |
60 | }; | |
61 | }; | |
62 | ||
2c195f9c PU |
63 | sound { |
64 | compatible = "ti,omap-twl4030"; | |
65 | ti,model = "omap3beagle"; | |
66 | ||
67 | ti,mcbsp = <&mcbsp2>; | |
2c195f9c | 68 | }; |
d641c3d5 KH |
69 | |
70 | gpio_keys { | |
71 | compatible = "gpio-keys"; | |
72 | ||
73 | user { | |
74 | label = "user"; | |
75 | gpios = <&gpio1 4 GPIO_ACTIVE_HIGH>; | |
76 | linux,code = <0x114>; | |
0c4d63b3 | 77 | wakeup-source; |
d641c3d5 KH |
78 | }; |
79 | ||
80 | }; | |
aaba9442 RQ |
81 | |
82 | /* HS USB Port 2 Power */ | |
83 | hsusb2_power: hsusb2_power_reg { | |
84 | compatible = "regulator-fixed"; | |
85 | regulator-name = "hsusb2_vbus"; | |
86 | regulator-min-microvolt = <3300000>; | |
87 | regulator-max-microvolt = <3300000>; | |
3a637e00 | 88 | gpio = <&twl_gpio 18 GPIO_ACTIVE_HIGH>; /* GPIO LEDA */ |
aaba9442 RQ |
89 | startup-delay-us = <70000>; |
90 | }; | |
91 | ||
92 | /* HS USB Host PHY on PORT 2 */ | |
93 | hsusb2_phy: hsusb2_phy { | |
94 | compatible = "usb-nop-xceiv"; | |
95 | reset-gpios = <&gpio5 19 GPIO_ACTIVE_LOW>; /* gpio_147 */ | |
96 | vcc-supply = <&hsusb2_power>; | |
f568f6f5 | 97 | #phy-cells = <0>; |
aaba9442 | 98 | }; |
9955a9e5 | 99 | |
a58280e5 | 100 | tfp410: encoder0 { |
9955a9e5 TV |
101 | compatible = "ti,tfp410"; |
102 | powerdown-gpios = <&twl_gpio 2 GPIO_ACTIVE_LOW>; | |
103 | ||
104 | /* XXX pinctrl from twl */ | |
105 | ||
106 | ports { | |
107 | #address-cells = <1>; | |
108 | #size-cells = <0>; | |
109 | ||
110 | port@0 { | |
111 | reg = <0>; | |
112 | ||
a58280e5 | 113 | tfp410_in: endpoint { |
9955a9e5 TV |
114 | remote-endpoint = <&dpi_out>; |
115 | }; | |
116 | }; | |
117 | ||
118 | port@1 { | |
119 | reg = <1>; | |
120 | ||
a58280e5 | 121 | tfp410_out: endpoint { |
9955a9e5 TV |
122 | remote-endpoint = <&dvi_connector_in>; |
123 | }; | |
124 | }; | |
125 | }; | |
126 | }; | |
127 | ||
a58280e5 | 128 | dvi0: connector0 { |
9955a9e5 TV |
129 | compatible = "dvi-connector"; |
130 | label = "dvi"; | |
131 | ||
132 | digital; | |
133 | ||
134 | ddc-i2c-bus = <&i2c3>; | |
135 | ||
136 | port { | |
137 | dvi_connector_in: endpoint { | |
138 | remote-endpoint = <&tfp410_out>; | |
139 | }; | |
140 | }; | |
141 | }; | |
142 | ||
a58280e5 | 143 | tv0: connector1 { |
9955a9e5 TV |
144 | compatible = "svideo-connector"; |
145 | label = "tv"; | |
146 | ||
147 | port { | |
148 | tv_connector_in: endpoint { | |
149 | remote-endpoint = <&venc_out>; | |
150 | }; | |
151 | }; | |
152 | }; | |
9d316202 MP |
153 | |
154 | etb@5401b000 { | |
155 | compatible = "arm,coresight-etb10", "arm,primecell"; | |
156 | reg = <0x5401b000 0x1000>; | |
157 | ||
9d316202 MP |
158 | clocks = <&emu_src_ck>; |
159 | clock-names = "apb_pclk"; | |
f2b07213 SP |
160 | in-ports { |
161 | port { | |
162 | etb_in: endpoint { | |
163 | remote-endpoint = <&etm_out>; | |
164 | }; | |
9d316202 MP |
165 | }; |
166 | }; | |
167 | }; | |
168 | ||
169 | etm@54010000 { | |
170 | compatible = "arm,coresight-etm3x", "arm,primecell"; | |
171 | reg = <0x54010000 0x1000>; | |
172 | ||
173 | clocks = <&emu_src_ck>; | |
174 | clock-names = "apb_pclk"; | |
f2b07213 SP |
175 | out-ports { |
176 | port { | |
177 | etm_out: endpoint { | |
178 | remote-endpoint = <&etb_in>; | |
179 | }; | |
9d316202 MP |
180 | }; |
181 | }; | |
182 | }; | |
d641c3d5 KH |
183 | }; |
184 | ||
185 | &omap3_pmx_wkup { | |
186 | gpio1_pins: pinmux_gpio1_pins { | |
187 | pinctrl-single,pins = < | |
0ba47e43 | 188 | OMAP3_WKUP_IOPAD(0x2a0e, PIN_INPUT | PIN_OFF_WAKEUPENABLE | MUX_MODE4) /* sys_boot2.gpio_4 */ |
d641c3d5 KH |
189 | >; |
190 | }; | |
9955a9e5 TV |
191 | |
192 | dss_dpi_pins2: pinmux_dss_dpi_pins1 { | |
193 | pinctrl-single,pins = < | |
0ba47e43 JMC |
194 | OMAP3_WKUP_IOPAD(0x2a0a, PIN_OUTPUT | MUX_MODE3) /* sys_boot0.dss_data18 */ |
195 | OMAP3_WKUP_IOPAD(0x2a0c, PIN_OUTPUT | MUX_MODE3) /* sys_boot1.dss_data19 */ | |
196 | OMAP3_WKUP_IOPAD(0x2a10, PIN_OUTPUT | MUX_MODE3) /* sys_boot3.dss_data20 */ | |
197 | OMAP3_WKUP_IOPAD(0x2a12, PIN_OUTPUT | MUX_MODE3) /* sys_boot4.dss_data21 */ | |
198 | OMAP3_WKUP_IOPAD(0x2a14, PIN_OUTPUT | MUX_MODE3) /* sys_boot5.dss_data22 */ | |
199 | OMAP3_WKUP_IOPAD(0x2a16, PIN_OUTPUT | MUX_MODE3) /* sys_boot6.dss_data23 */ | |
9955a9e5 TV |
200 | >; |
201 | }; | |
295e98c6 | 202 | }; |
5340b51d | 203 | |
aaba9442 RQ |
204 | &omap3_pmx_core { |
205 | pinctrl-names = "default"; | |
206 | pinctrl-0 = < | |
3d495383 | 207 | &hsusb2_pins |
aaba9442 RQ |
208 | >; |
209 | ||
210 | uart3_pins: pinmux_uart3_pins { | |
211 | pinctrl-single,pins = < | |
0ba47e43 JMC |
212 | OMAP3_CORE1_IOPAD(0x219e, PIN_INPUT | MUX_MODE0) /* uart3_rx_irrx.uart3_rx_irrx */ |
213 | OMAP3_CORE1_IOPAD(0x21a0, PIN_OUTPUT | MUX_MODE0) /* uart3_tx_irtx.uart3_tx_irtx OUTPUT | MODE0 */ | |
aaba9442 RQ |
214 | >; |
215 | }; | |
216 | ||
3d495383 | 217 | hsusb2_pins: pinmux_hsusb2_pins { |
aaba9442 | 218 | pinctrl-single,pins = < |
3d495383 LP |
219 | OMAP3_CORE1_IOPAD(0x21d4, PIN_INPUT_PULLDOWN | MUX_MODE3) /* mcspi1_cs3.hsusb2_data2 */ |
220 | OMAP3_CORE1_IOPAD(0x21d6, PIN_INPUT_PULLDOWN | MUX_MODE3) /* mcspi2_clk.hsusb2_data7 */ | |
221 | OMAP3_CORE1_IOPAD(0x21d8, PIN_INPUT_PULLDOWN | MUX_MODE3) /* mcspi2_simo.hsusb2_data4 */ | |
222 | OMAP3_CORE1_IOPAD(0x21da, PIN_INPUT_PULLDOWN | MUX_MODE3) /* mcspi2_somi.hsusb2_data5 */ | |
223 | OMAP3_CORE1_IOPAD(0x21dc, PIN_INPUT_PULLDOWN | MUX_MODE3) /* mcspi2_cs0.hsusb2_data6 */ | |
224 | OMAP3_CORE1_IOPAD(0x21de, PIN_INPUT_PULLDOWN | MUX_MODE3) /* mcspi2_cs1.hsusb2_data3 */ | |
225 | >; | |
226 | }; | |
9955a9e5 TV |
227 | |
228 | dss_dpi_pins1: pinmux_dss_dpi_pins2 { | |
229 | pinctrl-single,pins = < | |
230 | OMAP3_CORE1_IOPAD(0x20d4, PIN_OUTPUT | MUX_MODE0) /* dss_pclk.dss_pclk */ | |
231 | OMAP3_CORE1_IOPAD(0x20d6, PIN_OUTPUT | MUX_MODE0) /* dss_hsync.dss_hsync */ | |
232 | OMAP3_CORE1_IOPAD(0x20d8, PIN_OUTPUT | MUX_MODE0) /* dss_vsync.dss_vsync */ | |
233 | OMAP3_CORE1_IOPAD(0x20da, PIN_OUTPUT | MUX_MODE0) /* dss_acbias.dss_acbias */ | |
234 | ||
235 | OMAP3_CORE1_IOPAD(0x20e8, PIN_OUTPUT | MUX_MODE0) /* dss_data6.dss_data6 */ | |
236 | OMAP3_CORE1_IOPAD(0x20ea, PIN_OUTPUT | MUX_MODE0) /* dss_data7.dss_data7 */ | |
237 | OMAP3_CORE1_IOPAD(0x20ec, PIN_OUTPUT | MUX_MODE0) /* dss_data8.dss_data8 */ | |
238 | OMAP3_CORE1_IOPAD(0x20ee, PIN_OUTPUT | MUX_MODE0) /* dss_data9.dss_data9 */ | |
239 | OMAP3_CORE1_IOPAD(0x20f0, PIN_OUTPUT | MUX_MODE0) /* dss_data10.dss_data10 */ | |
240 | OMAP3_CORE1_IOPAD(0x20f2, PIN_OUTPUT | MUX_MODE0) /* dss_data11.dss_data11 */ | |
241 | OMAP3_CORE1_IOPAD(0x20f4, PIN_OUTPUT | MUX_MODE0) /* dss_data12.dss_data12 */ | |
242 | OMAP3_CORE1_IOPAD(0x20f6, PIN_OUTPUT | MUX_MODE0) /* dss_data13.dss_data13 */ | |
243 | OMAP3_CORE1_IOPAD(0x20f8, PIN_OUTPUT | MUX_MODE0) /* dss_data14.dss_data14 */ | |
244 | OMAP3_CORE1_IOPAD(0x20fa, PIN_OUTPUT | MUX_MODE0) /* dss_data15.dss_data15 */ | |
245 | OMAP3_CORE1_IOPAD(0x20fc, PIN_OUTPUT | MUX_MODE0) /* dss_data16.dss_data16 */ | |
246 | OMAP3_CORE1_IOPAD(0x20fe, PIN_OUTPUT | MUX_MODE0) /* dss_data17.dss_data17 */ | |
247 | ||
248 | OMAP3_CORE1_IOPAD(0x2100, PIN_OUTPUT | MUX_MODE3) /* dss_data18.dss_data0 */ | |
249 | OMAP3_CORE1_IOPAD(0x2102, PIN_OUTPUT | MUX_MODE3) /* dss_data19.dss_data1 */ | |
250 | OMAP3_CORE1_IOPAD(0x2104, PIN_OUTPUT | MUX_MODE3) /* dss_data20.dss_data2 */ | |
251 | OMAP3_CORE1_IOPAD(0x2106, PIN_OUTPUT | MUX_MODE3) /* dss_data21.dss_data3 */ | |
252 | OMAP3_CORE1_IOPAD(0x2108, PIN_OUTPUT | MUX_MODE3) /* dss_data22.dss_data4 */ | |
253 | OMAP3_CORE1_IOPAD(0x210a, PIN_OUTPUT | MUX_MODE3) /* dss_data23.dss_data5 */ | |
254 | >; | |
255 | }; | |
3d495383 LP |
256 | }; |
257 | ||
258 | &omap3_pmx_core2 { | |
259 | pinctrl-names = "default"; | |
260 | pinctrl-0 = < | |
261 | &hsusb2_2_pins | |
262 | >; | |
263 | ||
264 | hsusb2_2_pins: pinmux_hsusb2_2_pins { | |
265 | pinctrl-single,pins = < | |
266 | OMAP3630_CORE2_IOPAD(0x25f0, PIN_OUTPUT | MUX_MODE3) /* etk_d10.hsusb2_clk */ | |
267 | OMAP3630_CORE2_IOPAD(0x25f2, PIN_OUTPUT | MUX_MODE3) /* etk_d11.hsusb2_stp */ | |
268 | OMAP3630_CORE2_IOPAD(0x25f4, PIN_INPUT_PULLDOWN | MUX_MODE3) /* etk_d12.hsusb2_dir */ | |
269 | OMAP3630_CORE2_IOPAD(0x25f6, PIN_INPUT_PULLDOWN | MUX_MODE3) /* etk_d13.hsusb2_nxt */ | |
270 | OMAP3630_CORE2_IOPAD(0x25f8, PIN_INPUT_PULLDOWN | MUX_MODE3) /* etk_d14.hsusb2_data0 */ | |
271 | OMAP3630_CORE2_IOPAD(0x25fa, PIN_INPUT_PULLDOWN | MUX_MODE3) /* etk_d15.hsusb2_data1 */ | |
aaba9442 RQ |
272 | >; |
273 | }; | |
274 | }; | |
275 | ||
5340b51d BC |
276 | &i2c1 { |
277 | clock-frequency = <2600000>; | |
278 | ||
279 | twl: twl@48 { | |
280 | reg = <0x48>; | |
281 | interrupts = <7>; /* SYS_NIRQ cascaded to intc */ | |
282 | interrupt-parent = <&intc>; | |
ecc7b060 | 283 | |
bcddb927 PU |
284 | clocks = <&hfclk_26m>; |
285 | clock-names = "fck"; | |
286 | ||
2c195f9c PU |
287 | twl_audio: audio { |
288 | compatible = "ti,twl4030-audio"; | |
289 | codec { | |
290 | }; | |
291 | }; | |
9188883f TL |
292 | |
293 | twl_power: power { | |
294 | compatible = "ti,twl4030-power-beagleboard-xm", "ti,twl4030-power-idle-osc-off"; | |
295 | ti,use_poweroff; | |
296 | }; | |
5340b51d BC |
297 | }; |
298 | }; | |
299 | ||
98ef7957 | 300 | #include "twl4030.dtsi" |
f9688457 | 301 | #include "twl4030_omap3.dtsi" |
5340b51d BC |
302 | |
303 | &i2c2 { | |
304 | clock-frequency = <400000>; | |
305 | }; | |
306 | ||
307 | &i2c3 { | |
308 | clock-frequency = <100000>; | |
5340b51d | 309 | }; |
b3431f5b RN |
310 | |
311 | &mmc1 { | |
312 | vmmc-supply = <&vmmc1>; | |
45ea75eb | 313 | vqmmc-supply = <&vsim>; |
7f217794 | 314 | bus-width = <8>; |
b3431f5b RN |
315 | }; |
316 | ||
317 | &mmc2 { | |
fd5c3fd7 | 318 | status = "disabled"; |
b3431f5b RN |
319 | }; |
320 | ||
321 | &mmc3 { | |
fd5c3fd7 | 322 | status = "disabled"; |
b3431f5b | 323 | }; |
a60be2fe FV |
324 | |
325 | &twl_gpio { | |
326 | ti,use-leds; | |
327 | /* pullups: BIT(1) */ | |
328 | ti,pullups = <0x000002>; | |
329 | /* | |
330 | * pulldowns: | |
331 | * BIT(2), BIT(6), BIT(7), BIT(8), BIT(13) | |
332 | * BIT(15), BIT(16), BIT(17) | |
333 | */ | |
334 | ti,pulldowns = <0x03a1c4>; | |
335 | }; | |
ad871c10 KVA |
336 | |
337 | &usb_otg_hs { | |
338 | interface-type = <0>; | |
914dc329 | 339 | usb-phy = <&usb2_phy>; |
975d963e KVA |
340 | phys = <&usb2_phy>; |
341 | phy-names = "usb2-phy"; | |
ad871c10 KVA |
342 | mode = <3>; |
343 | power = <50>; | |
344 | }; | |
b859c1ef | 345 | |
b859c1ef | 346 | &uart3 { |
9188883f | 347 | interrupts-extended = <&intc 74 &omap3_pmx_core OMAP3_UART3_RX>; |
b859c1ef KH |
348 | pinctrl-names = "default"; |
349 | pinctrl-0 = <&uart3_pins>; | |
350 | }; | |
d641c3d5 KH |
351 | |
352 | &gpio1 { | |
353 | pinctrl-names = "default"; | |
354 | pinctrl-0 = <&gpio1_pins>; | |
355 | }; | |
aaba9442 RQ |
356 | |
357 | &usbhshost { | |
358 | port2-mode = "ehci-phy"; | |
359 | }; | |
360 | ||
361 | &usbhsehci { | |
362 | phys = <0 &hsusb2_phy>; | |
055d31de LP |
363 | |
364 | #address-cells = <1>; | |
365 | #size-cells = <0>; | |
366 | ||
367 | hub@2 { | |
368 | compatible = "usb424,9514"; | |
369 | reg = <2>; | |
370 | #address-cells = <1>; | |
371 | #size-cells = <0>; | |
372 | ||
373 | ethernet: usbether@1 { | |
374 | compatible = "usb424,ec00"; | |
375 | reg = <1>; | |
376 | }; | |
377 | }; | |
aaba9442 | 378 | }; |
30023a7e RQ |
379 | |
380 | &vaux2 { | |
381 | regulator-name = "usb_1v8"; | |
382 | regulator-min-microvolt = <1800000>; | |
383 | regulator-max-microvolt = <1800000>; | |
384 | regulator-always-on; | |
385 | }; | |
726322ce PU |
386 | |
387 | &mcbsp2 { | |
388 | status = "okay"; | |
389 | }; | |
9955a9e5 TV |
390 | |
391 | &dss { | |
392 | status = "ok"; | |
393 | ||
394 | pinctrl-names = "default"; | |
395 | pinctrl-0 = < | |
396 | &dss_dpi_pins1 | |
397 | &dss_dpi_pins2 | |
398 | >; | |
399 | ||
400 | port { | |
401 | dpi_out: endpoint { | |
402 | remote-endpoint = <&tfp410_in>; | |
403 | data-lines = <24>; | |
404 | }; | |
405 | }; | |
406 | }; | |
407 | ||
408 | &venc { | |
409 | status = "ok"; | |
410 | ||
411 | vdda-supply = <&vdac>; | |
412 | ||
413 | port { | |
414 | venc_out: endpoint { | |
415 | remote-endpoint = <&tv_connector_in>; | |
416 | ti,channels = <2>; | |
417 | }; | |
418 | }; | |
419 | }; |