aboutsummaryrefslogtreecommitdiffstats
path: root/drivers
diff options
context:
space:
mode:
Diffstat (limited to 'drivers')
-rw-r--r--drivers/hid/hid-wacom.c24
1 files changed, 24 insertions, 0 deletions
diff --git a/drivers/hid/hid-wacom.c b/drivers/hid/hid-wacom.c
index 3fc93869024e..694545d5bfea 100644
--- a/drivers/hid/hid-wacom.c
+++ b/drivers/hid/hid-wacom.c
@@ -36,6 +36,7 @@
36struct wacom_data { 36struct wacom_data {
37 __u16 tool; 37 __u16 tool;
38 __u16 butstate; 38 __u16 butstate;
39 __u8 whlstate;
39 __u8 features; 40 __u8 features;
40 __u32 id; 41 __u32 id;
41 __u32 serial; 42 __u32 serial;
@@ -322,6 +323,23 @@ static void wacom_i4_parse_button_report(struct wacom_data *wdata,
322 struct input_dev *input, unsigned char *data) 323 struct input_dev *input, unsigned char *data)
323{ 324{
324 __u16 new_butstate; 325 __u16 new_butstate;
326 __u8 new_whlstate;
327 __u8 sync = 0;
328
329 new_whlstate = data[1];
330 if (new_whlstate != wdata->whlstate) {
331 wdata->whlstate = new_whlstate;
332 if (new_whlstate & 0x80) {
333 input_report_key(input, BTN_TOUCH, 1);
334 input_report_abs(input, ABS_WHEEL, (new_whlstate & 0x7f));
335 input_report_key(input, BTN_TOOL_FINGER, 1);
336 } else {
337 input_report_key(input, BTN_TOUCH, 0);
338 input_report_abs(input, ABS_WHEEL, 0);
339 input_report_key(input, BTN_TOOL_FINGER, 0);
340 }
341 sync = 1;
342 }
325 343
326 new_butstate = (data[3] << 1) | (data[2] & 0x01); 344 new_butstate = (data[3] << 1) | (data[2] & 0x01);
327 if (new_butstate != wdata->butstate) { 345 if (new_butstate != wdata->butstate) {
@@ -336,6 +354,10 @@ static void wacom_i4_parse_button_report(struct wacom_data *wdata,
336 input_report_key(input, BTN_7, new_butstate & 0x080); 354 input_report_key(input, BTN_7, new_butstate & 0x080);
337 input_report_key(input, BTN_8, new_butstate & 0x100); 355 input_report_key(input, BTN_8, new_butstate & 0x100);
338 input_report_key(input, BTN_TOOL_FINGER, 1); 356 input_report_key(input, BTN_TOOL_FINGER, 1);
357 sync = 1;
358 }
359
360 if (sync) {
339 input_report_abs(input, ABS_MISC, PAD_DEVICE_ID); 361 input_report_abs(input, ABS_MISC, PAD_DEVICE_ID);
340 input_event(input, EV_MSC, MSC_SERIAL, 0xffffffff); 362 input_event(input, EV_MSC, MSC_SERIAL, 0xffffffff);
341 input_sync(input); 363 input_sync(input);
@@ -510,6 +532,7 @@ static int wacom_input_mapped(struct hid_device *hdev, struct hid_input *hi,
510 input_set_abs_params(input, ABS_DISTANCE, 0, 32, 0, 0); 532 input_set_abs_params(input, ABS_DISTANCE, 0, 32, 0, 0);
511 break; 533 break;
512 case USB_DEVICE_ID_WACOM_INTUOS4_BLUETOOTH: 534 case USB_DEVICE_ID_WACOM_INTUOS4_BLUETOOTH:
535 __set_bit(ABS_WHEEL, input->absbit);
513 __set_bit(ABS_MISC, input->absbit); 536 __set_bit(ABS_MISC, input->absbit);
514 __set_bit(BTN_2, input->keybit); 537 __set_bit(BTN_2, input->keybit);
515 __set_bit(BTN_3, input->keybit); 538 __set_bit(BTN_3, input->keybit);
@@ -518,6 +541,7 @@ static int wacom_input_mapped(struct hid_device *hdev, struct hid_input *hi,
518 __set_bit(BTN_6, input->keybit); 541 __set_bit(BTN_6, input->keybit);
519 __set_bit(BTN_7, input->keybit); 542 __set_bit(BTN_7, input->keybit);
520 __set_bit(BTN_8, input->keybit); 543 __set_bit(BTN_8, input->keybit);
544 input_set_abs_params(input, ABS_WHEEL, 0, 71, 0, 0);
521 input_set_abs_params(input, ABS_X, 0, 40640, 4, 0); 545 input_set_abs_params(input, ABS_X, 0, 40640, 4, 0);
522 input_set_abs_params(input, ABS_Y, 0, 25400, 4, 0); 546 input_set_abs_params(input, ABS_Y, 0, 25400, 4, 0);
523 input_set_abs_params(input, ABS_PRESSURE, 0, 2047, 0, 0); 547 input_set_abs_params(input, ABS_PRESSURE, 0, 2047, 0, 0);