diff options
author | Jason Gerecke <killertofu@gmail.com> | 2016-10-19 21:03:44 -0400 |
---|---|---|
committer | Jiri Kosina <jkosina@suse.cz> | 2016-10-20 03:53:57 -0400 |
commit | b5c921e6c3916cdadd6e605d792f811abf7a5f82 (patch) | |
tree | a48d0f6c04eaba605ef8ea9bd71bc5b587f75bf1 | |
parent | c9c095874ab4446be6dec6755d8f68862fdeae48 (diff) |
HID: wacom: generic: Add support for vendor-defined "Distance" usage
The vendor-defined 0xFF0D01032 ("Distance") usage is nearly equivalent to
HID_GD_Z, except that the axis direction is inverted. Unlike HID_GD_Z which
increases in value as the pen-to-surface distance is decreased, this usage
decreases. Treat this usage as a special case to ensure we don't invert the
scale to be ABS_DISTANCE compatible like we do for HID_GD_Z.
Signed-off-by: Jason Gerecke <jason.gerecke@wacom.com>
Reviewed-by: Benjamin Tissoires <benjamin.tissoires@redhat.com>
Signed-off-by: Jiri Kosina <jkosina@suse.cz>
-rw-r--r-- | drivers/hid/wacom_wac.c | 4 | ||||
-rw-r--r-- | drivers/hid/wacom_wac.h | 1 |
2 files changed, 4 insertions, 1 deletions
diff --git a/drivers/hid/wacom_wac.c b/drivers/hid/wacom_wac.c index 6c2f0e4baf7d..f78ad77d9ed7 100644 --- a/drivers/hid/wacom_wac.c +++ b/drivers/hid/wacom_wac.c | |||
@@ -1442,7 +1442,8 @@ static int wacom_equivalent_usage(int usage) | |||
1442 | int subusage = (usage & 0xFF); | 1442 | int subusage = (usage & 0xFF); |
1443 | 1443 | ||
1444 | if (subpage == WACOM_HID_SP_DIGITIZER || | 1444 | if (subpage == WACOM_HID_SP_DIGITIZER || |
1445 | subpage == WACOM_HID_SP_DIGITIZERINFO) { | 1445 | subpage == WACOM_HID_SP_DIGITIZERINFO || |
1446 | usage == WACOM_HID_WD_DISTANCE) { | ||
1446 | return usage; | 1447 | return usage; |
1447 | } | 1448 | } |
1448 | 1449 | ||
@@ -1502,6 +1503,7 @@ static void wacom_wac_pen_usage_mapping(struct hid_device *hdev, | |||
1502 | case HID_GD_Y: | 1503 | case HID_GD_Y: |
1503 | wacom_map_usage(input, usage, field, EV_ABS, ABS_Y, 4); | 1504 | wacom_map_usage(input, usage, field, EV_ABS, ABS_Y, 4); |
1504 | break; | 1505 | break; |
1506 | case WACOM_HID_WD_DISTANCE: | ||
1505 | case HID_GD_Z: | 1507 | case HID_GD_Z: |
1506 | wacom_map_usage(input, usage, field, EV_ABS, ABS_DISTANCE, 0); | 1508 | wacom_map_usage(input, usage, field, EV_ABS, ABS_DISTANCE, 0); |
1507 | break; | 1509 | break; |
diff --git a/drivers/hid/wacom_wac.h b/drivers/hid/wacom_wac.h index ba914bad971f..63a5a2586707 100644 --- a/drivers/hid/wacom_wac.h +++ b/drivers/hid/wacom_wac.h | |||
@@ -88,6 +88,7 @@ | |||
88 | #define WACOM_HID_SP_DIGITIZER 0x000d0000 | 88 | #define WACOM_HID_SP_DIGITIZER 0x000d0000 |
89 | #define WACOM_HID_SP_DIGITIZERINFO 0x00100000 | 89 | #define WACOM_HID_SP_DIGITIZERINFO 0x00100000 |
90 | #define WACOM_HID_WD_DIGITIZER (WACOM_HID_UP_WACOMDIGITIZER | 0x01) | 90 | #define WACOM_HID_WD_DIGITIZER (WACOM_HID_UP_WACOMDIGITIZER | 0x01) |
91 | #define WACOM_HID_WD_DISTANCE (WACOM_HID_UP_WACOMDIGITIZER | 0x0132) | ||
91 | #define WACOM_HID_WD_DATAMODE (WACOM_HID_UP_WACOMDIGITIZER | 0x1002) | 92 | #define WACOM_HID_WD_DATAMODE (WACOM_HID_UP_WACOMDIGITIZER | 0x1002) |
92 | #define WACOM_HID_UP_G9 0xff090000 | 93 | #define WACOM_HID_UP_G9 0xff090000 |
93 | #define WACOM_HID_G9_PEN (WACOM_HID_UP_G9 | 0x02) | 94 | #define WACOM_HID_G9_PEN (WACOM_HID_UP_G9 | 0x02) |