Merge remote-tracking branches 'asoc/topic/inntel', 'asoc/topic/input', 'asoc/topic...
[sfrench/cifs-2.6.git] / arch / arm / boot / dts / am335x-boneblack.dts
1 /*
2  * Copyright (C) 2012 Texas Instruments Incorporated - http://www.ti.com/
3  *
4  * This program is free software; you can redistribute it and/or modify
5  * it under the terms of the GNU General Public License version 2 as
6  * published by the Free Software Foundation.
7  */
8 /dts-v1/;
9
10 #include "am33xx.dtsi"
11 #include "am335x-bone-common.dtsi"
12 #include <dt-bindings/display/tda998x.h>
13
14 / {
15         model = "TI AM335x BeagleBone Black";
16         compatible = "ti,am335x-bone-black", "ti,am335x-bone", "ti,am33xx";
17 };
18
19 &ldo3_reg {
20         regulator-min-microvolt = <1800000>;
21         regulator-max-microvolt = <1800000>;
22         regulator-always-on;
23 };
24
25 &mmc1 {
26         vmmc-supply = <&vmmcsd_fixed>;
27 };
28
29 &mmc2 {
30         vmmc-supply = <&vmmcsd_fixed>;
31         pinctrl-names = "default";
32         pinctrl-0 = <&emmc_pins>;
33         bus-width = <8>;
34         status = "okay";
35 };
36
37 &am33xx_pinmux {
38         nxp_hdmi_bonelt_pins: nxp_hdmi_bonelt_pins {
39                 pinctrl-single,pins = <
40                         AM33XX_IOPAD(0x9b0, PIN_OUTPUT_PULLDOWN | MUX_MODE3)    /* xdma_event_intr0 */
41                         AM33XX_IOPAD(0x8a0, PIN_OUTPUT | MUX_MODE0)             /* lcd_data0.lcd_data0 */
42                         AM33XX_IOPAD(0x8a4, PIN_OUTPUT | MUX_MODE0)             /* lcd_data1.lcd_data1 */
43                         AM33XX_IOPAD(0x8a8, PIN_OUTPUT | MUX_MODE0)             /* lcd_data2.lcd_data2 */
44                         AM33XX_IOPAD(0x8ac, PIN_OUTPUT | MUX_MODE0)             /* lcd_data3.lcd_data3 */
45                         AM33XX_IOPAD(0x8b0, PIN_OUTPUT | MUX_MODE0)             /* lcd_data4.lcd_data4 */
46                         AM33XX_IOPAD(0x8b4, PIN_OUTPUT | MUX_MODE0)             /* lcd_data5.lcd_data5 */
47                         AM33XX_IOPAD(0x8b8, PIN_OUTPUT | MUX_MODE0)             /* lcd_data6.lcd_data6 */
48                         AM33XX_IOPAD(0x8bc, PIN_OUTPUT | MUX_MODE0)             /* lcd_data7.lcd_data7 */
49                         AM33XX_IOPAD(0x8c0, PIN_OUTPUT | MUX_MODE0)             /* lcd_data8.lcd_data8 */
50                         AM33XX_IOPAD(0x8c4, PIN_OUTPUT | MUX_MODE0)             /* lcd_data9.lcd_data9 */
51                         AM33XX_IOPAD(0x8c8, PIN_OUTPUT | MUX_MODE0)             /* lcd_data10.lcd_data10 */
52                         AM33XX_IOPAD(0x8cc, PIN_OUTPUT | MUX_MODE0)             /* lcd_data11.lcd_data11 */
53                         AM33XX_IOPAD(0x8d0, PIN_OUTPUT | MUX_MODE0)             /* lcd_data12.lcd_data12 */
54                         AM33XX_IOPAD(0x8d4, PIN_OUTPUT | MUX_MODE0)             /* lcd_data13.lcd_data13 */
55                         AM33XX_IOPAD(0x8d8, PIN_OUTPUT | MUX_MODE0)             /* lcd_data14.lcd_data14 */
56                         AM33XX_IOPAD(0x8dc, PIN_OUTPUT | MUX_MODE0)             /* lcd_data15.lcd_data15 */
57                         AM33XX_IOPAD(0x8e0, PIN_OUTPUT_PULLDOWN | MUX_MODE0)    /* lcd_vsync.lcd_vsync */
58                         AM33XX_IOPAD(0x8e4, PIN_OUTPUT_PULLDOWN | MUX_MODE0)    /* lcd_hsync.lcd_hsync */
59                         AM33XX_IOPAD(0x8e8, PIN_OUTPUT_PULLDOWN | MUX_MODE0)    /* lcd_pclk.lcd_pclk */
60                         AM33XX_IOPAD(0x8ec, PIN_OUTPUT_PULLDOWN | MUX_MODE0)    /* lcd_ac_bias_en.lcd_ac_bias_en */
61                 >;
62         };
63         nxp_hdmi_bonelt_off_pins: nxp_hdmi_bonelt_off_pins {
64                 pinctrl-single,pins = <
65                         AM33XX_IOPAD(0x9b0, PIN_OUTPUT_PULLDOWN | MUX_MODE3)    /* xdma_event_intr0 */
66                 >;
67         };
68
69         mcasp0_pins: mcasp0_pins {
70                 pinctrl-single,pins = <
71                         AM33XX_IOPAD(0x9ac, PIN_INPUT_PULLUP | MUX_MODE0) /* mcasp0_ahcklx.mcasp0_ahclkx */
72                         AM33XX_IOPAD(0x99c, PIN_OUTPUT_PULLDOWN | MUX_MODE2) /* mcasp0_ahclkr.mcasp0_axr2*/
73                         AM33XX_IOPAD(0x994, PIN_OUTPUT_PULLUP | MUX_MODE0) /* mcasp0_fsx.mcasp0_fsx */
74                         AM33XX_IOPAD(0x990, PIN_OUTPUT_PULLDOWN | MUX_MODE0) /* mcasp0_aclkx.mcasp0_aclkx */
75                         AM33XX_IOPAD(0x86c, PIN_OUTPUT_PULLDOWN | MUX_MODE7) /* gpmc_a11.GPIO1_27 */
76                 >;
77         };
78 };
79
80 &lcdc {
81         status = "okay";
82         port {
83                 lcdc_0: endpoint@0 {
84                         remote-endpoint = <&hdmi_0>;
85                 };
86         };
87 };
88
89 &i2c0 {
90         tda19988: tda19988 {
91                 compatible = "nxp,tda998x";
92                 reg = <0x70>;
93
94                 pinctrl-names = "default", "off";
95                 pinctrl-0 = <&nxp_hdmi_bonelt_pins>;
96                 pinctrl-1 = <&nxp_hdmi_bonelt_off_pins>;
97
98                 #sound-dai-cells = <0>;
99                 audio-ports = < TDA998x_I2S     0x03>;
100
101                 ports {
102                         port@0 {
103                                 hdmi_0: endpoint@0 {
104                                         remote-endpoint = <&lcdc_0>;
105                                 };
106                         };
107                 };
108         };
109 };
110
111 &rtc {
112         system-power-controller;
113 };
114
115 &mcasp0 {
116         #sound-dai-cells = <0>;
117         pinctrl-names = "default";
118         pinctrl-0 = <&mcasp0_pins>;
119         status = "okay";
120         op-mode = <0>;  /* MCASP_IIS_MODE */
121         tdm-slots = <2>;
122         serial-dir = <  /* 0: INACTIVE, 1: TX, 2: RX */
123                         0 0 1 0
124                 >;
125         tx-num-evt = <32>;
126         rx-num-evt = <32>;
127 };
128
129 / {
130         clk_mcasp0_fixed: clk_mcasp0_fixed {
131                 #clock-cells = <0>;
132                 compatible = "fixed-clock";
133                 clock-frequency = <24576000>;
134         };
135
136         clk_mcasp0: clk_mcasp0 {
137                 #clock-cells = <0>;
138                 compatible = "gpio-gate-clock";
139                 clocks = <&clk_mcasp0_fixed>;
140                 enable-gpios = <&gpio1 27 0>; /* BeagleBone Black Clk enable on GPIO1_27 */
141         };
142
143         sound {
144                 compatible = "simple-audio-card";
145                 simple-audio-card,name = "TI BeagleBone Black";
146                 simple-audio-card,format = "i2s";
147                 simple-audio-card,bitclock-master = <&dailink0_master>;
148                 simple-audio-card,frame-master = <&dailink0_master>;
149
150                 dailink0_master: simple-audio-card,cpu {
151                         sound-dai = <&mcasp0>;
152                         clocks = <&clk_mcasp0>;
153                 };
154
155                 simple-audio-card,codec {
156                         sound-dai = <&tda19988>;
157                 };
158         };
159 };