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