]> git.proxmox.com Git - mirror_ubuntu-eoan-kernel.git/blob - arch/arm/boot/dts/imx27-phytec-phycore-rdk.dts
Merge remote-tracking branch 'asoc/fix/cs4271' into asoc-linus
[mirror_ubuntu-eoan-kernel.git] / arch / arm / boot / dts / imx27-phytec-phycore-rdk.dts
1 /*
2 * The code contained herein is licensed under the GNU General Public
3 * License. You may obtain a copy of the GNU General Public License
4 * Version 2 or later at the following locations:
5 *
6 * http://www.opensource.org/licenses/gpl-license.html
7 * http://www.gnu.org/copyleft/gpl.html
8 */
9
10 #include "imx27-phytec-phycore-som.dtsi"
11
12 / {
13 model = "Phytec pcm970";
14 compatible = "phytec,imx27-pcm970", "phytec,imx27-pcm038", "fsl,imx27";
15
16 chosen {
17 stdout-path = &uart1;
18 };
19
20 display0: LQ035Q7 {
21 model = "Sharp-LQ035Q7";
22 native-mode = <&timing0>;
23 bits-per-pixel = <16>;
24 fsl,pcr = <0xf00080c0>;
25
26 display-timings {
27 timing0: 240x320 {
28 clock-frequency = <5500000>;
29 hactive = <240>;
30 vactive = <320>;
31 hback-porch = <5>;
32 hsync-len = <7>;
33 hfront-porch = <16>;
34 vback-porch = <7>;
35 vsync-len = <1>;
36 vfront-porch = <9>;
37 pixelclk-active = <1>;
38 hsync-active = <1>;
39 vsync-active = <1>;
40 de-active = <0>;
41 };
42 };
43 };
44
45 regulators {
46 regulator@2 {
47 compatible = "regulator-fixed";
48 pinctrl-names = "default";
49 pinctrl-0 = <&pinctrl_csien>;
50 reg = <2>;
51 regulator-name = "CSI_EN";
52 regulator-min-microvolt = <3300000>;
53 regulator-max-microvolt = <3300000>;
54 gpio = <&gpio2 24 GPIO_ACTIVE_LOW>;
55 regulator-always-on;
56 };
57 };
58
59 usbphy {
60 usbphy2: usbphy@2 {
61 compatible = "usb-nop-xceiv";
62 reg = <2>;
63 vcc-supply = <&reg_5v0>;
64 clocks = <&clks IMX27_CLK_DUMMY>;
65 clock-names = "main_clk";
66 };
67 };
68 };
69
70 &cspi1 {
71 pinctrl-0 = <&pinctrl_cspi1>, <&pinctrl_cspi1cs1>;
72 cs-gpios = <&gpio4 28 GPIO_ACTIVE_HIGH>,
73 <&gpio4 27 GPIO_ACTIVE_LOW>;
74 };
75
76 &fb {
77 pinctrl-names = "default";
78 pinctrl-0 = <&pinctrl_imxfb1>;
79 display = <&display0>;
80 lcd-supply = <&reg_5v0>;
81 fsl,dmacr = <0x00020010>;
82 fsl,lscr1 = <0x00120300>;
83 fsl,lpccr = <0x00a903ff>;
84 status = "okay";
85 };
86
87 &i2c1 {
88 clock-frequency = <400000>;
89 pinctrl-names = "default";
90 pinctrl-0 = <&pinctrl_i2c1>;
91 status = "okay";
92
93 camgpio: pca9536@41 {
94 compatible = "nxp,pca9536";
95 reg = <0x41>;
96 gpio-controller;
97 #gpio-cells = <2>;
98 };
99 };
100
101 &iomuxc {
102 imx27_phycore_rdk {
103 pinctrl_csien: csiengrp {
104 fsl,pins = <
105 MX27_PAD_USB_OC_B__GPIO2_24 0x0
106 >;
107 };
108
109 pinctrl_cspi1cs1: cspi1cs1grp {
110 fsl,pins = <
111 MX27_PAD_CSPI1_SS1__GPIO4_27 0x0
112 >;
113 };
114
115 pinctrl_imxfb1: imxfbgrp {
116 fsl,pins = <
117 MX27_PAD_LD0__LD0 0x0
118 MX27_PAD_LD1__LD1 0x0
119 MX27_PAD_LD2__LD2 0x0
120 MX27_PAD_LD3__LD3 0x0
121 MX27_PAD_LD4__LD4 0x0
122 MX27_PAD_LD5__LD5 0x0
123 MX27_PAD_LD6__LD6 0x0
124 MX27_PAD_LD7__LD7 0x0
125 MX27_PAD_LD8__LD8 0x0
126 MX27_PAD_LD9__LD9 0x0
127 MX27_PAD_LD10__LD10 0x0
128 MX27_PAD_LD11__LD11 0x0
129 MX27_PAD_LD12__LD12 0x0
130 MX27_PAD_LD13__LD13 0x0
131 MX27_PAD_LD14__LD14 0x0
132 MX27_PAD_LD15__LD15 0x0
133 MX27_PAD_LD16__LD16 0x0
134 MX27_PAD_LD17__LD17 0x0
135 MX27_PAD_CLS__CLS 0x0
136 MX27_PAD_CONTRAST__CONTRAST 0x0
137 MX27_PAD_LSCLK__LSCLK 0x0
138 MX27_PAD_OE_ACD__OE_ACD 0x0
139 MX27_PAD_PS__PS 0x0
140 MX27_PAD_REV__REV 0x0
141 MX27_PAD_SPL_SPR__SPL_SPR 0x0
142 MX27_PAD_HSYNC__HSYNC 0x0
143 MX27_PAD_VSYNC__VSYNC 0x0
144 >;
145 };
146
147 pinctrl_i2c1: i2c1grp {
148 /* Add pullup to DATA line */
149 fsl,pins = <
150 MX27_PAD_I2C_DATA__I2C_DATA 0x1
151 MX27_PAD_I2C_CLK__I2C_CLK 0x0
152 >;
153 };
154
155 pinctrl_owire1: owire1grp {
156 fsl,pins = <
157 MX27_PAD_RTCK__OWIRE 0x0
158 >;
159 };
160
161 pinctrl_sdhc2: sdhc2grp {
162 fsl,pins = <
163 MX27_PAD_SD2_CLK__SD2_CLK 0x0
164 MX27_PAD_SD2_CMD__SD2_CMD 0x0
165 MX27_PAD_SD2_D0__SD2_D0 0x0
166 MX27_PAD_SD2_D1__SD2_D1 0x0
167 MX27_PAD_SD2_D2__SD2_D2 0x0
168 MX27_PAD_SD2_D3__SD2_D3 0x0
169 MX27_PAD_SSI3_FS__GPIO3_28 0x0 /* WP */
170 MX27_PAD_SSI3_RXDAT__GPIO3_29 0x0 /* CD */
171 >;
172 };
173
174 pinctrl_uart1: uart1grp {
175 fsl,pins = <
176 MX27_PAD_UART1_TXD__UART1_TXD 0x0
177 MX27_PAD_UART1_RXD__UART1_RXD 0x0
178 MX27_PAD_UART1_CTS__UART1_CTS 0x0
179 MX27_PAD_UART1_RTS__UART1_RTS 0x0
180 >;
181 };
182
183 pinctrl_uart2: uart2grp {
184 fsl,pins = <
185 MX27_PAD_UART2_TXD__UART2_TXD 0x0
186 MX27_PAD_UART2_RXD__UART2_RXD 0x0
187 MX27_PAD_UART2_CTS__UART2_CTS 0x0
188 MX27_PAD_UART2_RTS__UART2_RTS 0x0
189 >;
190 };
191
192 pinctrl_usbh2: usbh2grp {
193 fsl,pins = <
194 MX27_PAD_USBH2_CLK__USBH2_CLK 0x0
195 MX27_PAD_USBH2_DIR__USBH2_DIR 0x0
196 MX27_PAD_USBH2_NXT__USBH2_NXT 0x0
197 MX27_PAD_USBH2_STP__USBH2_STP 0x0
198 MX27_PAD_CSPI2_SCLK__USBH2_DATA0 0x0
199 MX27_PAD_CSPI2_MOSI__USBH2_DATA1 0x0
200 MX27_PAD_CSPI2_MISO__USBH2_DATA2 0x0
201 MX27_PAD_CSPI2_SS1__USBH2_DATA3 0x0
202 MX27_PAD_CSPI2_SS2__USBH2_DATA4 0x0
203 MX27_PAD_CSPI1_SS2__USBH2_DATA5 0x0
204 MX27_PAD_CSPI2_SS0__USBH2_DATA6 0x0
205 MX27_PAD_USBH2_DATA7__USBH2_DATA7 0x0
206 >;
207 };
208
209 pinctrl_weim: weimgrp {
210 fsl,pins = <
211 MX27_PAD_CS4_B__CS4_B 0x0 /* CS4 */
212 MX27_PAD_SD1_D1__GPIO5_19 0x0 /* CAN IRQ */
213 >;
214 };
215 };
216 };
217
218 &owire {
219 pinctrl-names = "default";
220 pinctrl-0 = <&pinctrl_owire1>;
221 status = "okay";
222 };
223
224 &pmicleds {
225 ledr1: led@3 {
226 reg = <3>;
227 label = "system:red1:user";
228 };
229
230 ledg1: led@4 {
231 reg = <4>;
232 label = "system:green1:user";
233 };
234
235 ledb1: led@5 {
236 reg = <5>;
237 label = "system:blue1:user";
238 };
239
240 ledr2: led@6 {
241 reg = <6>;
242 label = "system:red2:user";
243 };
244
245 ledg2: led@7 {
246 reg = <7>;
247 label = "system:green2:user";
248 };
249
250 ledb2: led@8 {
251 reg = <8>;
252 label = "system:blue2:user";
253 };
254
255 ledr3: led@9 {
256 reg = <9>;
257 label = "system:red3:nand";
258 linux,default-trigger = "nand-disk";
259 };
260
261 ledg3: led@10 {
262 reg = <10>;
263 label = "system:green3:live";
264 linux,default-trigger = "heartbeat";
265 };
266
267 ledb3: led@11 {
268 reg = <11>;
269 label = "system:blue3:cpu";
270 linux,default-trigger = "cpu0";
271 };
272 };
273
274 &sdhci2 {
275 pinctrl-names = "default";
276 pinctrl-0 = <&pinctrl_sdhc2>;
277 bus-width = <4>;
278 cd-gpios = <&gpio3 29 GPIO_ACTIVE_HIGH>;
279 wp-gpios = <&gpio3 28 GPIO_ACTIVE_HIGH>;
280 vmmc-supply = <&vmmc1_reg>;
281 status = "okay";
282 };
283
284 &uart1 {
285 uart-has-rtscts;
286 pinctrl-names = "default";
287 pinctrl-0 = <&pinctrl_uart1>;
288 status = "okay";
289 };
290
291 &uart2 {
292 uart-has-rtscts;
293 pinctrl-names = "default";
294 pinctrl-0 = <&pinctrl_uart2>;
295 status = "okay";
296 };
297
298 &usbh2 {
299 pinctrl-names = "default";
300 pinctrl-0 = <&pinctrl_usbh2>;
301 dr_mode = "host";
302 phy_type = "ulpi";
303 vbus-supply = <&reg_5v0>;
304 fsl,usbphy = <&usbphy2>;
305 disable-over-current;
306 status = "okay";
307 };
308
309 &weim {
310 pinctrl-names = "default";
311 pinctrl-0 = <&pinctrl_weim>;
312
313 can@4,0 {
314 compatible = "nxp,sja1000";
315 reg = <4 0x00000000 0x00000100>;
316 interrupt-parent = <&gpio5>;
317 interrupts = <19 IRQ_TYPE_EDGE_FALLING>;
318 nxp,external-clock-frequency = <16000000>;
319 nxp,tx-output-config = <0x16>;
320 nxp,no-comparator-bypass;
321 fsl,weim-cs-timing = <0x0000dcf6 0x444a0301 0x44443302>;
322 };
323 };