HID: input: Set INPUT_PROP_-property for HID_UP_DIGITIZERS
authorTatsunosuke Tobita <junkpainting@gmail.com>
Wed, 8 Aug 2018 00:31:43 +0000 (09:31 +0900)
committerJiri Kosina <jkosina@suse.cz>
Wed, 5 Sep 2018 14:59:24 +0000 (16:59 +0200)
Some system may want to know if a detected digitizer device is either an
integrated or an external device.  In order to distinguish such condition,
setting either INPUT_PROP_DIRECT or INPUT_PROP_POINTER is required,
checking the member, "application", in "hid_field" structure.

Signed-off-by: Tatsunosuke Tobita <tobita.tatsunosuke@wacom.co.jp>
Reviewed-by: Ping Cheng <ping.cheng@wacom.com>
Signed-off-by: Jiri Kosina <jkosina@suse.cz>
drivers/hid/hid-input.c

index 83755ba33ef44af0bff1fb44713f16d90a88e8a7..42c1a4c2a978dab5a7fc7de33b728b8f43e304d5 100644 (file)
@@ -758,6 +758,11 @@ static void hidinput_configure_usage(struct hid_input *hidinput, struct hid_fiel
                break;
 
        case HID_UP_DIGITIZER:
+               if ((field->application & 0xff) == 0x01) /* Digitizer */
+                       __set_bit(INPUT_PROP_POINTER, input->propbit);
+               else if ((field->application & 0xff) == 0x02) /* Pen */
+                       __set_bit(INPUT_PROP_DIRECT, input->propbit);
+
                switch (usage->hid & 0xff) {
                case 0x00: /* Undefined */
                        goto ignore;