xref: /OK3568_Linux_fs/kernel/arch/arm/boot/dts/imx51-ts4800.dts (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun/*
2*4882a593Smuzhiyun * Copyright 2015 Savoir-faire Linux
3*4882a593Smuzhiyun *
4*4882a593Smuzhiyun * This device tree is based on imx51-babbage.dts
5*4882a593Smuzhiyun *
6*4882a593Smuzhiyun * Licensed under the X11 license or the GPL v2 (or later)
7*4882a593Smuzhiyun */
8*4882a593Smuzhiyun
9*4882a593Smuzhiyun/dts-v1/;
10*4882a593Smuzhiyun#include "imx51.dtsi"
11*4882a593Smuzhiyun
12*4882a593Smuzhiyun/ {
13*4882a593Smuzhiyun	model = "Technologic Systems TS-4800";
14*4882a593Smuzhiyun	compatible = "technologic,imx51-ts4800", "fsl,imx51";
15*4882a593Smuzhiyun
16*4882a593Smuzhiyun	chosen {
17*4882a593Smuzhiyun		stdout-path = &uart1;
18*4882a593Smuzhiyun	};
19*4882a593Smuzhiyun
20*4882a593Smuzhiyun	memory@90000000 {
21*4882a593Smuzhiyun		device_type = "memory";
22*4882a593Smuzhiyun		reg = <0x90000000 0x10000000>;
23*4882a593Smuzhiyun	};
24*4882a593Smuzhiyun
25*4882a593Smuzhiyun	clocks {
26*4882a593Smuzhiyun		ckih1 {
27*4882a593Smuzhiyun			clock-frequency = <22579200>;
28*4882a593Smuzhiyun		};
29*4882a593Smuzhiyun
30*4882a593Smuzhiyun		ckih2 {
31*4882a593Smuzhiyun			clock-frequency = <24576000>;
32*4882a593Smuzhiyun		};
33*4882a593Smuzhiyun	};
34*4882a593Smuzhiyun
35*4882a593Smuzhiyun	backlight_reg: regulator-backlight {
36*4882a593Smuzhiyun		compatible = "regulator-fixed";
37*4882a593Smuzhiyun		pinctrl-names = "default";
38*4882a593Smuzhiyun		pinctrl-0 = <&pinctrl_enable_lcd>;
39*4882a593Smuzhiyun		regulator-name = "enable_lcd_reg";
40*4882a593Smuzhiyun		regulator-min-microvolt = <3300000>;
41*4882a593Smuzhiyun		regulator-max-microvolt = <3300000>;
42*4882a593Smuzhiyun		gpio = <&gpio4 9 GPIO_ACTIVE_HIGH>;
43*4882a593Smuzhiyun		enable-active-high;
44*4882a593Smuzhiyun	};
45*4882a593Smuzhiyun
46*4882a593Smuzhiyun	backlight: backlight {
47*4882a593Smuzhiyun		compatible = "pwm-backlight";
48*4882a593Smuzhiyun		pwms = <&pwm1 0 78770>;
49*4882a593Smuzhiyun		brightness-levels = <0 150 200 255>;
50*4882a593Smuzhiyun		default-brightness-level = <1>;
51*4882a593Smuzhiyun		power-supply = <&backlight_reg>;
52*4882a593Smuzhiyun	};
53*4882a593Smuzhiyun
54*4882a593Smuzhiyun	display1: disp1 {
55*4882a593Smuzhiyun		compatible = "fsl,imx-parallel-display";
56*4882a593Smuzhiyun		interface-pix-fmt = "rgb24";
57*4882a593Smuzhiyun		pinctrl-names = "default";
58*4882a593Smuzhiyun		pinctrl-0 = <&pinctrl_lcd>;
59*4882a593Smuzhiyun
60*4882a593Smuzhiyun		display-timings {
61*4882a593Smuzhiyun			800x480p60 {
62*4882a593Smuzhiyun				native-mode;
63*4882a593Smuzhiyun				clock-frequency = <30066000>;
64*4882a593Smuzhiyun				hactive = <800>;
65*4882a593Smuzhiyun				vactive = <480>;
66*4882a593Smuzhiyun				hfront-porch = <50>;
67*4882a593Smuzhiyun				hback-porch = <70>;
68*4882a593Smuzhiyun				hsync-len = <50>;
69*4882a593Smuzhiyun				vback-porch = <0>;
70*4882a593Smuzhiyun				vfront-porch = <0>;
71*4882a593Smuzhiyun				vsync-len = <50>;
72*4882a593Smuzhiyun			};
73*4882a593Smuzhiyun		};
74*4882a593Smuzhiyun
75*4882a593Smuzhiyun		port {
76*4882a593Smuzhiyun			display0_in: endpoint {
77*4882a593Smuzhiyun				remote-endpoint = <&ipu_di0_disp1>;
78*4882a593Smuzhiyun			};
79*4882a593Smuzhiyun		};
80*4882a593Smuzhiyun	};
81*4882a593Smuzhiyun};
82*4882a593Smuzhiyun
83*4882a593Smuzhiyun&esdhc1 {
84*4882a593Smuzhiyun	pinctrl-names = "default";
85*4882a593Smuzhiyun	pinctrl-0 = <&pinctrl_esdhc1>;
86*4882a593Smuzhiyun	cd-gpios = <&gpio1 0 GPIO_ACTIVE_LOW>;
87*4882a593Smuzhiyun	wp-gpios = <&gpio1 1 GPIO_ACTIVE_HIGH>;
88*4882a593Smuzhiyun	status = "okay";
89*4882a593Smuzhiyun};
90*4882a593Smuzhiyun
91*4882a593Smuzhiyun&fec {
92*4882a593Smuzhiyun	pinctrl-names = "default";
93*4882a593Smuzhiyun	pinctrl-0 = <&pinctrl_fec>;
94*4882a593Smuzhiyun	phy-mode = "mii";
95*4882a593Smuzhiyun	phy-reset-gpios = <&gpio2 14 GPIO_ACTIVE_LOW>;
96*4882a593Smuzhiyun	phy-reset-duration = <1>;
97*4882a593Smuzhiyun	status = "okay";
98*4882a593Smuzhiyun};
99*4882a593Smuzhiyun
100*4882a593Smuzhiyun&i2c2 {
101*4882a593Smuzhiyun	pinctrl-names = "default";
102*4882a593Smuzhiyun	pinctrl-0 = <&pinctrl_i2c2>;
103*4882a593Smuzhiyun	status = "okay";
104*4882a593Smuzhiyun
105*4882a593Smuzhiyun	rtc: m41t00@68 {
106*4882a593Smuzhiyun		compatible = "st,m41t00";
107*4882a593Smuzhiyun		reg = <0x68>;
108*4882a593Smuzhiyun	};
109*4882a593Smuzhiyun};
110*4882a593Smuzhiyun
111*4882a593Smuzhiyun&ipu_di0_disp1 {
112*4882a593Smuzhiyun	remote-endpoint = <&display0_in>;
113*4882a593Smuzhiyun};
114*4882a593Smuzhiyun
115*4882a593Smuzhiyun&pwm1 {
116*4882a593Smuzhiyun	#pwm-cells = <2>;
117*4882a593Smuzhiyun	pinctrl-names = "default";
118*4882a593Smuzhiyun	pinctrl-0 = <&pinctrl_pwm_backlight>;
119*4882a593Smuzhiyun	status = "okay";
120*4882a593Smuzhiyun};
121*4882a593Smuzhiyun
122*4882a593Smuzhiyun&uart1 {
123*4882a593Smuzhiyun	pinctrl-names = "default";
124*4882a593Smuzhiyun	pinctrl-0 = <&pinctrl_uart1>;
125*4882a593Smuzhiyun	status = "okay";
126*4882a593Smuzhiyun};
127*4882a593Smuzhiyun
128*4882a593Smuzhiyun&uart2 {
129*4882a593Smuzhiyun	pinctrl-names = "default";
130*4882a593Smuzhiyun	pinctrl-0 = <&pinctrl_uart2>;
131*4882a593Smuzhiyun	status = "okay";
132*4882a593Smuzhiyun};
133*4882a593Smuzhiyun
134*4882a593Smuzhiyun&uart3 {
135*4882a593Smuzhiyun	pinctrl-names = "default";
136*4882a593Smuzhiyun	pinctrl-0 = <&pinctrl_uart3>;
137*4882a593Smuzhiyun	status = "okay";
138*4882a593Smuzhiyun};
139*4882a593Smuzhiyun
140*4882a593Smuzhiyun&weim {
141*4882a593Smuzhiyun	pinctrl-names = "default";
142*4882a593Smuzhiyun	pinctrl-0 = <&pinctrl_weim>;
143*4882a593Smuzhiyun	status = "okay";
144*4882a593Smuzhiyun
145*4882a593Smuzhiyun	fpga@0 {
146*4882a593Smuzhiyun		compatible = "simple-bus";
147*4882a593Smuzhiyun		fsl,weim-cs-timing = <0x0061008F 0x00000002 0x1c022000
148*4882a593Smuzhiyun				      0x00000000 0x1c092480 0x00000000>;
149*4882a593Smuzhiyun		reg = <0 0x0000000 0x1d000>;
150*4882a593Smuzhiyun		#address-cells = <1>;
151*4882a593Smuzhiyun		#size-cells = <1>;
152*4882a593Smuzhiyun		ranges = <0 0 0 0x1d000>;
153*4882a593Smuzhiyun
154*4882a593Smuzhiyun		syscon: syscon@10000 {
155*4882a593Smuzhiyun			compatible = "syscon", "simple-mfd";
156*4882a593Smuzhiyun			reg = <0x10000 0x3d>;
157*4882a593Smuzhiyun			reg-io-width = <2>;
158*4882a593Smuzhiyun
159*4882a593Smuzhiyun			wdt {
160*4882a593Smuzhiyun				compatible = "technologic,ts4800-wdt";
161*4882a593Smuzhiyun				syscon = <&syscon 0xe>;
162*4882a593Smuzhiyun			};
163*4882a593Smuzhiyun		};
164*4882a593Smuzhiyun
165*4882a593Smuzhiyun		touchscreen@12000 {
166*4882a593Smuzhiyun			compatible = "technologic,ts4800-ts";
167*4882a593Smuzhiyun			reg = <0x12000 0x1000>;
168*4882a593Smuzhiyun			syscon = <&syscon 0x10 6>;
169*4882a593Smuzhiyun		};
170*4882a593Smuzhiyun
171*4882a593Smuzhiyun		fpga_irqc: fpga-irqc@15000 {
172*4882a593Smuzhiyun			compatible = "technologic,ts4800-irqc";
173*4882a593Smuzhiyun			reg = <0x15000 0x1000>;
174*4882a593Smuzhiyun			pinctrl-names = "default";
175*4882a593Smuzhiyun			pinctrl-0 = <&pinctrl_interrupt_fpga>;
176*4882a593Smuzhiyun			interrupt-parent = <&gpio2>;
177*4882a593Smuzhiyun			interrupts= <9 IRQ_TYPE_LEVEL_HIGH>;
178*4882a593Smuzhiyun			interrupt-controller;
179*4882a593Smuzhiyun			#interrupt-cells = <1>;
180*4882a593Smuzhiyun		};
181*4882a593Smuzhiyun
182*4882a593Smuzhiyun		can@1a000 {
183*4882a593Smuzhiyun			compatible = "technologic,sja1000";
184*4882a593Smuzhiyun			reg = <0x1a000 0x100>;
185*4882a593Smuzhiyun			interrupt-parent = <&fpga_irqc>;
186*4882a593Smuzhiyun			interrupts = <1>;
187*4882a593Smuzhiyun			reg-io-width = <2>;
188*4882a593Smuzhiyun			nxp,tx-output-config = <0x06>;
189*4882a593Smuzhiyun			nxp,external-clock-frequency = <24000000>;
190*4882a593Smuzhiyun		};
191*4882a593Smuzhiyun	};
192*4882a593Smuzhiyun};
193*4882a593Smuzhiyun
194*4882a593Smuzhiyun&iomuxc {
195*4882a593Smuzhiyun	pinctrl_ecspi1: ecspi1grp {
196*4882a593Smuzhiyun		fsl,pins = <
197*4882a593Smuzhiyun			MX51_PAD_CSPI1_MISO__ECSPI1_MISO	0x185
198*4882a593Smuzhiyun			MX51_PAD_CSPI1_MOSI__ECSPI1_MOSI	0x185
199*4882a593Smuzhiyun			MX51_PAD_CSPI1_SCLK__ECSPI1_SCLK	0x185
200*4882a593Smuzhiyun			MX51_PAD_CSPI1_SS0__GPIO4_24		0x85 /* CS0 */
201*4882a593Smuzhiyun		>;
202*4882a593Smuzhiyun	};
203*4882a593Smuzhiyun
204*4882a593Smuzhiyun	pinctrl_enable_lcd: enablelcdgrp {
205*4882a593Smuzhiyun		fsl,pins = <
206*4882a593Smuzhiyun			MX51_PAD_CSI2_D12__GPIO4_9		0x1c5
207*4882a593Smuzhiyun		>;
208*4882a593Smuzhiyun	};
209*4882a593Smuzhiyun
210*4882a593Smuzhiyun	pinctrl_esdhc1: esdhc1grp {
211*4882a593Smuzhiyun		fsl,pins = <
212*4882a593Smuzhiyun			MX51_PAD_SD1_CMD__SD1_CMD		0x400020d5
213*4882a593Smuzhiyun			MX51_PAD_SD1_CLK__SD1_CLK		0x20d5
214*4882a593Smuzhiyun			MX51_PAD_SD1_DATA0__SD1_DATA0		0x20d5
215*4882a593Smuzhiyun			MX51_PAD_SD1_DATA1__SD1_DATA1		0x20d5
216*4882a593Smuzhiyun			MX51_PAD_SD1_DATA2__SD1_DATA2		0x20d5
217*4882a593Smuzhiyun			MX51_PAD_SD1_DATA3__SD1_DATA3		0x20d5
218*4882a593Smuzhiyun			MX51_PAD_GPIO1_0__GPIO1_0		0x100
219*4882a593Smuzhiyun			MX51_PAD_GPIO1_1__GPIO1_1		0x100
220*4882a593Smuzhiyun		>;
221*4882a593Smuzhiyun	};
222*4882a593Smuzhiyun
223*4882a593Smuzhiyun	pinctrl_fec: fecgrp {
224*4882a593Smuzhiyun		fsl,pins = <
225*4882a593Smuzhiyun			MX51_PAD_EIM_EB2__FEC_MDIO		0x000001f5
226*4882a593Smuzhiyun			MX51_PAD_EIM_EB3__FEC_RDATA1		0x00000085
227*4882a593Smuzhiyun			MX51_PAD_EIM_CS2__FEC_RDATA2		0x00000085
228*4882a593Smuzhiyun			MX51_PAD_EIM_CS3__FEC_RDATA3		0x00000085
229*4882a593Smuzhiyun			MX51_PAD_EIM_CS4__FEC_RX_ER		0x00000180
230*4882a593Smuzhiyun			MX51_PAD_EIM_CS5__FEC_CRS		0x00000180
231*4882a593Smuzhiyun			MX51_PAD_DISP2_DAT10__FEC_COL		0x00000180
232*4882a593Smuzhiyun			MX51_PAD_DISP2_DAT11__FEC_RX_CLK	0x00000180
233*4882a593Smuzhiyun			MX51_PAD_DISP2_DAT14__FEC_RDATA0	0x00002180
234*4882a593Smuzhiyun			MX51_PAD_DISP2_DAT15__FEC_TDATA0	0x00002004
235*4882a593Smuzhiyun			MX51_PAD_NANDF_CS2__FEC_TX_ER		0x00002004
236*4882a593Smuzhiyun			MX51_PAD_DI2_PIN2__FEC_MDC		0x00002004
237*4882a593Smuzhiyun			MX51_PAD_DISP2_DAT6__FEC_TDATA1		0x00002004
238*4882a593Smuzhiyun			MX51_PAD_DISP2_DAT7__FEC_TDATA2		0x00002004
239*4882a593Smuzhiyun			MX51_PAD_DISP2_DAT8__FEC_TDATA3		0x00002004
240*4882a593Smuzhiyun			MX51_PAD_DISP2_DAT9__FEC_TX_EN		0x00002004
241*4882a593Smuzhiyun			MX51_PAD_DISP2_DAT13__FEC_TX_CLK	0x00002180
242*4882a593Smuzhiyun			MX51_PAD_DISP2_DAT12__FEC_RX_DV		0x000020a4
243*4882a593Smuzhiyun			MX51_PAD_EIM_A20__GPIO2_14		0x00000085 /* Phy Reset */
244*4882a593Smuzhiyun		>;
245*4882a593Smuzhiyun	};
246*4882a593Smuzhiyun
247*4882a593Smuzhiyun	pinctrl_i2c2: i2c2grp {
248*4882a593Smuzhiyun		fsl,pins = <
249*4882a593Smuzhiyun			MX51_PAD_KEY_COL4__I2C2_SCL		0x400001ed
250*4882a593Smuzhiyun			MX51_PAD_KEY_COL5__I2C2_SDA		0x400001ed
251*4882a593Smuzhiyun		>;
252*4882a593Smuzhiyun	};
253*4882a593Smuzhiyun
254*4882a593Smuzhiyun	pinctrl_interrupt_fpga: fpgaicgrp {
255*4882a593Smuzhiyun		fsl,pins = <
256*4882a593Smuzhiyun			MX51_PAD_EIM_D27__GPIO2_9		0xe5
257*4882a593Smuzhiyun		>;
258*4882a593Smuzhiyun	};
259*4882a593Smuzhiyun
260*4882a593Smuzhiyun	pinctrl_lcd: lcdgrp {
261*4882a593Smuzhiyun		fsl,pins = <
262*4882a593Smuzhiyun			MX51_PAD_DISP1_DAT0__DISP1_DAT0		0x5
263*4882a593Smuzhiyun			MX51_PAD_DISP1_DAT1__DISP1_DAT1		0x5
264*4882a593Smuzhiyun			MX51_PAD_DISP1_DAT2__DISP1_DAT2		0x5
265*4882a593Smuzhiyun			MX51_PAD_DISP1_DAT3__DISP1_DAT3		0x5
266*4882a593Smuzhiyun			MX51_PAD_DISP1_DAT4__DISP1_DAT4		0x5
267*4882a593Smuzhiyun			MX51_PAD_DISP1_DAT5__DISP1_DAT5		0x5
268*4882a593Smuzhiyun			MX51_PAD_DISP1_DAT6__DISP1_DAT6		0x5
269*4882a593Smuzhiyun			MX51_PAD_DISP1_DAT7__DISP1_DAT7		0x5
270*4882a593Smuzhiyun			MX51_PAD_DISP1_DAT8__DISP1_DAT8		0x5
271*4882a593Smuzhiyun			MX51_PAD_DISP1_DAT9__DISP1_DAT9		0x5
272*4882a593Smuzhiyun			MX51_PAD_DISP1_DAT10__DISP1_DAT10	0x5
273*4882a593Smuzhiyun			MX51_PAD_DISP1_DAT11__DISP1_DAT11	0x5
274*4882a593Smuzhiyun			MX51_PAD_DISP1_DAT12__DISP1_DAT12	0x5
275*4882a593Smuzhiyun			MX51_PAD_DISP1_DAT13__DISP1_DAT13	0x5
276*4882a593Smuzhiyun			MX51_PAD_DISP1_DAT14__DISP1_DAT14	0x5
277*4882a593Smuzhiyun			MX51_PAD_DISP1_DAT15__DISP1_DAT15	0x5
278*4882a593Smuzhiyun			MX51_PAD_DISP1_DAT16__DISP1_DAT16	0x5
279*4882a593Smuzhiyun			MX51_PAD_DISP1_DAT17__DISP1_DAT17	0x5
280*4882a593Smuzhiyun			MX51_PAD_DISP1_DAT18__DISP1_DAT18	0x5
281*4882a593Smuzhiyun			MX51_PAD_DISP1_DAT19__DISP1_DAT19	0x5
282*4882a593Smuzhiyun			MX51_PAD_DISP1_DAT20__DISP1_DAT20	0x5
283*4882a593Smuzhiyun			MX51_PAD_DISP1_DAT21__DISP1_DAT21	0x5
284*4882a593Smuzhiyun			MX51_PAD_DISP1_DAT22__DISP1_DAT22	0x5
285*4882a593Smuzhiyun			MX51_PAD_DISP1_DAT23__DISP1_DAT23	0x5
286*4882a593Smuzhiyun			MX51_PAD_DI1_PIN2__DI1_PIN2		0x5
287*4882a593Smuzhiyun			MX51_PAD_DI1_PIN3__DI1_PIN3		0x5
288*4882a593Smuzhiyun			MX51_PAD_DI2_DISP_CLK__DI2_DISP_CLK	0x5
289*4882a593Smuzhiyun			MX51_PAD_DI_GP4__DI2_PIN15		0x5
290*4882a593Smuzhiyun		>;
291*4882a593Smuzhiyun	};
292*4882a593Smuzhiyun
293*4882a593Smuzhiyun	pinctrl_pwm_backlight: backlightgrp {
294*4882a593Smuzhiyun		fsl,pins = <
295*4882a593Smuzhiyun			MX51_PAD_GPIO1_2__PWM1_PWMO		0x80000000
296*4882a593Smuzhiyun		>;
297*4882a593Smuzhiyun	};
298*4882a593Smuzhiyun
299*4882a593Smuzhiyun	pinctrl_uart1: uart1grp {
300*4882a593Smuzhiyun		fsl,pins = <
301*4882a593Smuzhiyun			MX51_PAD_UART1_RXD__UART1_RXD		0x1c5
302*4882a593Smuzhiyun			MX51_PAD_UART1_TXD__UART1_TXD		0x1c5
303*4882a593Smuzhiyun		>;
304*4882a593Smuzhiyun	};
305*4882a593Smuzhiyun
306*4882a593Smuzhiyun	pinctrl_uart2: uart2grp {
307*4882a593Smuzhiyun		fsl,pins = <
308*4882a593Smuzhiyun			MX51_PAD_UART2_RXD__UART2_RXD		0x1c5
309*4882a593Smuzhiyun			MX51_PAD_UART2_TXD__UART2_TXD		0x1c5
310*4882a593Smuzhiyun		>;
311*4882a593Smuzhiyun	};
312*4882a593Smuzhiyun
313*4882a593Smuzhiyun	pinctrl_uart3: uart3grp {
314*4882a593Smuzhiyun		fsl,pins = <
315*4882a593Smuzhiyun			MX51_PAD_EIM_D25__UART3_RXD		0x1c5
316*4882a593Smuzhiyun			MX51_PAD_EIM_D26__UART3_TXD		0x1c5
317*4882a593Smuzhiyun		>;
318*4882a593Smuzhiyun	};
319*4882a593Smuzhiyun
320*4882a593Smuzhiyun	pinctrl_weim: weimgrp {
321*4882a593Smuzhiyun		fsl,pins = <
322*4882a593Smuzhiyun			MX51_PAD_EIM_DTACK__EIM_DTACK		0x85
323*4882a593Smuzhiyun			MX51_PAD_EIM_CS0__EIM_CS0		0x0
324*4882a593Smuzhiyun			MX51_PAD_EIM_CS1__EIM_CS1		0x0
325*4882a593Smuzhiyun			MX51_PAD_EIM_EB0__EIM_EB0		0x85
326*4882a593Smuzhiyun			MX51_PAD_EIM_EB1__EIM_EB1		0x85
327*4882a593Smuzhiyun			MX51_PAD_EIM_OE__EIM_OE			0x85
328*4882a593Smuzhiyun			MX51_PAD_EIM_LBA__EIM_LBA		0x85
329*4882a593Smuzhiyun		>;
330*4882a593Smuzhiyun	};
331*4882a593Smuzhiyun};
332