aboutsummaryrefslogtreecommitdiffstats
path: root/arch/arm
diff options
context:
space:
mode:
authorTony Lindgren <tony@atomide.com>2014-05-13 17:32:05 -0400
committerTomi Valkeinen <tomi.valkeinen@ti.com>2014-06-03 03:22:21 -0400
commitbc10f310e2856f7bb80875fd7d8386836df4c85e (patch)
tree145eee8cdde77241e9465f7f61b7143d1c67072c /arch/arm
parentc2e138bc8ed80ae291d689917e88d2d09bf1d478 (diff)
ARM: dts: Add LCD panel sharp ls037v7dw01 support for omap3-evm and ldp
Looks like quite a few omap3 boards have sharp ls037v7dw01 that's configured as various panel dpi entries for whatever legacy reasons. For device tree based support, let's just configure these properly for panel ls037v7dw01 instead of panel dpi. This patch creates a common file for panel ls037v7dw01, and makes boards ldp and omap3-evm to use it. The ls037v7dw01 also seems to be coupled with an ad7846 touchscreen controller for the omaps, so let's add a basic configuration for the touchscreen also using the default values. Signed-off-by: Tony Lindgren <tony@atomide.com> Signed-off-by: Tomi Valkeinen <tomi.valkeinen@ti.com>
Diffstat (limited to 'arch/arm')
-rw-r--r--arch/arm/boot/dts/omap3-evm-37xx.dts50
-rw-r--r--arch/arm/boot/dts/omap3-evm-common.dtsi26
-rw-r--r--arch/arm/boot/dts/omap3-ldp.dts29
-rw-r--r--arch/arm/boot/dts/omap3-panel-sharp-ls037v7dw01.dtsi71
4 files changed, 171 insertions, 5 deletions
diff --git a/arch/arm/boot/dts/omap3-evm-37xx.dts b/arch/arm/boot/dts/omap3-evm-37xx.dts
index 4df68ad3736a..a181e30daaef 100644
--- a/arch/arm/boot/dts/omap3-evm-37xx.dts
+++ b/arch/arm/boot/dts/omap3-evm-37xx.dts
@@ -26,7 +26,44 @@
26 }; 26 };
27}; 27};
28 28
29&dss {
30 pinctrl-names = "default";
31 pinctrl-0 = <
32 &dss_dpi_pins1
33 &dss_dpi_pins2
34 >;
35};
36
29&omap3_pmx_core { 37&omap3_pmx_core {
38 dss_dpi_pins1: pinmux_dss_dpi_pins2 {
39 pinctrl-single,pins = <
40 OMAP3_CORE1_IOPAD(0x20d4, PIN_OUTPUT | MUX_MODE0) /* dss_pclk.dss_pclk */
41 OMAP3_CORE1_IOPAD(0x20d6, PIN_OUTPUT | MUX_MODE0) /* dss_hsync.dss_hsync */
42 OMAP3_CORE1_IOPAD(0x20d8, PIN_OUTPUT | MUX_MODE0) /* dss_vsync.dss_vsync */
43 OMAP3_CORE1_IOPAD(0x20da, PIN_OUTPUT | MUX_MODE0) /* dss_acbias.dss_acbias */
44
45 OMAP3_CORE1_IOPAD(0x20e8, PIN_OUTPUT | MUX_MODE0) /* dss_data6.dss_data6 */
46 OMAP3_CORE1_IOPAD(0x20ea, PIN_OUTPUT | MUX_MODE0) /* dss_data7.dss_data7 */
47 OMAP3_CORE1_IOPAD(0x20ec, PIN_OUTPUT | MUX_MODE0) /* dss_data8.dss_data8 */
48 OMAP3_CORE1_IOPAD(0x20ee, PIN_OUTPUT | MUX_MODE0) /* dss_data9.dss_data9 */
49 OMAP3_CORE1_IOPAD(0x20f0, PIN_OUTPUT | MUX_MODE0) /* dss_data10.dss_data10 */
50 OMAP3_CORE1_IOPAD(0x20f2, PIN_OUTPUT | MUX_MODE0) /* dss_data11.dss_data11 */
51 OMAP3_CORE1_IOPAD(0x20f4, PIN_OUTPUT | MUX_MODE0) /* dss_data12.dss_data12 */
52 OMAP3_CORE1_IOPAD(0x20f6, PIN_OUTPUT | MUX_MODE0) /* dss_data13.dss_data13 */
53 OMAP3_CORE1_IOPAD(0x20f8, PIN_OUTPUT | MUX_MODE0) /* dss_data14.dss_data14 */
54 OMAP3_CORE1_IOPAD(0x20fa, PIN_OUTPUT | MUX_MODE0) /* dss_data15.dss_data15 */
55 OMAP3_CORE1_IOPAD(0x20fc, PIN_OUTPUT | MUX_MODE0) /* dss_data16.dss_data16 */
56 OMAP3_CORE1_IOPAD(0x20fe, PIN_OUTPUT | MUX_MODE0) /* dss_data17.dss_data17 */
57
58 OMAP3_CORE1_IOPAD(0x2100, PIN_OUTPUT | MUX_MODE3) /* dss_data18.dss_data0 */
59 OMAP3_CORE1_IOPAD(0x2102, PIN_OUTPUT | MUX_MODE3) /* dss_data19.dss_data1 */
60 OMAP3_CORE1_IOPAD(0x2104, PIN_OUTPUT | MUX_MODE3) /* dss_data20.dss_data2 */
61 OMAP3_CORE1_IOPAD(0x2106, PIN_OUTPUT | MUX_MODE3) /* dss_data21.dss_data3 */
62 OMAP3_CORE1_IOPAD(0x2108, PIN_OUTPUT | MUX_MODE3) /* dss_data22.dss_data4 */
63 OMAP3_CORE1_IOPAD(0x210a, PIN_OUTPUT | MUX_MODE3) /* dss_data23.dss_data5 */
64 >;
65 };
66
30 mmc1_pins: pinmux_mmc1_pins { 67 mmc1_pins: pinmux_mmc1_pins {
31 pinctrl-single,pins = < 68 pinctrl-single,pins = <
32 0x114 (PIN_OUTPUT_PULLUP | MUX_MODE0) /* sdmmc1_clk.sdmmc1_clk */ 69 0x114 (PIN_OUTPUT_PULLUP | MUX_MODE0) /* sdmmc1_clk.sdmmc1_clk */
@@ -75,6 +112,19 @@
75 }; 112 };
76}; 113};
77 114
115&omap3_pmx_wkup {
116 dss_dpi_pins2: pinmux_dss_dpi_pins1 {
117 pinctrl-single,pins = <
118 0x0a (PIN_OUTPUT | MUX_MODE3) /* sys_boot0.dss_data18 */
119 0x0c (PIN_OUTPUT | MUX_MODE3) /* sys_boot1.dss_data19 */
120 0x10 (PIN_OUTPUT | MUX_MODE3) /* sys_boot3.dss_data20 */
121 0x12 (PIN_OUTPUT | MUX_MODE3) /* sys_boot4.dss_data21 */
122 0x14 (PIN_OUTPUT | MUX_MODE3) /* sys_boot5.dss_data22 */
123 0x16 (PIN_OUTPUT | MUX_MODE3) /* sys_boot6.dss_data23 */
124 >;
125 };
126};
127
78&mmc1 { 128&mmc1 {
79 pinctrl-names = "default"; 129 pinctrl-names = "default";
80 pinctrl-0 = <&mmc1_pins>; 130 pinctrl-0 = <&mmc1_pins>;
diff --git a/arch/arm/boot/dts/omap3-evm-common.dtsi b/arch/arm/boot/dts/omap3-evm-common.dtsi
index 3007e79c9cd6..8ae8f007c8ad 100644
--- a/arch/arm/boot/dts/omap3-evm-common.dtsi
+++ b/arch/arm/boot/dts/omap3-evm-common.dtsi
@@ -44,6 +44,11 @@
44 44
45#include "twl4030.dtsi" 45#include "twl4030.dtsi"
46#include "twl4030_omap3.dtsi" 46#include "twl4030_omap3.dtsi"
47#include "omap3-panel-sharp-ls037v7dw01.dtsi"
48
49&backlight0 {
50 gpios = <&twl_gpio 18 GPIO_ACTIVE_LOW>;
51};
47 52
48&i2c2 { 53&i2c2 {
49 clock-frequency = <400000>; 54 clock-frequency = <400000>;
@@ -61,6 +66,27 @@
61 }; 66 };
62}; 67};
63 68
69&lcd_3v3 {
70 gpio = <&gpio5 25 GPIO_ACTIVE_LOW>; /* gpio153 */
71 enable-active-low;
72};
73
74&lcd0 {
75 enable-gpios = <&gpio5 24 GPIO_ACTIVE_HIGH>; /* gpio152, lcd INI */
76 reset-gpios = <&gpio5 27 GPIO_ACTIVE_HIGH>; /* gpio155, lcd RESB */
77 mode-gpios = <&gpio5 26 GPIO_ACTIVE_HIGH /* gpio154, lcd MO */
78 &gpio1 2 GPIO_ACTIVE_HIGH /* gpio2, lcd LR */
79 &gpio1 3 GPIO_ACTIVE_HIGH>; /* gpio3, lcd UD */
80};
81
82&mcspi1 {
83 tsc2046@0 {
84 interrupt-parent = <&gpio6>;
85 interrupts = <15 0>; /* gpio175 */
86 pendown-gpio = <&gpio6 15 0>;
87 };
88};
89
64&mmc1 { 90&mmc1 {
65 vmmc-supply = <&vmmc1>; 91 vmmc-supply = <&vmmc1>;
66 vmmc_aux-supply = <&vsim>; 92 vmmc_aux-supply = <&vsim>;
diff --git a/arch/arm/boot/dts/omap3-ldp.dts b/arch/arm/boot/dts/omap3-ldp.dts
index 0abe986a4ecc..9c751e420f37 100644
--- a/arch/arm/boot/dts/omap3-ldp.dts
+++ b/arch/arm/boot/dts/omap3-ldp.dts
@@ -164,6 +164,11 @@
164 164
165#include "twl4030.dtsi" 165#include "twl4030.dtsi"
166#include "twl4030_omap3.dtsi" 166#include "twl4030_omap3.dtsi"
167#include "omap3-panel-sharp-ls037v7dw01.dtsi"
168
169&backlight0 {
170 gpios = <&twl_gpio 7 GPIO_ACTIVE_HIGH>;
171};
167 172
168&i2c2 { 173&i2c2 {
169 clock-frequency = <400000>; 174 clock-frequency = <400000>;
@@ -173,6 +178,25 @@
173 clock-frequency = <400000>; 178 clock-frequency = <400000>;
174}; 179};
175 180
181/* tps61130rsa enabled by twl4030 regen */
182&lcd_3v3 {
183 regulator-always-on;
184};
185
186&lcd0 {
187 enable-gpios = <&twl_gpio 15 GPIO_ACTIVE_HIGH>; /* lcd INI */
188 reset-gpios = <&gpio2 23 GPIO_ACTIVE_HIGH>; /* gpio55, lcd RESB */
189 mode-gpios = <&gpio2 24 GPIO_ACTIVE_HIGH>; /* gpio56, lcd MO */
190};
191
192&mcspi1 {
193 tsc2046@0 {
194 interrupt-parent = <&gpio2>;
195 interrupts = <22 0>; /* gpio54 */
196 pendown-gpio = <&gpio2 22 0>;
197 };
198};
199
176&mmc1 { 200&mmc1 {
177 /* See 35xx errata 2.1.1.128 in SPRZ278F */ 201 /* See 35xx errata 2.1.1.128 in SPRZ278F */
178 compatible = "ti,omap3-pre-es3-hsmmc"; 202 compatible = "ti,omap3-pre-es3-hsmmc";
@@ -247,8 +271,3 @@
247 /* Needed for ads7846 */ 271 /* Needed for ads7846 */
248 regulator-name = "vcc"; 272 regulator-name = "vcc";
249}; 273};
250
251&vpll2 {
252 /* Needed for DSS */
253 regulator-name = "vdds_dsi";
254};
diff --git a/arch/arm/boot/dts/omap3-panel-sharp-ls037v7dw01.dtsi b/arch/arm/boot/dts/omap3-panel-sharp-ls037v7dw01.dtsi
new file mode 100644
index 000000000000..f4b1a61853e3
--- /dev/null
+++ b/arch/arm/boot/dts/omap3-panel-sharp-ls037v7dw01.dtsi
@@ -0,0 +1,71 @@
1/*
2 * Common file for omap dpi panels with QVGA and reset pins
3 *
4 * Note that the board specifc DTS file needs to specify
5 * at minimum the GPIO enable-gpios for display, and
6 * gpios for gpio-backlight.
7 */
8
9/ {
10 aliases {
11 display0 = &lcd0;
12 };
13
14 backlight0: backlight {
15 compatible = "gpio-backlight";
16 default-on;
17 };
18
19 /* 3.3V GPIO controlled regulator for LCD_ENVDD */
20 lcd_3v3: regulator-lcd-3v3 {
21 compatible = "regulator-fixed";
22 regulator-name = "lcd_3v3";
23 regulator-min-microvolt = <3300000>;
24 regulator-max-microvolt = <3300000>;
25 startup-delay-us = <70000>;
26 };
27
28 lcd0: display {
29 compatible = "sharp,ls037v7dw01";
30 label = "lcd";
31 power-supply = <&lcd_3v3>;
32
33 port {
34 lcd_in: endpoint {
35 remote-endpoint = <&dpi_out>;
36 };
37 };
38 };
39};
40
41/* Needed to power the DPI pins */
42&vpll2 {
43 regulator-always-on;
44};
45
46&dss {
47 status = "ok";
48 port {
49 dpi_out: endpoint {
50 remote-endpoint = <&lcd_in>;
51 data-lines = <18>;
52 };
53 };
54};
55
56&mcspi1 {
57 tsc2046@0 {
58 reg = <0>; /* CS0 */
59 compatible = "ti,tsc2046";
60 spi-max-frequency = <1000000>;
61 vcc-supply = <&lcd_3v3>;
62 ti,x-min = /bits/ 16 <0>;
63 ti,x-max = /bits/ 16 <8000>;
64 ti,y-min = /bits/ 16 <0>;
65 ti,y-max = /bits/ 16 <4800>;
66 ti,x-plate-ohms = /bits/ 16 <40>;
67 ti,pressure-max = /bits/ 16 <255>;
68 ti,swap-xy;
69 linux,wakeup;
70 };
71};