diff options
author | Zumeng Chen <zumeng.chen@windriver.com> | 2012-06-20 05:14:53 -0400 |
---|---|---|
committer | Tony Lindgren <tony@atomide.com> | 2012-07-06 04:37:25 -0400 |
commit | 16aced80f6739beb2a6ff7b6f96c83ba80d331e8 (patch) | |
tree | 50e83b4139384aa0622f3b1b90bca221ab3476d4 /arch/arm/mach-omap2/common-board-devices.c | |
parent | cb8ca5897b58f1820f44ac365c9740ba9986701b (diff) |
ARM: OMAP3530evm: set pendown_state and debounce time for ads7846
Currently most ads7846 config definitions for OMAP3 series boards have
been moved to common-board-devices.c, and it is transparent for init.
And it's no very proper to do gpio_request based on get_pendown_state
since omap_ads7846_init knows everything about ads7846_config.
So it's more fit to request gpio according to the right gpio_pendown
and set debounce time conditionally. If we don't set proper debouce
time, there are flooded interrupt counters of ads7846 responding to
one time touch on screen, then the driver couldn't work very well.
This patch has been validated on 3530evm.
Signed-off-by: Zumeng Chen <zumeng.chen@windriver.com>
Signed-off-by: Tony Lindgren <tony@atomide.com>
Diffstat (limited to 'arch/arm/mach-omap2/common-board-devices.c')
-rw-r--r-- | arch/arm/mach-omap2/common-board-devices.c | 18 |
1 files changed, 16 insertions, 2 deletions
diff --git a/arch/arm/mach-omap2/common-board-devices.c b/arch/arm/mach-omap2/common-board-devices.c index 1706ebcec08d..4ba070e1288c 100644 --- a/arch/arm/mach-omap2/common-board-devices.c +++ b/arch/arm/mach-omap2/common-board-devices.c | |||
@@ -35,6 +35,16 @@ static struct omap2_mcspi_device_config ads7846_mcspi_config = { | |||
35 | .turbo_mode = 0, | 35 | .turbo_mode = 0, |
36 | }; | 36 | }; |
37 | 37 | ||
38 | /* | ||
39 | * ADS7846 driver maybe request a gpio according to the value | ||
40 | * of pdata->get_pendown_state, but we have done this. So set | ||
41 | * get_pendown_state to avoid twice gpio requesting. | ||
42 | */ | ||
43 | static int omap3_get_pendown_state(void) | ||
44 | { | ||
45 | return !gpio_get_value(OMAP3_EVM_TS_GPIO); | ||
46 | } | ||
47 | |||
38 | static struct ads7846_platform_data ads7846_config = { | 48 | static struct ads7846_platform_data ads7846_config = { |
39 | .x_max = 0x0fff, | 49 | .x_max = 0x0fff, |
40 | .y_max = 0x0fff, | 50 | .y_max = 0x0fff, |
@@ -45,6 +55,7 @@ static struct ads7846_platform_data ads7846_config = { | |||
45 | .debounce_rep = 1, | 55 | .debounce_rep = 1, |
46 | .gpio_pendown = -EINVAL, | 56 | .gpio_pendown = -EINVAL, |
47 | .keep_vref_on = 1, | 57 | .keep_vref_on = 1, |
58 | .get_pendown_state = &omap3_get_pendown_state, | ||
48 | }; | 59 | }; |
49 | 60 | ||
50 | static struct spi_board_info ads7846_spi_board_info __initdata = { | 61 | static struct spi_board_info ads7846_spi_board_info __initdata = { |
@@ -63,14 +74,17 @@ void __init omap_ads7846_init(int bus_num, int gpio_pendown, int gpio_debounce, | |||
63 | struct spi_board_info *spi_bi = &ads7846_spi_board_info; | 74 | struct spi_board_info *spi_bi = &ads7846_spi_board_info; |
64 | int err; | 75 | int err; |
65 | 76 | ||
66 | if (board_pdata && board_pdata->get_pendown_state) { | 77 | if (gpio_pendown) { |
67 | err = gpio_request_one(gpio_pendown, GPIOF_IN, "TSPenDown"); | 78 | err = gpio_request_one(gpio_pendown, GPIOF_IN, "TSPenDown"); |
68 | if (err) { | 79 | if (err) { |
69 | pr_err("Couldn't obtain gpio for TSPenDown: %d\n", err); | 80 | pr_err("Couldn't obtain gpio for TSPenDown: %d\n", err); |
70 | return; | 81 | return; |
71 | } | 82 | } |
72 | gpio_export(gpio_pendown, 0); | ||
73 | 83 | ||
84 | /* TS GPIOPendown doesn't allow user to change the direction */ | ||
85 | gpio_export(gpio_pendown, false); | ||
86 | |||
87 | /* Set proper debouce time for ads7846. */ | ||
74 | if (gpio_debounce) | 88 | if (gpio_debounce) |
75 | gpio_set_debounce(gpio_pendown, gpio_debounce); | 89 | gpio_set_debounce(gpio_pendown, gpio_debounce); |
76 | } | 90 | } |