[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <CAGS+omCfw3CQ8z6iS3QQx7hZs1e8kOpC1-L1SFsGQv0RdmAMqg@mail.gmail.com>
Date: Wed, 29 Jun 2011 19:04:45 +0800
From: Daniel Kurtz <djkurtz@...omium.org>
To: Chase Douglas <chase.douglas@...onical.com>
Cc: dmitry.torokhov@...il.com, rydberg@...omail.se,
rubini@...l.unipv.it, linux-input@...r.kernel.org,
linux-kernel@...r.kernel.org, derek.foreman@...labora.co.uk,
daniel.stone@...labora.co.uk, olofj@...omium.org
Subject: Re: [PATCH 10/12] Input: synaptics - decode AGM packet types
Hi Chase,
Thanks for looking at the patches!
On Wed, Jun 29, 2011 at 6:02 PM, Chase Douglas
<chase.douglas@...onical.com> wrote:
>
> On 06/29/2011 06:07 AM, djkurtz@...omium.org wrote:
> > From: Daniel Kurtz <djkurtz@...omium.org>
> >
> > A Synaptics image sensor tracks 5 fingers, but can only report 2.
> > This behavior is called "T5R2" = Track 5 Report 2
> >
> > Algorithm for choosing which 2 fingers to report in which packet:
> > Touchpad maintains 5 slots, numbered 0 to 4.
> > Initially all slots are empty.
> > As new fingers are detected, they are assigned the lowest available
> > slot.
> > Touchpad always reports:
> > SGM: lowest numbered non-empty slot
> > AGM: highest numbered non-empty slot, if there is one.
>
> Hi Daniel,
>
> Thanks for the new patches! I will review them soon in detail, but I
> would like to first confirm some details about the above.
>
> In the older "profile" devices, we got essentially the bounding box of
> all touches. This allows us to detect pinch gestures between the two
> most extreme touches when there are three touches on the touchpad.
>
> The above description makes it sound like we will no longer have a
> bounding box of touches. According to the description, if I put four
> fingers down in a square formation and then touch a fifth finger in the
> middle of the square, I will only see the locations of one corner and
> the middle of the square. This would make meaningful gesture detection
> beyond two touches nearly impossible. Is this really how the touchpad
> works, or is the above description not quite right?
This is how the image sensor works, from my observations.
As for profile sensors the kernel driver creates a "best guess
bounding box" by picking:
top_left = (min(x1,x2), min(y1,y2))
bottom_right = (max(x1,x2), max(y1,y2))
However, at least from my experiments with one profile sensor, there
is no guarantee that this rectangle actually contains all touches on
the pad.
In fact, I think it is trying really hard to return the position of
the first two touches that it is tracking.
When there are two fingers, it returns the finger with the larger
y-value (and what the trackpad believes to be its x-), and the SGM
packet, and the other finger in the AGM.
When there are three or more fingers, it still reports the first two,
irregardless of where the new fingers are added.
It would be very curious if different profile sensors behaved differently.
In any case, this patch should not change the behavior of profile
sensors, since it only applies to image sensors.
Thanks,
-Daniel
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists