From: Rolf Eike Beer <eike-kernel@sf-tec.de>
To: Dmitry Torokhov <dmitry.torokhov@gmail.com>, linux-input@vger.kernel.org
Subject: Re: ABS_PRESSURE and 0 ranges
Date: Thu, 25 Oct 2012 23:45:18 +0200 [thread overview]
Message-ID: <2136905.J2mg6vAfqB@donald.sf-tec.de> (raw)
In-Reply-To: <2450762.pYR3zhxxMr@dtor-d630.eng.vmware.com>
[-- Attachment #1: Type: text/plain, Size: 2276 bytes --]
You wrote:
> On Thursday, October 25, 2012 10:11:27 PM Rolf Eike Beer wrote:
> > You wrote:
> > > Hi Rolf,
> > >
> > > On Thu, Oct 25, 2012 at 02:59:49PM +0200, Rolf Eike Beer wrote:
> > > > Hi all,
> > > >
> > > > as I found out the hard way tslib does the detection if a touchscreen
> > > > has
> > > > been "clicked" if the kernel driver says it does not support
> > > > ABS_PRESSURE. But when the kernel says it can do ABS_PRESSURE tslib
> > > > will
> > > > not do it's emulation and just pass on whatever pressure value the
> > > > kernel
> > > > sends.
> > > >
> > > > So far, so good. Sadly there are some drivers that do:
> > > >
> > > > input_set_abs_params(dev, ABS_PRESSURE, 0, 0, 0, 0);
> > >
> > > What drivers are doing this?
> >
> > git grep 'ABS_PRESSURE, 0, 0, 0, 0' drivers/input/
> >
> > > > Guess what happens: no clicks at all. The question I have is: does the
> > > > above line make any sense to be in a kernel driver at all? Or is that
> > > > some voodoo that must be there and it's all tslib fault?
> > > >
> > > > Now that I know where the problem is coming from the problem is easily
> > > > fixable, I'm just wondering which patch to make.
> > >
> > > Well, the limits are strictly advisory for userspace, input core does
> > > not perform any clamping or discarding the data that falls outside the
> > > limits, so tslib probably should not do that either.
> >
> > My main concern is that if the driver says it will only ever give pressure
> > values from 0 to 0, what useful stuff may that ever be? And since the
> > driver says it supports presure touchscreen will wait for the driver to
> > report it. Since it will never do it (or could at most return a 0), then
> > there is nothing that could ever become a valid click event.
>
> Once again, the limits are simply advisory and can even be adjusted from
> userspace (EVIOCSABS).
>
> So ucb1400_ts does report true pressure so all is good there, but tsc40 is
> not. I think the claim for ABS_PRESSURE is left over from time when tslib
> did not think that device without ABS_PRESSURE was a touchscreen. I'll
> remove it from the driver.
Thanks, so I know what part to patch. Please backport that to stable, too, so
tslib will work with that driver even on stable kernels.
Eike
[-- Attachment #2: This is a digitally signed message part. --]
[-- Type: application/pgp-signature, Size: 198 bytes --]
prev parent reply other threads:[~2012-10-25 21:45 UTC|newest]
Thread overview: 5+ messages / expand[flat|nested] mbox.gz Atom feed top
2012-10-25 12:59 ABS_PRESSURE and 0 ranges Rolf Eike Beer
2012-10-25 18:34 ` Dmitry Torokhov
2012-10-25 20:11 ` Rolf Eike Beer
2012-10-25 20:51 ` Dmitry Torokhov
2012-10-25 21:45 ` Rolf Eike Beer [this message]
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=2136905.J2mg6vAfqB@donald.sf-tec.de \
--to=eike-kernel@sf-tec.de \
--cc=dmitry.torokhov@gmail.com \
--cc=linux-input@vger.kernel.org \
/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.