All of lore.kernel.org
 help / color / mirror / Atom feed
From: Alek Du <alek.du@intel.com>
To: Jani Nikula <ext-jani.1.nikula@nokia.com>
Cc: LKML <linux-kernel@vger.kernel.org>,
	Trilok Soni <soni.trilok@gmail.com>,
	"linux-input@vger.kernel.org" <linux-input@vger.kernel.org>,
	Dmitry Torokhov <dmitry.torokhov@gmail.com>,
	"ben-linux@fluff.org" <ben-linux@fluff.org>
Subject: Re: [PATCH]input: Change timer function to workqueue for gpio_keys driver
Date: Thu, 25 Jun 2009 23:09:49 +0800	[thread overview]
Message-ID: <20090625230949.53beda65@dxy.sh.intel.com> (raw)
In-Reply-To: <1245942355.20530.141.camel@jani-desktop>

On Thu, 25 Jun 2009 23:05:55 +0800
Jani Nikula <ext-jani.1.nikula@nokia.com> wrote:

> On Thu, 2009-06-25 at 16:52 +0200, Jani Nikula wrote:
> > On Thu, 2009-06-25 at 16:08 +0200, ext Alek Du wrote:
> > > If you schedule the timer when you decide it "stabilized", the final gpio_get_value()
> > > could still return 0 in the timer handler, if the key released at that time. So your previous
> > > "stabilized" state is useless.
> > 
> > True, gpio_keys_report_event should also compare the value to the
> > previous state and bail out if it's unchanged. Something along the lines
> > of:
> > 
> > @@ -46,6 +46,10 @@ static void gpio_keys_report_event(struct work_struct *work)
> >  	unsigned int type = button->type ?: EV_KEY;
> >  	int state = (gpio_get_value(button->gpio) ? 1 : 0) ^ button->active_low;
> >  
> > +	if (state == bdata->state)
> > +		return;
> > +	bdata->state = state; 
> 
> Actually scrap that, the input layer already ignores events with no
> state changes, right?
> 
Yes, correct. I just want to reply your previous mail, but seems you find that. :-)
> > Debouncing should also completely ignore a single spike shorter than
> > debounce_interval. Admittedly gpio-keys was flawed, but please consider
> > a change like above which should fix that.
> 
> Same here, gpio-keys did ignore spikes shorter than debounce_interval.
> 
Yes, sending first state 0 to input layer does nothing wrong. 
> 
> BR,
> Jani.
> 
> 

  reply	other threads:[~2009-06-25 15:14 UTC|newest]

Thread overview: 30+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2009-06-08  7:24 [PATCH]input: Change timer function to workqueue for gpio_keys driver Alek Du
2009-06-12 17:40 ` Trilok Soni
2009-06-12 17:40   ` Trilok Soni
2009-06-25 10:29   ` Jani Nikula
2009-06-25 10:29     ` Jani Nikula
2009-06-25 13:06     ` Alek Du
2009-06-25 13:06       ` Alek Du
2009-06-25 13:31       ` Jani Nikula
2009-06-25 14:08         ` Alek Du
2009-06-25 14:52           ` Jani Nikula
2009-06-25 15:05             ` Jani Nikula
2009-06-25 15:09               ` Alek Du [this message]
2009-06-25 15:42                 ` Jani Nikula
2009-06-25 15:48                   ` Alek Du
2009-06-25 16:09                     ` Phil Carmody
2009-06-25 16:23                       ` Alek Du
2009-06-25 16:42                         ` Dmitry Torokhov
2009-06-25 16:42                           ` Dmitry Torokhov
2009-06-26 12:15                         ` [PATCH 0/2] fix gpio-keys debouncing and timer sleep issues Jani Nikula
2009-06-26 12:15                           ` [PATCH 1/2] Revert "Input: gpio-keys - change timer to workqueue" Jani Nikula
2009-06-26 12:15                           ` [PATCH 2/2] input: gpio-keys: avoid possibility of sleeping in timer function Jani Nikula
2009-06-29 10:30                             ` Alek Du
2009-06-29 10:30                               ` Alek Du
2009-06-26 12:50                           ` [PATCH 0/2] fix gpio-keys debouncing and timer sleep issues Du, Alek
2009-06-26 12:50                             ` Du, Alek
2009-06-29  5:59                           ` Dmitry Torokhov
2009-06-29 10:32                             ` Jani Nikula
  -- strict thread matches above, loose matches on Subject: below --
2009-06-08  5:54 [PATCH] input: Change timer function to workqueue for gpio_keys driver Alek Du
2009-06-08  6:04 ` Trilok Soni
2009-06-08  6:04   ` Trilok Soni

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20090625230949.53beda65@dxy.sh.intel.com \
    --to=alek.du@intel.com \
    --cc=ben-linux@fluff.org \
    --cc=dmitry.torokhov@gmail.com \
    --cc=ext-jani.1.nikula@nokia.com \
    --cc=linux-input@vger.kernel.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=soni.trilok@gmail.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.