hc
2024-12-19 9370bb92b2d16684ee45cf24e879c93c509162da
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
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
// 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-ha-common.dtsi"
 
/ {
   model = "TI OMAP3 HEAD acoustics LCD-baseboard with TAO3530 SOM";
   compatible = "headacoustics,omap3-ha-lcd", "technexion,omap3-tao3530", "ti,omap3430", "ti,omap34xx", "ti,omap3";
};
 
&omap3_pmx_core {
   pinctrl-names = "default";
   pinctrl-0 = <
       &hsusbb2_pins
       &powerdown_input_pins
       &fpga_boot0_pins
       &fpga_boot1_pins
       &led_blue_pins
       &led_green_pins
       &led_red_pins
       &touchscreen_wake_pins
   >;
 
   touchscreen_irq_pins: pinmux_touchscreen_irq_pins {
       pinctrl-single,pins = <
           OMAP3_CORE1_IOPAD(0x2164, PIN_INPUT_PULLUP | MUX_MODE4)    /* gpio_136, Touchscreen IRQ */
       >;
   };
 
   touchscreen_wake_pins: pinmux_touchscreen_wake_pins {
       pinctrl-single,pins = <
           OMAP3_CORE1_IOPAD(0x212c, PIN_OUTPUT_PULLUP | MUX_MODE4)    /* gpio_110, Touchscreen Wake */
       >;
   };
 
   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 */
       >;
   };
};
 
/* I2C2: mux'ed with GPIO168 which is connected to nKILL_POWER */
&i2c2 {
   status = "disabled";
};
 
&i2c3 {
   clock-frequency = <100000>;
 
   pinctrl-names = "default";
   pinctrl-0 = <&i2c3_pins>;
};
 
/* 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 = "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 = <31250000>;
           hactive = <800>;
           vactive = <480>;
           hfront-porch = <40>;
           hback-porch = <86>;
           hsync-len = <1>;
           vback-porch = <30>;
           vfront-porch = <13>;
           vsync-len = <3>;
 
           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;
   };
};