[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20110706174503.GA5695@core.coreip.homeip.net>
Date: Wed, 6 Jul 2011 10:45:03 -0700
From: Dmitry Torokhov <dmitry.torokhov@...il.com>
To: Daniel Kurtz <djkurtz@...omium.org>
Cc: Henrik Rydberg <rydberg@...omail.se>, chase.douglas@...onical.com,
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 09/12] Input: synaptics - add image sensor support
On Thu, Jul 07, 2011 at 12:41:26AM +0800, Daniel Kurtz wrote:
> On Wed, Jul 6, 2011 at 3:27 AM, Henrik Rydberg <rydberg@...omail.se> wrote:
> >> ...
> >> This implementation addresses the following issues:
> >>
> >> (1) Improves handling of the 2-finger case. Image sensors due allow
> >> true MT-B for two finger case. This, for example, allows detecting
> >> whether the click in a click+drag is happening in bottom right or
> >> bottom left quadrant of the pad.
> >
> > In principle, this could be done within the semi-mt realm by adding a
> > binary value to the protocol, distinguishing the diagonals of the
> > bounding box. It would be ugly too, but at least it would be
> > compatible with the current semi-mt effort in userspace.
>
> (A) I think the "semi-mt" protocol works like this:
> (1) When two or more fingers are on the pad, report two MT-B slots, where:
> (a) slot[0] contains (x_min, y_min) of the two fingers
> (b) slot[1] contains (x_max, y_max) of the two fingers
> (c) Total number of fingers on pad is indicated by EV_KEY/BTN_TOOL_* is set.
> (2) If one of the two fingers is removed, then the first slot is
> used to report
> the remaining finger, whichever it is, without changing the
> slot's tracking_id.
> (3) Advertise this behavior with the SEMI_MT device property
>
> (B) This is what the proposed T5R2 driver does:
> (1) When N fingers are on the pad, report N MT-B slots, where:
> (a) The lowest indexed active slot (tracking_id != -1) contains
> valid finger position data.
> (b) The highest indexed active slot (tracking_id != -1) contains
> valid finger position data.
> (c) Any active slots (tracking_id != -1) between these does not
> contain valid finger position data, these 'hidden' slots are just
> active to indicate that there are that many fingers on the pad.
> (d) Total number of fingers on the pad is always the number of active slots.
> (2) When fingers are removed from the pad:
> (a) keep reporting the fingers that are left in the same slots,
> with the same tracking_ids, if possible.
> (b) If the identities of the fingers that remain is ambiguous,
> invalidate all slots,then re-assign the fingers that remain to new
> slots, with new tracking ids.
> (3) Advertise this behavior with the T5R2 device property
>
This is a no-go. I do not want to add TxRy or similar "properties". We
have a workable semi-mt (counding box) and full mt concepts and we
should present userspace with data stream that conforms either one or
another.
> (C) A third, compromise implementation might be to do something like this:
> (1) When >=2 fingers are on the pad, report 2 MT-B slots, where:
> (a) slot[0] reports finger 1
> (b) slot[1] reports finger 2
> (c) Total number of fingers on pad is indicated by EV_KEY/BTN_TOOL_* is set.
> (2) If 1 finger is removed, the tracking_id for its slot is invalidated;
> but, the finger that remains stays in its same slot with the
> same tracking_id.
> (3) Whenever the number of fingers changes from/to 3 or more
> fingers, both slots are always invalidated.
> New tracking_ids are assigned to both slots which contain the
> two fingers now being reported.
> (4) No special driver property is required for this, not even "semi-mt".
> It should be as pure MT-B as we can get (plus BTN_TOOL_* hack).
>
This is the best option in my opinion. We will present 2 finger position
data plus extended finger count.
Thanks.
--
Dmitry
--
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