From: Dmitry Torokhov <dtor@chromium.org>
To: Henrik Rydberg <rydberg@bitmath.org>
Cc: Wei-Ning Huang <wnhuang@chromium.org>,
LKML <linux-kernel@vger.kernel.org>,
Linux Input <linux-input@vger.kernel.org>,
Dmitry Torokhov <dtor@chromium.org>,
Jiri Kosina <jikos@kernel.org>,
Benjamin Tissoires <benjamin.tissoires@redhat.com>
Subject: Re: [PATCH v4] HID: hid-multitouch: support fine-grain orientation reporting
Date: Tue, 10 Oct 2017 09:25:48 -0700 [thread overview]
Message-ID: <CAE_wzQ_jPP54_1GgEuPZWHjs57=owTTP35ygO6dafYmxgDZYPQ@mail.gmail.com> (raw)
In-Reply-To: <20171010065740.GA22909@mars.bitmath.org>
On Mon, Oct 9, 2017 at 11:57 PM, Henrik Rydberg <rydberg@bitmath.org> wrote:
> Hi Wei-Ning,
>
>> The current hid-multitouch driver only allow the report of two
>> orientations, vertical and horizontal. We use the Azimuth orientation
>> usage 0x3F under the Digitizer usage page to report orientation if the
>> device supports it.
>>
>> Changelog:
>> v1 -> v2:
>> - Fix commit message.
>> - Remove resolution reporting for ABS_MT_ORIENTATION.
>> v2 -> v3:
>> - Fix commit message.
>> v3 -> v4:
>> - Fix ABS_MT_ORIENTATION ABS param range.
>> - Don't set ABS_MT_ORIENTATION in ABS_DG_HEIGHT when it is already
>> set by ABS_DG_AZIMUTH.
>>
>> Signed-off-by: Wei-Ning Huang <wnhuang@chromium.org>
>> Reviewed-by: Dmitry Torokhov <dtor@chromium.org>
>> ---
>> drivers/hid/hid-multitouch.c | 52 ++++++++++++++++++++++++++++++++++++++++----
>> include/linux/hid.h | 1 +
>> 2 files changed, 49 insertions(+), 4 deletions(-)
>>
>> diff --git a/drivers/hid/hid-multitouch.c b/drivers/hid/hid-multitouch.c
>> index 440b999304a5..3317dae64ef7 100644
>> --- a/drivers/hid/hid-multitouch.c
>> +++ b/drivers/hid/hid-multitouch.c
>> @@ -84,11 +84,12 @@ MODULE_LICENSE("GPL");
>> #define MT_IO_FLAGS_PENDING_SLOTS 2
>>
>> struct mt_slot {
>> - __s32 x, y, cx, cy, p, w, h;
>> + __s32 x, y, cx, cy, p, w, h, a;
>> __s32 contactid; /* the device ContactID assigned to this slot */
>> bool touch_state; /* is the touch valid? */
>> bool inrange_state; /* is the finger in proximity of the sensor? */
>> bool confidence_state; /* is the touch made by a finger? */
>> + bool has_azimuth; /* the contact reports azimuth */
>> };
>>
>> struct mt_class {
>> @@ -571,8 +572,15 @@ static int mt_touch_input_mapping(struct hid_device *hdev, struct hid_input *hi,
>> if (!(cls->quirks & MT_QUIRK_NO_AREA)) {
>> set_abs(hi->input, ABS_MT_TOUCH_MINOR, field,
>> cls->sn_height);
>> - input_set_abs_params(hi->input,
>> - ABS_MT_ORIENTATION, 0, 1, 0, 0);
>> +
>> + /*
>> + * Only set ABS_MT_ORIENTATION if it is not
>> + * already set by the HID_DG_AZIMUTH usage.
>> + */
>> + if (!test_bit(ABS_MT_ORIENTATION,
>> + hi->input->absbit))
>> + input_set_abs_params(hi->input,
>> + ABS_MT_ORIENTATION, 0, 1, 0, 0);
>> }
>> mt_store_field(usage, td, hi);
>> return 1;
>> @@ -591,6 +599,21 @@ static int mt_touch_input_mapping(struct hid_device *hdev, struct hid_input *hi,
>> td->cc_index = field->index;
>> td->cc_value_index = usage->usage_index;
>> return 1;
>> + case HID_DG_AZIMUTH:
>> + hid_map_usage(hi, usage, bit, max,
>> + EV_ABS, ABS_MT_ORIENTATION);
>> + /*
>> + * Azimuth has the range of [0, MAX) representing a full
>> + * revolution. Set ABS_MT_ORIENTATION to a quarter of
>> + * MAX according the definition of ABS_MT_ORIENTATION
>> + */
>> + input_set_abs_params(hi->input, ABS_MT_ORIENTATION,
>> + -field->logical_maximum / 4,
>> + field->logical_maximum / 4,
So do we expect userspace to have special handling for the range when
"min" is negative? I.e. when range is [0,1] it is understood that we
are reporting the first quadrant only, with 0 reported when finger is
roughly vertical and 1 is when it is horizontal. Similarly, the range
[0-90] would describe the 1st quadrant as well. This matches the
in-kernel documentation. However here we have [-90, 90] that describes
2 quadrants. Do we want to keep it as is and have userspace adapt (we
probably will need a patch to multi-touch-protocol.txt), or should
this be:
input_set_abs_params(hi->input, ABS_MT_ORIENTATION, 0,
field->logical_maximum / 4, ...);
and userspace should be able to handle reported negative events and
have them being understood as going counter-clockwise into the 4th and
then 3rd quadrant?
Thanks,
Dmitry
next prev parent reply other threads:[~2017-10-10 16:25 UTC|newest]
Thread overview: 9+ messages / expand[flat|nested] mbox.gz Atom feed top
2017-10-10 4:16 [PATCH v4] HID: hid-multitouch: support fine-grain orientation reporting Wei-Ning Huang
2017-10-10 6:57 ` Henrik Rydberg
2017-10-10 16:25 ` Dmitry Torokhov [this message]
2017-10-11 8:54 ` Benjamin Tissoires
2017-10-11 13:30 ` Jiri Kosina
2017-10-11 13:53 ` Benjamin Tissoires
2017-10-11 20:43 ` Henrik Rydberg
2017-10-11 22:24 ` Peter Hutterer
2017-10-10 7:40 ` Benjamin Tissoires
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='CAE_wzQ_jPP54_1GgEuPZWHjs57=owTTP35ygO6dafYmxgDZYPQ@mail.gmail.com' \
--to=dtor@chromium.org \
--cc=benjamin.tissoires@redhat.com \
--cc=jikos@kernel.org \
--cc=linux-input@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=rydberg@bitmath.org \
--cc=wnhuang@chromium.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 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).