Loading...
Note: File does not exist in v4.17.
1// SPDX-License-Identifier: GPL-2.0
2#include "tegra20.dtsi"
3
4/*
5 * Toradex Colibri T20 Module Device Tree
6 * Compatible for Revisions Colibri T20 256MB V1.1B, V1.2A;
7 * Colibri T20 256MB IT V1.2A; Colibri T20 512MB V1.1C, V1.2A;
8 * Colibri T20 512MB IT V1.2A
9 */
10/ {
11 memory@0 {
12 /*
13 * Set memory to 256 MB to be safe as this could be used on
14 * 256 or 512 MB module. It is expected from bootloader
15 * to fix this up for 512 MB version.
16 */
17 reg = <0x00000000 0x10000000>;
18 };
19
20 host1x@50000000 {
21 hdmi@54280000 {
22 nvidia,ddc-i2c-bus = <&hdmi_ddc>;
23 nvidia,hpd-gpio =
24 <&gpio TEGRA_GPIO(N, 7) GPIO_ACTIVE_HIGH>;
25 pll-supply = <®_1v8_avdd_hdmi_pll>;
26 vdd-supply = <®_3v3_avdd_hdmi>;
27 };
28 };
29
30 pinmux@70000014 {
31 pinctrl-names = "default";
32 pinctrl-0 = <&state_default>;
33
34 state_default: pinmux {
35 /* Analogue Audio AC97 to WM9712 (On-module) */
36 audio-refclk {
37 nvidia,pins = "cdev1";
38 nvidia,function = "plla_out";
39 nvidia,pull = <TEGRA_PIN_PULL_NONE>;
40 nvidia,tristate = <TEGRA_PIN_DISABLE>;
41 };
42 dap3 {
43 nvidia,pins = "dap3";
44 nvidia,function = "dap3";
45 nvidia,pull = <TEGRA_PIN_PULL_NONE>;
46 nvidia,tristate = <TEGRA_PIN_DISABLE>;
47 };
48
49 /*
50 * AC97_RESET, ULPI_RESET, AC97_INT aka WM9712 GENIRQ
51 * (All on-module), SODIMM Pin 45 Wakeup
52 */
53 gpio-uac {
54 nvidia,pins = "uac";
55 nvidia,function = "rsvd2";
56 nvidia,pull = <TEGRA_PIN_PULL_NONE>;
57 nvidia,tristate = <TEGRA_PIN_DISABLE>;
58 };
59
60 /*
61 * Buffer Enables for nPWE and RDnWR (On-module,
62 * see GPIO hogging further down below)
63 */
64 gpio-pta {
65 nvidia,pins = "pta";
66 nvidia,function = "rsvd4";
67 nvidia,pull = <TEGRA_PIN_PULL_NONE>;
68 nvidia,tristate = <TEGRA_PIN_DISABLE>;
69 };
70
71 /*
72 * CLK_32K_OUT, CORE_PWR_REQ, CPU_PWR_REQ, PWR_INT_N,
73 * SYS_CLK_REQ (All on-module)
74 */
75 pmc {
76 nvidia,pins = "pmc";
77 nvidia,function = "pwr_on";
78 nvidia,tristate = <TEGRA_PIN_DISABLE>;
79 };
80
81 /*
82 * Colibri Address/Data Bus (GMI)
83 * Note: spid and spie optionally used for SPI1
84 */
85 gmi {
86 nvidia,pins = "atc", "atd", "ate", "dap1",
87 "dap2", "dap4", "gmd", "gpu",
88 "irrx", "irtx", "spia", "spib",
89 "spic", "spid", "spie", "uca",
90 "ucb";
91 nvidia,function = "gmi";
92 nvidia,pull = <TEGRA_PIN_PULL_NONE>;
93 nvidia,tristate = <TEGRA_PIN_ENABLE>;
94 };
95 /* Further pins may be used as GPIOs */
96 gmi-gpio1 {
97 nvidia,pins = "lpw0", "lsc1", "lsck", "lsda";
98 nvidia,function = "hdmi";
99 nvidia,tristate = <TEGRA_PIN_ENABLE>;
100 };
101 gmi-gpio2 {
102 nvidia,pins = "lcsn", "ldc", "lm0", "lsdi";
103 nvidia,function = "rsvd4";
104 nvidia,tristate = <TEGRA_PIN_ENABLE>;
105 };
106
107 /* Colibri BL_ON */
108 bl-on {
109 nvidia,pins = "dta";
110 nvidia,function = "rsvd1";
111 nvidia,pull = <TEGRA_PIN_PULL_NONE>;
112 nvidia,tristate = <TEGRA_PIN_ENABLE>;
113 };
114
115 /* Colibri Backlight PWM<A>, PWM<B> */
116 sdc {
117 nvidia,pins = "sdc";
118 nvidia,function = "pwm";
119 nvidia,tristate = <TEGRA_PIN_ENABLE>;
120 };
121
122 /* Colibri DDC */
123 ddc {
124 nvidia,pins = "ddc";
125 nvidia,function = "i2c2";
126 nvidia,pull = <TEGRA_PIN_PULL_UP>;
127 nvidia,tristate = <TEGRA_PIN_ENABLE>;
128 };
129
130 /*
131 * Colibri EXT_IO*
132 * Note: dtf optionally used for I2C3
133 */
134 ext-io {
135 nvidia,pins = "dtf", "spdi";
136 nvidia,function = "rsvd2";
137 nvidia,pull = <TEGRA_PIN_PULL_NONE>;
138 nvidia,tristate = <TEGRA_PIN_ENABLE>;
139 };
140
141 /*
142 * Colibri Ethernet (On-module)
143 * ULPI EHCI instance 1 USB2_DP/N -> AX88772B
144 */
145 ulpi {
146 nvidia,pins = "uaa", "uab", "uda";
147 nvidia,function = "ulpi";
148 nvidia,pull = <TEGRA_PIN_PULL_NONE>;
149 nvidia,tristate = <TEGRA_PIN_DISABLE>;
150 };
151 ulpi-refclk {
152 nvidia,pins = "cdev2";
153 nvidia,function = "pllp_out4";
154 nvidia,pull = <TEGRA_PIN_PULL_NONE>;
155 nvidia,tristate = <TEGRA_PIN_DISABLE>;
156 };
157
158 /* Colibri HOTPLUG_DETECT (HDMI) */
159 hotplug-detect {
160 nvidia,pins = "hdint";
161 nvidia,function = "hdmi";
162 nvidia,tristate = <TEGRA_PIN_ENABLE>;
163 };
164
165 /* Colibri I2C */
166 i2c {
167 nvidia,pins = "rm";
168 nvidia,function = "i2c1";
169 nvidia,pull = <TEGRA_PIN_PULL_NONE>;
170 nvidia,tristate = <TEGRA_PIN_ENABLE>;
171 };
172
173 /*
174 * Colibri L_BIAS, LCD_M1 is muxed with LCD_DE
175 * today's display need DE, disable LCD_M1
176 */
177 lm1 {
178 nvidia,pins = "lm1";
179 nvidia,function = "rsvd3";
180 nvidia,tristate = <TEGRA_PIN_ENABLE>;
181 };
182
183 /* Colibri LCD (L_* resp. LDD<*>) */
184 lcd {
185 nvidia,pins = "ld0", "ld1", "ld2", "ld3",
186 "ld4", "ld5", "ld6", "ld7",
187 "ld8", "ld9", "ld10", "ld11",
188 "ld12", "ld13", "ld14", "ld15",
189 "ld16", "ld17", "lhs", "lsc0",
190 "lspi", "lvs";
191 nvidia,function = "displaya";
192 nvidia,tristate = <TEGRA_PIN_ENABLE>;
193 };
194 /* Colibri LCD (Optional 24 BPP Support) */
195 lcd-24 {
196 nvidia,pins = "ldi", "lhp0", "lhp1", "lhp2",
197 "lpp", "lvp1";
198 nvidia,function = "displaya";
199 nvidia,tristate = <TEGRA_PIN_ENABLE>;
200 };
201
202 /* Colibri MMC */
203 mmc {
204 nvidia,pins = "atb", "gma";
205 nvidia,function = "sdio4";
206 nvidia,pull = <TEGRA_PIN_PULL_NONE>;
207 nvidia,tristate = <TEGRA_PIN_ENABLE>;
208 };
209
210 /* Colibri MMCCD */
211 mmccd {
212 nvidia,pins = "gmb";
213 nvidia,function = "gmi_int";
214 nvidia,pull = <TEGRA_PIN_PULL_NONE>;
215 nvidia,tristate = <TEGRA_PIN_ENABLE>;
216 };
217
218 /* Colibri MMC (Optional 8-bit) */
219 mmc-8bit {
220 nvidia,pins = "gme";
221 nvidia,function = "sdio4";
222 nvidia,pull = <TEGRA_PIN_PULL_NONE>;
223 nvidia,tristate = <TEGRA_PIN_ENABLE>;
224 };
225
226 /*
227 * Colibri Parallel Camera (Optional)
228 * pins multiplexed with others and therefore disabled
229 * Note: dta used for BL_ON by default
230 */
231 cif-mclk {
232 nvidia,pins = "csus";
233 nvidia,function = "vi_sensor_clk";
234 nvidia,pull = <TEGRA_PIN_PULL_NONE>;
235 nvidia,tristate = <TEGRA_PIN_ENABLE>;
236 };
237 cif {
238 nvidia,pins = "dtb", "dtc", "dtd";
239 nvidia,function = "vi";
240 nvidia,pull = <TEGRA_PIN_PULL_NONE>;
241 nvidia,tristate = <TEGRA_PIN_ENABLE>;
242 };
243
244 /* Colibri PWM<C>, PWM<D> */
245 sdb_sdd {
246 nvidia,pins = "sdb", "sdd";
247 nvidia,function = "pwm";
248 nvidia,tristate = <TEGRA_PIN_ENABLE>;
249 };
250
251 /* Colibri SSP */
252 ssp {
253 nvidia,pins = "slxa", "slxc", "slxd", "slxk";
254 nvidia,function = "spi4";
255 nvidia,pull = <TEGRA_PIN_PULL_NONE>;
256 nvidia,tristate = <TEGRA_PIN_ENABLE>;
257 };
258
259 /* Colibri UART-A */
260 uart-a {
261 nvidia,pins = "sdio1";
262 nvidia,function = "uarta";
263 nvidia,pull = <TEGRA_PIN_PULL_NONE>;
264 nvidia,tristate = <TEGRA_PIN_ENABLE>;
265 };
266 uart-a-dsr {
267 nvidia,pins = "lpw1";
268 nvidia,function = "rsvd3";
269 nvidia,tristate = <TEGRA_PIN_ENABLE>;
270 };
271 uart-a-dcd {
272 nvidia,pins = "lpw2";
273 nvidia,function = "hdmi";
274 nvidia,tristate = <TEGRA_PIN_ENABLE>;
275 };
276
277 /* Colibri UART-B */
278 uart-b {
279 nvidia,pins = "gmc";
280 nvidia,function = "uartd";
281 nvidia,pull = <TEGRA_PIN_PULL_NONE>;
282 nvidia,tristate = <TEGRA_PIN_ENABLE>;
283 };
284
285 /* Colibri UART-C */
286 uart-c {
287 nvidia,pins = "uad";
288 nvidia,function = "irda";
289 nvidia,pull = <TEGRA_PIN_PULL_NONE>;
290 nvidia,tristate = <TEGRA_PIN_ENABLE>;
291 };
292
293 /* Colibri USB_CDET */
294 usb-cdet {
295 nvidia,pins = "spdo";
296 nvidia,function = "rsvd2";
297 nvidia,pull = <TEGRA_PIN_PULL_NONE>;
298 nvidia,tristate = <TEGRA_PIN_ENABLE>;
299 };
300
301 /* Colibri USBH_OC */
302 usbh-oc {
303 nvidia,pins = "spih";
304 nvidia,function = "spi2_alt";
305 nvidia,pull = <TEGRA_PIN_PULL_NONE>;
306 nvidia,tristate = <TEGRA_PIN_ENABLE>;
307 };
308
309 /* Colibri USBH_PEN */
310 usbh-pen {
311 nvidia,pins = "spig";
312 nvidia,function = "spi2_alt";
313 nvidia,pull = <TEGRA_PIN_PULL_NONE>;
314 nvidia,tristate = <TEGRA_PIN_ENABLE>;
315 };
316
317 /* Colibri VGA not supported */
318 vga {
319 nvidia,pins = "crtp";
320 nvidia,function = "crt";
321 nvidia,pull = <TEGRA_PIN_PULL_NONE>;
322 nvidia,tristate = <TEGRA_PIN_ENABLE>;
323 };
324
325 /* I2C3 (Optional) */
326 i2c3 {
327 nvidia,pins = "dtf";
328 nvidia,function = "i2c3";
329 nvidia,pull = <TEGRA_PIN_PULL_NONE>;
330 nvidia,tristate = <TEGRA_PIN_ENABLE>;
331 };
332
333 /* JTAG_RTCK */
334 jtag-rtck {
335 nvidia,pins = "gpu7";
336 nvidia,function = "rtck";
337 nvidia,pull = <TEGRA_PIN_PULL_NONE>;
338 nvidia,tristate = <TEGRA_PIN_ENABLE>;
339 };
340
341 /*
342 * LAN_RESET, LAN_EXT_WAKEUP and LAN_PME
343 * (All On-module)
344 */
345 gpio-gpv {
346 nvidia,pins = "gpv";
347 nvidia,function = "rsvd2";
348 nvidia,pull = <TEGRA_PIN_PULL_NONE>;
349 nvidia,tristate = <TEGRA_PIN_DISABLE>;
350 };
351
352 /*
353 * LAN_V_BUS, VDD_FAULT, BATT_FAULT, WM9712 PENDOWN
354 * (All On-module); Colibri CAN_INT
355 */
356 gpio-dte {
357 nvidia,pins = "dte";
358 nvidia,function = "rsvd1";
359 nvidia,pull = <TEGRA_PIN_PULL_NONE>;
360 nvidia,tristate = <TEGRA_PIN_DISABLE>;
361 };
362
363 /* NAND (On-module) */
364 nand {
365 nvidia,pins = "kbca", "kbcb", "kbcc", "kbcd",
366 "kbce", "kbcf";
367 nvidia,function = "nand";
368 nvidia,pull = <TEGRA_PIN_PULL_NONE>;
369 nvidia,tristate = <TEGRA_PIN_DISABLE>;
370 };
371
372 /* Onewire (Optional) */
373 owr {
374 nvidia,pins = "owc";
375 nvidia,function = "owr";
376 nvidia,pull = <TEGRA_PIN_PULL_NONE>;
377 nvidia,tristate = <TEGRA_PIN_ENABLE>;
378 };
379
380 /* Power I2C (On-module) */
381 i2cp {
382 nvidia,pins = "i2cp";
383 nvidia,function = "i2cp";
384 nvidia,pull = <TEGRA_PIN_PULL_NONE>;
385 nvidia,tristate = <TEGRA_PIN_DISABLE>;
386 };
387
388 /* RESET_OUT */
389 reset-out {
390 nvidia,pins = "ata";
391 nvidia,function = "gmi";
392 nvidia,pull = <TEGRA_PIN_PULL_NONE>;
393 nvidia,tristate = <TEGRA_PIN_DISABLE>;
394 };
395
396 /*
397 * SPI1 (Optional)
398 * Note: spid and spie used for Colibri Address/Data
399 * Bus (GMI)
400 */
401 spi1 {
402 nvidia,pins = "spid", "spie", "spif";
403 nvidia,function = "spi1";
404 nvidia,pull = <TEGRA_PIN_PULL_NONE>;
405 nvidia,tristate = <TEGRA_PIN_ENABLE>;
406 };
407
408 /*
409 * THERMD_ALERT# (On-module), unlatched I2C address pin
410 * of LM95245 temperature sensor therefore requires
411 * disabling for now
412 */
413 lvp0 {
414 nvidia,pins = "lvp0";
415 nvidia,function = "rsvd3";
416 nvidia,tristate = <TEGRA_PIN_ENABLE>;
417 };
418 };
419 };
420
421 tegra_ac97: ac97@70002000 {
422 status = "okay";
423 nvidia,codec-reset-gpio =
424 <&gpio TEGRA_GPIO(V, 0) GPIO_ACTIVE_HIGH>;
425 nvidia,codec-sync-gpio =
426 <&gpio TEGRA_GPIO(P, 0) GPIO_ACTIVE_HIGH>;
427 };
428
429 serial@70006040 {
430 compatible = "nvidia,tegra20-hsuart";
431 /delete-property/ reg-shift;
432 };
433
434 serial@70006300 {
435 compatible = "nvidia,tegra20-hsuart";
436 /delete-property/ reg-shift;
437 };
438
439 nand-controller@70008000 {
440 status = "okay";
441
442 nand@0 {
443 reg = <0>;
444 #address-cells = <1>;
445 #size-cells = <1>;
446 nand-bus-width = <8>;
447 nand-on-flash-bbt;
448 nand-ecc-algo = "bch";
449 nand-is-boot-medium;
450 nand-ecc-maximize;
451 wp-gpios = <&gpio TEGRA_GPIO(S, 0) GPIO_ACTIVE_LOW>;
452 };
453 };
454
455 /*
456 * GEN1_I2C: I2C_SDA/SCL on SODIMM pin 194/196 (e.g. RTC on carrier
457 * board)
458 */
459 i2c@7000c000 {
460 clock-frequency = <400000>;
461 };
462
463 /* DDC_SCL/SDA on X3 pin 15/16 (e.g. display EDID) */
464 hdmi_ddc: i2c@7000c400 {
465 clock-frequency = <10000>;
466 };
467
468 /* GEN2_I2C: unused */
469
470 /* CAM/GEN3_I2C: used as EXT_IO1/2 GPIOs on SODIMM pin 133/127 */
471
472 /* PWR_I2C: power I2C to PMIC and temperature sensor (On-module) */
473 i2c@7000d000 {
474 status = "okay";
475 clock-frequency = <100000>;
476
477 pmic@34 {
478 compatible = "ti,tps6586x";
479 reg = <0x34>;
480 interrupts = <GIC_SPI 86 IRQ_TYPE_LEVEL_HIGH>;
481 ti,system-power-controller;
482 #gpio-cells = <2>;
483 gpio-controller;
484 sys-supply = <®_module_3v3>;
485 vin-sm0-supply = <®_3v3_vsys>;
486 vin-sm1-supply = <®_3v3_vsys>;
487 vin-sm2-supply = <®_3v3_vsys>;
488 vinldo01-supply = <®_1v8_vdd_ddr2>;
489 vinldo23-supply = <®_module_3v3>;
490 vinldo4-supply = <®_module_3v3>;
491 vinldo678-supply = <®_module_3v3>;
492 vinldo9-supply = <®_module_3v3>;
493
494 regulators {
495 reg_3v3_vsys: sys {
496 regulator-name = "VSYS_3.3V";
497 regulator-always-on;
498 };
499
500 vdd_core: sm0 {
501 regulator-name = "VDD_CORE_1.2V";
502 regulator-min-microvolt = <1200000>;
503 regulator-max-microvolt = <1200000>;
504 regulator-always-on;
505 };
506
507 sm1 {
508 regulator-name = "VDD_CPU_1.0V";
509 regulator-min-microvolt = <1000000>;
510 regulator-max-microvolt = <1000000>;
511 regulator-always-on;
512 };
513
514 reg_1v8_vdd_ddr2: sm2 {
515 regulator-name = "VDD_DDR2_1.8V";
516 regulator-min-microvolt = <1800000>;
517 regulator-max-microvolt = <1800000>;
518 regulator-always-on;
519 };
520
521 /* LDO0 is not connected to anything */
522
523 /*
524 * +3.3V_ENABLE_N switching via FET:
525 * AVDD_AUDIO_S and +3.3V
526 * see also +3.3V fixed supply
527 */
528 ldo1 {
529 regulator-name = "AVDD_PLL_1.1V";
530 regulator-min-microvolt = <1100000>;
531 regulator-max-microvolt = <1100000>;
532 regulator-always-on;
533 };
534
535 ldo2 {
536 regulator-name = "VDD_RTC_1.2V";
537 regulator-min-microvolt = <1200000>;
538 regulator-max-microvolt = <1200000>;
539 };
540
541 /* LDO3 is not connected to anything */
542
543 ldo4 {
544 regulator-name = "VDDIO_SYS_1.8V";
545 regulator-min-microvolt = <1800000>;
546 regulator-max-microvolt = <1800000>;
547 regulator-always-on;
548 };
549
550 /* Switched via FET from regular +3.3V */
551 ldo5 {
552 regulator-name = "+3.3V_USB";
553 regulator-min-microvolt = <3300000>;
554 regulator-max-microvolt = <3300000>;
555 regulator-always-on;
556 };
557
558 ldo6 {
559 regulator-name = "AVDD_VDAC_2.85V";
560 regulator-min-microvolt = <2850000>;
561 regulator-max-microvolt = <2850000>;
562 };
563
564 reg_3v3_avdd_hdmi: ldo7 {
565 regulator-name = "AVDD_HDMI_3.3V";
566 regulator-min-microvolt = <3300000>;
567 regulator-max-microvolt = <3300000>;
568 };
569
570 reg_1v8_avdd_hdmi_pll: ldo8 {
571 regulator-name = "AVDD_HDMI_PLL_1.8V";
572 regulator-min-microvolt = <1800000>;
573 regulator-max-microvolt = <1800000>;
574 };
575
576 ldo9 {
577 regulator-name = "VDDIO_RX_DDR_2.85V";
578 regulator-min-microvolt = <2850000>;
579 regulator-max-microvolt = <2850000>;
580 regulator-always-on;
581 };
582
583 ldo_rtc {
584 regulator-name = "VCC_BATT";
585 regulator-min-microvolt = <3300000>;
586 regulator-max-microvolt = <3300000>;
587 regulator-always-on;
588 };
589 };
590 };
591
592 /* LM95245 temperature sensor */
593 temp-sensor@4c {
594 compatible = "national,lm95245";
595 reg = <0x4c>;
596 };
597 };
598
599 pmc@7000e400 {
600 nvidia,suspend-mode = <1>;
601 nvidia,cpu-pwr-good-time = <5000>;
602 nvidia,cpu-pwr-off-time = <5000>;
603 nvidia,core-pwr-good-time = <3845 3845>;
604 nvidia,core-pwr-off-time = <3875>;
605 nvidia,sys-clock-req-active-high;
606 core-supply = <&vdd_core>;
607
608 /* Set SLEEP MODE bit in SUPPLYENE register of TPS658643 PMIC */
609 i2c-thermtrip {
610 nvidia,i2c-controller-id = <3>;
611 nvidia,bus-addr = <0x34>;
612 nvidia,reg-addr = <0x14>;
613 nvidia,reg-data = <0x8>;
614 };
615 };
616
617 memory-controller@7000f400 {
618 emc-table@83250 {
619 reg = <83250>;
620 compatible = "nvidia,tegra20-emc-table";
621 clock-frequency = <83250>;
622 nvidia,emc-registers = <0x00000005 0x00000011
623 0x00000004 0x00000002 0x00000004 0x00000004
624 0x00000001 0x0000000a 0x00000002 0x00000002
625 0x00000001 0x00000001 0x00000003 0x00000004
626 0x00000003 0x00000009 0x0000000c 0x0000025f
627 0x00000000 0x00000003 0x00000003 0x00000002
628 0x00000002 0x00000001 0x00000008 0x000000c8
629 0x00000003 0x00000005 0x00000003 0x0000000c
630 0x00000002 0x00000000 0x00000000 0x00000002
631 0x00000000 0x00000000 0x00000083 0x00520006
632 0x00000010 0x00000008 0x00000000 0x00000000
633 0x00000000 0x00000000 0x00000000 0x00000000>;
634 };
635 emc-table@133200 {
636 reg = <133200>;
637 compatible = "nvidia,tegra20-emc-table";
638 clock-frequency = <133200>;
639 nvidia,emc-registers = <0x00000008 0x00000019
640 0x00000006 0x00000002 0x00000004 0x00000004
641 0x00000001 0x0000000a 0x00000002 0x00000002
642 0x00000002 0x00000001 0x00000003 0x00000004
643 0x00000003 0x00000009 0x0000000c 0x0000039f
644 0x00000000 0x00000003 0x00000003 0x00000002
645 0x00000002 0x00000001 0x00000008 0x000000c8
646 0x00000003 0x00000007 0x00000003 0x0000000c
647 0x00000002 0x00000000 0x00000000 0x00000002
648 0x00000000 0x00000000 0x00000083 0x00510006
649 0x00000010 0x00000008 0x00000000 0x00000000
650 0x00000000 0x00000000 0x00000000 0x00000000>;
651 };
652 emc-table@166500 {
653 reg = <166500>;
654 compatible = "nvidia,tegra20-emc-table";
655 clock-frequency = <166500>;
656 nvidia,emc-registers = <0x0000000a 0x00000021
657 0x00000008 0x00000003 0x00000004 0x00000004
658 0x00000002 0x0000000a 0x00000003 0x00000003
659 0x00000002 0x00000001 0x00000003 0x00000004
660 0x00000003 0x00000009 0x0000000c 0x000004df
661 0x00000000 0x00000003 0x00000003 0x00000003
662 0x00000003 0x00000001 0x00000009 0x000000c8
663 0x00000003 0x00000009 0x00000004 0x0000000c
664 0x00000002 0x00000000 0x00000000 0x00000002
665 0x00000000 0x00000000 0x00000083 0x004f0006
666 0x00000010 0x00000008 0x00000000 0x00000000
667 0x00000000 0x00000000 0x00000000 0x00000000>;
668 };
669 emc-table@333000 {
670 reg = <333000>;
671 compatible = "nvidia,tegra20-emc-table";
672 clock-frequency = <333000>;
673 nvidia,emc-registers = <0x00000014 0x00000041
674 0x0000000f 0x00000005 0x00000004 0x00000005
675 0x00000003 0x0000000a 0x00000005 0x00000005
676 0x00000004 0x00000001 0x00000003 0x00000004
677 0x00000003 0x00000009 0x0000000c 0x000009ff
678 0x00000000 0x00000003 0x00000003 0x00000005
679 0x00000005 0x00000001 0x0000000e 0x000000c8
680 0x00000003 0x00000011 0x00000006 0x0000000c
681 0x00000002 0x00000000 0x00000000 0x00000002
682 0x00000000 0x00000000 0x00000083 0x00380006
683 0x00000010 0x00000008 0x00000000 0x00000000
684 0x00000000 0x00000000 0x00000000 0x00000000>;
685 };
686 };
687
688 /* EHCI instance 1: ULPI PHY -> AX88772B (On-module) */
689 usb@c5004000 {
690 status = "okay";
691 #address-cells = <1>;
692 #size-cells = <0>;
693
694 ethernet@1 {
695 compatible = "usbb95,772b";
696 reg = <1>;
697 local-mac-address = [00 00 00 00 00 00];
698 };
699 };
700
701 usb-phy@c5004000 {
702 status = "okay";
703 nvidia,phy-reset-gpio =
704 <&gpio TEGRA_GPIO(V, 1) GPIO_ACTIVE_LOW>;
705 vbus-supply = <®_lan_v_bus>;
706 };
707
708 clk32k_in: xtal3 {
709 compatible = "fixed-clock";
710 #clock-cells = <0>;
711 clock-frequency = <32768>;
712 };
713
714 reg_lan_v_bus: regulator-lan-v-bus {
715 compatible = "regulator-fixed";
716 regulator-name = "LAN_V_BUS";
717 regulator-min-microvolt = <5000000>;
718 regulator-max-microvolt = <5000000>;
719 enable-active-high;
720 gpio = <&gpio TEGRA_GPIO(BB, 1) GPIO_ACTIVE_HIGH>;
721 };
722
723 reg_module_3v3: regulator-module-3v3 {
724 compatible = "regulator-fixed";
725 regulator-name = "+V3.3";
726 regulator-min-microvolt = <3300000>;
727 regulator-max-microvolt = <3300000>;
728 regulator-always-on;
729 };
730
731 sound {
732 compatible = "nvidia,tegra-audio-wm9712-colibri_t20",
733 "nvidia,tegra-audio-wm9712";
734 nvidia,model = "Toradex Colibri T20";
735 nvidia,audio-routing =
736 "Headphone", "HPOUTL",
737 "Headphone", "HPOUTR",
738 "LineIn", "LINEINL",
739 "LineIn", "LINEINR",
740 "Mic", "MIC1";
741 nvidia,ac97-controller = <&tegra_ac97>;
742 clocks = <&tegra_car TEGRA20_CLK_PLL_A>,
743 <&tegra_car TEGRA20_CLK_PLL_A_OUT0>,
744 <&tegra_car TEGRA20_CLK_CDEV1>;
745 clock-names = "pll_a", "pll_a_out0", "mclk";
746 };
747};
748
749&emc_icc_dvfs_opp_table {
750 /delete-node/ opp-760000000;
751};
752
753&gpio {
754 lan-reset-n-hog {
755 gpio-hog;
756 gpios = <TEGRA_GPIO(V, 4) GPIO_ACTIVE_HIGH>;
757 output-high;
758 line-name = "LAN_RESET#";
759 };
760
761 /* Tri-stating GMI_WR_N on SODIMM pin 99 nPWE */
762 npwe-hog {
763 gpio-hog;
764 gpios = <TEGRA_GPIO(T, 5) GPIO_ACTIVE_HIGH>;
765 output-high;
766 line-name = "Tri-state nPWE";
767 };
768
769 /* Not tri-stating GMI_WR_N on SODIMM pin 93 RDnWR */
770 rdnwr-hog {
771 gpio-hog;
772 gpios = <TEGRA_GPIO(T, 6) GPIO_ACTIVE_HIGH>;
773 output-low;
774 line-name = "Not tri-state RDnWR";
775 };
776};