diff options
author | Jason Gerecke <killertofu@gmail.com> | 2012-10-03 20:25:35 -0400 |
---|---|---|
committer | Dmitry Torokhov <dmitry.torokhov@gmail.com> | 2012-10-05 02:09:32 -0400 |
commit | fe494bc2f6e47f02a78ec4761117187db40381a6 (patch) | |
tree | 05d31e702033a0b7a68f468097a8e9f086a9f246 /drivers | |
parent | 115d5e12a7d5fe62076f9dcc728905196162d709 (diff) |
Input: wacom - clean up wacom_query_tablet_data
Rewrites this function to be easier to read and understand. The new
function 'wacom_set_device_mode' now handles the grunt work of
assembling the proper feature report, sending it to the device,
and ensuring the setting "sticks".
Signed-off-by: Jason Gerecke <killertofu@gmail.com>
Tested-by: Ping Cheng <pingc@wacom.com>
Signed-off-by: Dmitry Torokhov <dmitry.torokhov@gmail.com>
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/input/tablet/wacom_sys.c | 74 |
1 files changed, 35 insertions, 39 deletions
diff --git a/drivers/input/tablet/wacom_sys.c b/drivers/input/tablet/wacom_sys.c index b44bba2a60c2..9edf9806cff9 100644 --- a/drivers/input/tablet/wacom_sys.c +++ b/drivers/input/tablet/wacom_sys.c | |||
@@ -502,56 +502,52 @@ static int wacom_parse_hid(struct usb_interface *intf, | |||
502 | return result; | 502 | return result; |
503 | } | 503 | } |
504 | 504 | ||
505 | static int wacom_query_tablet_data(struct usb_interface *intf, struct wacom_features *features) | 505 | static int wacom_set_device_mode(struct usb_interface *intf, int report_id, int length, int mode) |
506 | { | 506 | { |
507 | unsigned char *rep_data; | 507 | unsigned char *rep_data; |
508 | int limit = 0, report_id = 2; | 508 | int error = -ENOMEM, limit = 0; |
509 | int error = -ENOMEM; | ||
510 | 509 | ||
511 | rep_data = kmalloc(4, GFP_KERNEL); | 510 | rep_data = kzalloc(length, GFP_KERNEL); |
512 | if (!rep_data) | 511 | if (!rep_data) |
513 | return error; | 512 | return error; |
514 | 513 | ||
515 | /* ask to report Wacom data */ | 514 | rep_data[0] = report_id; |
515 | rep_data[1] = mode; | ||
516 | |||
517 | do { | ||
518 | error = wacom_set_report(intf, WAC_HID_FEATURE_REPORT, | ||
519 | report_id, rep_data, length, 1); | ||
520 | if (error >= 0) | ||
521 | error = wacom_get_report(intf, WAC_HID_FEATURE_REPORT, | ||
522 | report_id, rep_data, length, 1); | ||
523 | } while ((error < 0 || rep_data[1] != mode) && limit++ < WAC_MSG_RETRIES); | ||
524 | |||
525 | kfree(rep_data); | ||
526 | |||
527 | return error < 0 ? error : 0; | ||
528 | } | ||
529 | |||
530 | /* | ||
531 | * Switch the tablet into its most-capable mode. Wacom tablets are | ||
532 | * typically configured to power-up in a mode which sends mouse-like | ||
533 | * reports to the OS. To get absolute position, pressure data, etc. | ||
534 | * from the tablet, it is necessary to switch the tablet out of this | ||
535 | * mode and into one which sends the full range of tablet data. | ||
536 | */ | ||
537 | static int wacom_query_tablet_data(struct usb_interface *intf, struct wacom_features *features) | ||
538 | { | ||
516 | if (features->device_type == BTN_TOOL_FINGER) { | 539 | if (features->device_type == BTN_TOOL_FINGER) { |
517 | /* if it is an MT Tablet PC touch */ | ||
518 | if (features->type > TABLETPC) { | 540 | if (features->type > TABLETPC) { |
519 | do { | 541 | /* MT Tablet PC touch */ |
520 | rep_data[0] = 3; | 542 | return wacom_set_device_mode(intf, 3, 4, 4); |
521 | rep_data[1] = 4; | 543 | } |
522 | rep_data[2] = 0; | 544 | } else if (features->device_type == BTN_TOOL_PEN) { |
523 | rep_data[3] = 0; | 545 | if (features->type <= BAMBOO_PT && features->type != WIRELESS) { |
524 | report_id = 3; | 546 | return wacom_set_device_mode(intf, 2, 2, 2); |
525 | error = wacom_set_report(intf, | ||
526 | WAC_HID_FEATURE_REPORT, | ||
527 | report_id, | ||
528 | rep_data, 4, 1); | ||
529 | if (error >= 0) | ||
530 | error = wacom_get_report(intf, | ||
531 | WAC_HID_FEATURE_REPORT, | ||
532 | report_id, | ||
533 | rep_data, 4, 1); | ||
534 | } while ((error < 0 || rep_data[1] != 4) && | ||
535 | limit++ < WAC_MSG_RETRIES); | ||
536 | } | 547 | } |
537 | } else if (features->type <= BAMBOO_PT && | ||
538 | features->type != WIRELESS && | ||
539 | features->device_type == BTN_TOOL_PEN) { | ||
540 | do { | ||
541 | rep_data[0] = 2; | ||
542 | rep_data[1] = 2; | ||
543 | error = wacom_set_report(intf, WAC_HID_FEATURE_REPORT, | ||
544 | report_id, rep_data, 2, 1); | ||
545 | if (error >= 0) | ||
546 | error = wacom_get_report(intf, | ||
547 | WAC_HID_FEATURE_REPORT, | ||
548 | report_id, rep_data, 2, 1); | ||
549 | } while ((error < 0 || rep_data[1] != 2) && limit++ < WAC_MSG_RETRIES); | ||
550 | } | 548 | } |
551 | 549 | ||
552 | kfree(rep_data); | 550 | return 0; |
553 | |||
554 | return error < 0 ? error : 0; | ||
555 | } | 551 | } |
556 | 552 | ||
557 | static int wacom_retrieve_hid_descriptor(struct usb_interface *intf, | 553 | static int wacom_retrieve_hid_descriptor(struct usb_interface *intf, |