* Re: [PATCH 5/5] Input: ads7846: set proper debounce time in driver level [not found] ` <1339423216-1323-6-git-send-email-zumeng.chen@gmail.com> @ 2012-06-11 14:37 ` Igor Grinberg 2012-06-12 2:49 ` Zumeng Chen 0 siblings, 1 reply; 3+ messages in thread From: Igor Grinberg @ 2012-06-11 14:37 UTC (permalink / raw) To: Zumeng Chen Cc: tony, linux-omap, linux-arm-kernel, khilman, khasim, ajay.gupta, Vaibhav Hiremath, Dmitry Torokhov, linux-input@vger.kernel.org Hi, This is input subsystem, add Dmitry and linux-input. On 06/11/12 17:00, Zumeng Chen wrote: > If we don't set proper debouce time for ads7846, then there are > flooded interrupt counters of ads7846 responding to one time > touch on screen, so the driver couldn't work well. > > And since most OMAP3 series boards pass NULL pointer of board_pdata > to omap_ads7846_init, so it's more proper to set it in driver level > after having gpio_request done. What about other non-OMAP platforms? NULL pointer for board_pdata, only means that the default pdata is used. Please, see the common-board-devices.c file more closely. > > This patch has been validated on 3530evm. > > Signed-off-by: Zumeng Chen <zumeng.chen@gmail.com> > Signed-off-by: Syed Mohammed Khasim <khasim@ti.com> > Signed-off-by: Tony Lindgren <tony@atomide.com> > --- > drivers/input/touchscreen/ads7846.c | 2 ++ > 1 files changed, 2 insertions(+), 0 deletions(-) > > diff --git a/drivers/input/touchscreen/ads7846.c b/drivers/input/touchscreen/ads7846.c > index f02028e..a82a5fb 100644 > --- a/drivers/input/touchscreen/ads7846.c > +++ b/drivers/input/touchscreen/ads7846.c > @@ -61,6 +61,7 @@ > > /* this driver doesn't aim at the peak continuous sample rate */ > #define SAMPLE_BITS (8 /*cmd*/ + 16 /*sample*/ + 2 /* before, after */) > +#define DEBOUNCE_TIME 310 /* About 10 ms */ I think hard coding this value is wrong. Can't it be derived from the pdata->debounce_* fields? > > struct ts_event { > /* > @@ -980,6 +981,7 @@ static int __devinit ads7846_setup_pendown(struct spi_device *spi, struct ads784 > } > > ts->gpio_pendown = pdata->gpio_pendown; > + gpio_set_debounce(pdata->gpio_pendown, DEBOUNCE_TIME); > > } else { > dev_err(&spi->dev, "no get_pendown_state nor gpio_pendown?\n"); -- Regards, Igor. ^ permalink raw reply [flat|nested] 3+ messages in thread
* Re: [PATCH 5/5] Input: ads7846: set proper debounce time in driver level 2012-06-11 14:37 ` [PATCH 5/5] Input: ads7846: set proper debounce time in driver level Igor Grinberg @ 2012-06-12 2:49 ` Zumeng Chen 2012-06-12 7:53 ` Igor Grinberg 0 siblings, 1 reply; 3+ messages in thread From: Zumeng Chen @ 2012-06-12 2:49 UTC (permalink / raw) To: Igor Grinberg Cc: khilman, zumeng.chen, tony, Dmitry Torokhov, Vaibhav Hiremath, ajay.gupta, khasim, linux-input@vger.kernel.org, linux-omap, linux-arm-kernel [-- Attachment #1.1: Type: text/plain, Size: 3265 bytes --] 2012/6/11 Igor Grinberg <grinberg@compulab.co.il> > Hi, > > This is input subsystem, add Dmitry and linux-input. > > On 06/11/12 17:00, Zumeng Chen wrote: > > If we don't set proper debouce time for ads7846, then there are > > flooded interrupt counters of ads7846 responding to one time > > touch on screen, so the driver couldn't work well. > > > > And since most OMAP3 series boards pass NULL pointer of board_pdata > > to omap_ads7846_init, so it's more proper to set it in driver level > > after having gpio_request done. > > What about other non-OMAP platforms? > Good point, I thought it should be the same situation, and I have no other boards to validate it :) Then I'll fall back on my original patch to bracket them with OMAP3EVM > > NULL pointer for board_pdata, only means that the default pdata is used. > Please, see the common-board-devices.c file more closely. > Yes, I just went through again, two points: 1 ) get_pendown_state is not set for OMAP3 boards, and the state will be get by gpio_get_value(gpio-omap.c) The second path will be available in the ads7846_setup_pendown if (pdata->get_pendown_state) { ts->get_pendown_state = pdata->get_pendown_state; } else if (gpio_is_valid(pdata->gpio_pendown)) { 2 ) All omap3 boards set gpio_pendown for pdata. So it had better we set_debounce in driver level after gpio_request_one having done I'll remove DEBOUNCE_TIME in V2 and change into like following: +#ifdef CONFIG_MACH_OMAP3EVM + /* 310 means 10 microsecond for omap3 */ + gpio_set_debounce(pdata->gpio_pendown, 310); +#endif > > > > This patch has been validated on 3530evm. > > > > Signed-off-by: Zumeng Chen <zumeng.chen@gmail.com> > > Signed-off-by: Syed Mohammed Khasim <khasim@ti.com> > > Signed-off-by: Tony Lindgren <tony@atomide.com> > > --- > > drivers/input/touchscreen/ads7846.c | 2 ++ > > 1 files changed, 2 insertions(+), 0 deletions(-) > > > > diff --git a/drivers/input/touchscreen/ads7846.c > b/drivers/input/touchscreen/ads7846.c > > index f02028e..a82a5fb 100644 > > --- a/drivers/input/touchscreen/ads7846.c > > +++ b/drivers/input/touchscreen/ads7846.c > > @@ -61,6 +61,7 @@ > > > > /* this driver doesn't aim at the peak continuous sample rate */ > > #define SAMPLE_BITS (8 /*cmd*/ + 16 /*sample*/ + 2 /* before, > after */) > > +#define DEBOUNCE_TIME 310 /* About 10 ms */ > > I think hard coding this value is wrong. > Yes, me too. > Can't it be derived from the pdata->debounce_* fields? > Yes, I agreed this way, and to be honest, my first choice is to find if there is a member for debounce, but no. And there is no more sense to derive it from debounce_max, although which is the right value for us. So I have to use the hardcode here. Regards, Zumeng > > > > struct ts_event { > > /* > > @@ -980,6 +981,7 @@ static int __devinit ads7846_setup_pendown(struct > spi_device *spi, struct ads784 > > } > > > > ts->gpio_pendown = pdata->gpio_pendown; > > + gpio_set_debounce(pdata->gpio_pendown, DEBOUNCE_TIME); > > > > } else { > > dev_err(&spi->dev, "no get_pendown_state nor > gpio_pendown?\n"); > > -- > Regards, > Igor. > [-- Attachment #1.2: Type: text/html, Size: 4770 bytes --] [-- Attachment #2: Type: text/plain, Size: 176 bytes --] _______________________________________________ linux-arm-kernel mailing list linux-arm-kernel@lists.infradead.org http://lists.infradead.org/mailman/listinfo/linux-arm-kernel ^ permalink raw reply [flat|nested] 3+ messages in thread
* Re: [PATCH 5/5] Input: ads7846: set proper debounce time in driver level 2012-06-12 2:49 ` Zumeng Chen @ 2012-06-12 7:53 ` Igor Grinberg 0 siblings, 0 replies; 3+ messages in thread From: Igor Grinberg @ 2012-06-12 7:53 UTC (permalink / raw) To: Zumeng Chen Cc: khilman, tony, Dmitry Torokhov, Vaibhav Hiremath, ajay.gupta, khasim, linux-input@vger.kernel.org, linux-omap, linux-arm-kernel On 06/12/12 05:49, Zumeng Chen wrote: > > > 2012/6/11 Igor Grinberg <grinberg@compulab.co.il <mailto:grinberg@compulab.co.il>> > > Hi, > > This is input subsystem, add Dmitry and linux-input. > > On 06/11/12 17:00, Zumeng Chen wrote: > > If we don't set proper debouce time for ads7846, then there are > > flooded interrupt counters of ads7846 responding to one time > > touch on screen, so the driver couldn't work well. > > > > And since most OMAP3 series boards pass NULL pointer of board_pdata > > to omap_ads7846_init, so it's more proper to set it in driver level > > after having gpio_request done. > > What about other non-OMAP platforms? > > Good point, I thought it should be the same situation, and I have no other boards > to validate it :) Then I'll fall back on my original patch to bracket them with OMAP3EVM This isn't a good solution either... > > > NULL pointer for board_pdata, only means that the default pdata is used. > Please, see the common-board-devices.c file more closely. > > Yes, I just went through again, two points: > > 1 ) get_pendown_state is not set for OMAP3 boards, and the state You can supply your own pdata and provide the get_pendown_state() callback. > will be get by gpio_get_value(gpio-omap.c) > The second path will be available in the ads7846_setup_pendown > if (pdata->get_pendown_state) { > ts->get_pendown_state = pdata->get_pendown_state; > } else if (gpio_is_valid(pdata->gpio_pendown)) { > > 2 ) All omap3 boards set gpio_pendown for pdata. > So it had better we set_debounce in driver level after gpio_request_one > having done > I'll remove DEBOUNCE_TIME in V2 and change into like following: > > +#ifdef CONFIG_MACH_OMAP3EVM > + /* 310 means 10 microsecond for omap3 */ > + gpio_set_debounce(pdata->gpio_pendown, 310); > +#endif I don't think this kind of fix is acceptable... > > > > > > This patch has been validated on 3530evm. > > > > Signed-off-by: Zumeng Chen <zumeng.chen@gmail.com <mailto:zumeng.chen@gmail.com>> > > Signed-off-by: Syed Mohammed Khasim <khasim@ti.com <mailto:khasim@ti.com>> > > Signed-off-by: Tony Lindgren <tony@atomide.com <mailto:tony@atomide.com>> > > --- > > drivers/input/touchscreen/ads7846.c | 2 ++ > > 1 files changed, 2 insertions(+), 0 deletions(-) > > > > diff --git a/drivers/input/touchscreen/ads7846.c b/drivers/input/touchscreen/ads7846.c > > index f02028e..a82a5fb 100644 > > --- a/drivers/input/touchscreen/ads7846.c > > +++ b/drivers/input/touchscreen/ads7846.c > > @@ -61,6 +61,7 @@ > > > > /* this driver doesn't aim at the peak continuous sample rate */ > > #define SAMPLE_BITS (8 /*cmd*/ + 16 /*sample*/ + 2 /* before, after */) > > +#define DEBOUNCE_TIME 310 /* About 10 ms */ > > I think hard coding this value is wrong. > > Yes, me too. > > Can't it be derived from the pdata->debounce_* fields? > > Yes, I agreed this way, and to be honest, my first choice > is to find if there is a member for debounce, but no. And > there is no more sense to derive it from debounce_max, > although which is the right value for us. It makes sense to me... Why do you think there is no sense? -- Regards, Igor. ^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2012-06-12 7:53 UTC | newest] Thread overview: 3+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- [not found] <1339423216-1323-1-git-send-email-zumeng.chen@gmail.com> [not found] ` <1339423216-1323-6-git-send-email-zumeng.chen@gmail.com> 2012-06-11 14:37 ` [PATCH 5/5] Input: ads7846: set proper debounce time in driver level Igor Grinberg 2012-06-12 2:49 ` Zumeng Chen 2012-06-12 7:53 ` Igor Grinberg
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox; as well as URLs for NNTP newsgroup(s).