aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJason Gerecke <killertofu@gmail.com>2016-10-19 21:03:44 -0400
committerJiri Kosina <jkosina@suse.cz>2016-10-20 03:53:57 -0400
commitb5c921e6c3916cdadd6e605d792f811abf7a5f82 (patch)
treea48d0f6c04eaba605ef8ea9bd71bc5b587f75bf1
parentc9c095874ab4446be6dec6755d8f68862fdeae48 (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.c4
-rw-r--r--drivers/hid/wacom_wac.h1
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)