blob: 6bbb1fee08689182dca4e113e9e37038c9a7b055 [file] [log] [blame]
Koen Kooi2ba35492013-09-09 16:29:21 +02001/*
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"
Jyri Sarhadf0bd1e2016-08-09 22:00:06 +030012#include <dt-bindings/display/tda998x.h>
Koen Kooi2ba35492013-09-09 16:29:21 +020013
Nishanth Menon9a15fff2014-09-03 11:03:10 -050014/ {
15 model = "TI AM335x BeagleBone Black";
16 compatible = "ti,am335x-bone-black", "ti,am335x-bone", "ti,am33xx";
17};
18
Koen Kooi2ba35492013-09-09 16:29:21 +020019&ldo3_reg {
20 regulator-min-microvolt = <1800000>;
21 regulator-max-microvolt = <1800000>;
22 regulator-always-on;
23};
Koen Kooi1aac4a92013-09-12 20:35:33 +020024
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";
Koen Kooi1aac4a92013-09-12 20:35:33 +020035};
Darren Etheridge559a08e2013-09-20 15:01:42 -050036
37&am33xx_pinmux {
38 nxp_hdmi_bonelt_pins: nxp_hdmi_bonelt_pins {
39 pinctrl-single,pins = <
Andrew F. Davisdf10ead2015-11-13 10:47:27 -060040 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 */
Darren Etheridge559a08e2013-09-20 15:01:42 -050061 >;
62 };
63 nxp_hdmi_bonelt_off_pins: nxp_hdmi_bonelt_off_pins {
64 pinctrl-single,pins = <
Andrew F. Davisdf10ead2015-11-13 10:47:27 -060065 AM33XX_IOPAD(0x9b0, PIN_OUTPUT_PULLDOWN | MUX_MODE3) /* xdma_event_intr0 */
Darren Etheridge559a08e2013-09-20 15:01:42 -050066 >;
67 };
Jyri Sarhadf0bd1e2016-08-09 22:00:06 +030068
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 };
Darren Etheridge559a08e2013-09-20 15:01:42 -050078};
79
80&lcdc {
81 status = "okay";
Jyri Sarha34c900a2015-05-08 14:27:19 +030082 port {
83 lcdc_0: endpoint@0 {
84 remote-endpoint = <&hdmi_0>;
85 };
86 };
Darren Etheridge559a08e2013-09-20 15:01:42 -050087};
88
Jyri Sarha34c900a2015-05-08 14:27:19 +030089&i2c0 {
Jyri Sarhadf0bd1e2016-08-09 22:00:06 +030090 tda19988: tda19988 {
Jyri Sarha34c900a2015-05-08 14:27:19 +030091 compatible = "nxp,tda998x";
92 reg = <0x70>;
Jyri Sarhadf0bd1e2016-08-09 22:00:06 +030093
Darren Etheridge559a08e2013-09-20 15:01:42 -050094 pinctrl-names = "default", "off";
95 pinctrl-0 = <&nxp_hdmi_bonelt_pins>;
96 pinctrl-1 = <&nxp_hdmi_bonelt_off_pins>;
Jyri Sarha34c900a2015-05-08 14:27:19 +030097
Jyri Sarhadf0bd1e2016-08-09 22:00:06 +030098 #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 };
Jyri Sarha34c900a2015-05-08 14:27:19 +0300106 };
107 };
Darren Etheridge559a08e2013-09-20 15:01:42 -0500108 };
109};
Johan Hovold672e2b12014-12-10 15:53:29 -0800110
111&rtc {
Johan Hovold094d3ee2014-12-10 15:54:14 -0800112 system-power-controller;
Johan Hovold672e2b12014-12-10 15:53:29 -0800113};
Jyri Sarhadf0bd1e2016-08-09 22:00:06 +0300114
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};