hc
2025-02-14 bbb9540dc49f70f6b703d1c8d1b85fa5f602d86e
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
// SPDX-License-Identifier: GPL-2.0-only
/*
 * Copyright (C) 2012 Texas Instruments Incorporated - https://www.ti.com/
 * Copyright (C) 2014 Stefan Roese <sr@denx.de>
 */
 
#include "omap3-tao3530.dtsi"
 
/ {
   model = "TI OMAP3 Thunder baseboard with TAO3530 SOM";
   compatible = "technexion,omap3-thunder", "technexion,omap3-tao3530", "ti,omap3430", "ti,omap34xx", "ti,omap3";
};
 
&omap3_pmx_core {
   dss_dpi_pins: pinmux_dss_dpi_pins {
       pinctrl-single,pins = <
           OMAP3_CORE1_IOPAD(0x20d4, PIN_OUTPUT | MUX_MODE0)    /* dss_pclk.dss_pclk */
           OMAP3_CORE1_IOPAD(0x20d6, PIN_OUTPUT | MUX_MODE0)    /* dss_hsync.dss_hsync */
           OMAP3_CORE1_IOPAD(0x20d8, PIN_OUTPUT | MUX_MODE0)    /* dss_vsync.dss_vsync */
           OMAP3_CORE1_IOPAD(0x20da, PIN_OUTPUT | MUX_MODE0)    /* dss_acbias.dss_acbias */
           OMAP3_CORE1_IOPAD(0x20dc, PIN_OUTPUT | MUX_MODE0)    /* dss_data0.dss_data0 */
           OMAP3_CORE1_IOPAD(0x20de, PIN_OUTPUT | MUX_MODE0)    /* dss_data1.dss_data1 */
           OMAP3_CORE1_IOPAD(0x20e0, PIN_OUTPUT | MUX_MODE0)    /* dss_data2.dss_data2 */
           OMAP3_CORE1_IOPAD(0x20e2, PIN_OUTPUT | MUX_MODE0)    /* dss_data3.dss_data3 */
           OMAP3_CORE1_IOPAD(0x20e4, PIN_OUTPUT | MUX_MODE0)    /* dss_data4.dss_data4 */
           OMAP3_CORE1_IOPAD(0x20e6, PIN_OUTPUT | MUX_MODE0)    /* dss_data5.dss_data5 */
           OMAP3_CORE1_IOPAD(0x20e8, PIN_OUTPUT | MUX_MODE0)    /* dss_data6.dss_data6 */
           OMAP3_CORE1_IOPAD(0x20ea, PIN_OUTPUT | MUX_MODE0)    /* dss_data7.dss_data7 */
           OMAP3_CORE1_IOPAD(0x20ec, PIN_OUTPUT | MUX_MODE0)    /* dss_data8.dss_data8 */
           OMAP3_CORE1_IOPAD(0x20ee, PIN_OUTPUT | MUX_MODE0)    /* dss_data9.dss_data9 */
           OMAP3_CORE1_IOPAD(0x20f0, PIN_OUTPUT | MUX_MODE0)    /* dss_data10.dss_data10 */
           OMAP3_CORE1_IOPAD(0x20f2, PIN_OUTPUT | MUX_MODE0)    /* dss_data11.dss_data11 */
           OMAP3_CORE1_IOPAD(0x20f4, PIN_OUTPUT | MUX_MODE0)    /* dss_data12.dss_data12 */
           OMAP3_CORE1_IOPAD(0x20f6, PIN_OUTPUT | MUX_MODE0)    /* dss_data13.dss_data13 */
           OMAP3_CORE1_IOPAD(0x20f8, PIN_OUTPUT | MUX_MODE0)    /* dss_data14.dss_data14 */
           OMAP3_CORE1_IOPAD(0x20fa, PIN_OUTPUT | MUX_MODE0)    /* dss_data15.dss_data15 */
           OMAP3_CORE1_IOPAD(0x20fc, PIN_OUTPUT | MUX_MODE0)    /* dss_data16.dss_data16 */
           OMAP3_CORE1_IOPAD(0x20fe, PIN_OUTPUT | MUX_MODE0)    /* dss_data17.dss_data17 */
           OMAP3_CORE1_IOPAD(0x2100, PIN_OUTPUT | MUX_MODE0)    /* dss_data18.dss_data18 */
           OMAP3_CORE1_IOPAD(0x2102, PIN_OUTPUT | MUX_MODE0)    /* dss_data19.dss_data19 */
           OMAP3_CORE1_IOPAD(0x2104, PIN_OUTPUT | MUX_MODE0)    /* dss_data20.dss_data20 */
           OMAP3_CORE1_IOPAD(0x2106, PIN_OUTPUT | MUX_MODE0)    /* dss_data21.dss_data21 */
           OMAP3_CORE1_IOPAD(0x2108, PIN_OUTPUT | MUX_MODE0)    /* dss_data22.dss_data22 */
           OMAP3_CORE1_IOPAD(0x210a, PIN_OUTPUT | MUX_MODE0)    /* dss_data23.dss_data23 */
       >;
   };
 
   lte430_pins: pinmux_lte430_pins {
       pinctrl-single,pins = <
           OMAP3_CORE1_IOPAD(0x2168, PIN_OUTPUT | MUX_MODE4)    /* sdmmc2_dat6.gpio_138 */
       >;
   };
 
   backlight_pins: pinmux_backlight_pins {
       pinctrl-single,pins = <
           OMAP3_CORE1_IOPAD(0x216a, PIN_OUTPUT | MUX_MODE4)    /* sdmmc2_dat7.gpio_139 */
       >;
   };
};
 
/* Needed to power the DPI pins */
&vpll2 {
   regulator-always-on;
};
 
&dss {
   status = "okay";
 
   pinctrl-names = "default";
   pinctrl-0 = <&dss_dpi_pins>;
 
   port {
       dpi_out: endpoint {
           remote-endpoint = <&lcd_in>;
           data-lines = <24>;
       };
   };
};
 
/ {
   aliases {
       display0 = &lcd0;
   };
 
   lcd0: display {
       compatible = "samsung,lte430wq-f0c", "panel-dpi";
       label = "lcd";
 
       pinctrl-names = "default";
       pinctrl-0 = <&lte430_pins>;
       enable-gpios = <&gpio5 10 GPIO_ACTIVE_LOW>;    /* gpio_138 */
 
       port {
           lcd_in: endpoint {
               remote-endpoint = <&dpi_out>;
           };
       };
 
       panel-timing {
           clock-frequency = <9000000>;
           hactive = <480>;
           vactive = <272>;
           hfront-porch = <3>;
           hback-porch = <2>;
           hsync-len = <42>;
           vback-porch = <2>;
           vfront-porch = <3>;
           vsync-len = <11>;
 
           hsync-active = <0>;
           vsync-active = <0>;
           de-active = <1>;
           pixelclk-active = <1>;
       };
   };
 
   backlight {
       compatible = "gpio-backlight";
 
       pinctrl-names = "default";
       pinctrl-0 = <&backlight_pins>;
       gpios = <&gpio5 11 GPIO_ACTIVE_HIGH>;        /* gpio_139 */
 
       default-on;
   };
};