diff options
-rw-r--r-- | drivers/usb/input/ati_remote.c | 135 |
1 files changed, 77 insertions, 58 deletions
diff --git a/drivers/usb/input/ati_remote.c b/drivers/usb/input/ati_remote.c index 5a56f6cb36a8..3719fcb04b8f 100644 --- a/drivers/usb/input/ati_remote.c +++ b/drivers/usb/input/ati_remote.c | |||
@@ -157,9 +157,6 @@ MODULE_DEVICE_TABLE(usb, ati_remote_table); | |||
157 | static char init1[] = { 0x01, 0x00, 0x20, 0x14 }; | 157 | static char init1[] = { 0x01, 0x00, 0x20, 0x14 }; |
158 | static char init2[] = { 0x01, 0x00, 0x20, 0x14, 0x20, 0x20, 0x20 }; | 158 | static char init2[] = { 0x01, 0x00, 0x20, 0x14, 0x20, 0x20, 0x20 }; |
159 | 159 | ||
160 | /* Acceleration curve for directional control pad */ | ||
161 | static const char accel[] = { 1, 2, 4, 6, 9, 13, 20 }; | ||
162 | |||
163 | struct ati_remote { | 160 | struct ati_remote { |
164 | struct input_dev *idev; | 161 | struct input_dev *idev; |
165 | struct usb_device *udev; | 162 | struct usb_device *udev; |
@@ -417,6 +414,43 @@ static int ati_remote_event_lookup(int rem, unsigned char d1, unsigned char d2) | |||
417 | } | 414 | } |
418 | 415 | ||
419 | /* | 416 | /* |
417 | * ati_remote_compute_accel | ||
418 | * | ||
419 | * Implements acceleration curve for directional control pad | ||
420 | * If elapsed time since last event is > 1/4 second, user "stopped", | ||
421 | * so reset acceleration. Otherwise, user is probably holding the control | ||
422 | * pad down, so we increase acceleration, ramping up over two seconds to | ||
423 | * a maximum speed. | ||
424 | */ | ||
425 | static int ati_remote_compute_accel(struct ati_remote *ati_remote) | ||
426 | { | ||
427 | static const char accel[] = { 1, 2, 4, 6, 9, 13, 20 }; | ||
428 | unsigned long now = jiffies; | ||
429 | int acc; | ||
430 | |||
431 | if (time_after(now, ati_remote->old_jiffies + msecs_to_jiffies(250))) { | ||
432 | acc = 1; | ||
433 | ati_remote->acc_jiffies = now; | ||
434 | } | ||
435 | else if (time_before(now, ati_remote->acc_jiffies + msecs_to_jiffies(125))) | ||
436 | acc = accel[0]; | ||
437 | else if (time_before(now, ati_remote->acc_jiffies + msecs_to_jiffies(250))) | ||
438 | acc = accel[1]; | ||
439 | else if (time_before(now, ati_remote->acc_jiffies + msecs_to_jiffies(500))) | ||
440 | acc = accel[2]; | ||
441 | else if (time_before(now, ati_remote->acc_jiffies + msecs_to_jiffies(1000))) | ||
442 | acc = accel[3]; | ||
443 | else if (time_before(now, ati_remote->acc_jiffies + msecs_to_jiffies(1500))) | ||
444 | acc = accel[4]; | ||
445 | else if (time_before(now, ati_remote->acc_jiffies + msecs_to_jiffies(2000))) | ||
446 | acc = accel[5]; | ||
447 | else | ||
448 | acc = accel[6]; | ||
449 | |||
450 | return acc; | ||
451 | } | ||
452 | |||
453 | /* | ||
420 | * ati_remote_report_input | 454 | * ati_remote_report_input |
421 | */ | 455 | */ |
422 | static void ati_remote_input_report(struct urb *urb, struct pt_regs *regs) | 456 | static void ati_remote_input_report(struct urb *urb, struct pt_regs *regs) |
@@ -494,63 +528,48 @@ static void ati_remote_input_report(struct urb *urb, struct pt_regs *regs) | |||
494 | ati_remote_tbl[index].code, 0); | 528 | ati_remote_tbl[index].code, 0); |
495 | input_sync(dev); | 529 | input_sync(dev); |
496 | 530 | ||
497 | return; | 531 | } else { |
498 | } | ||
499 | 532 | ||
500 | /* | 533 | /* |
501 | * Other event kinds are from the directional control pad, and have an | 534 | * Other event kinds are from the directional control pad, and have an |
502 | * acceleration factor applied to them. Without this acceleration, the | 535 | * acceleration factor applied to them. Without this acceleration, the |
503 | * control pad is mostly unusable. | 536 | * control pad is mostly unusable. |
504 | * | 537 | */ |
505 | * If elapsed time since last event is > 1/4 second, user "stopped", | 538 | acc = ati_remote_compute_accel(ati_remote); |
506 | * so reset acceleration. Otherwise, user is probably holding the control | ||
507 | * pad down, so we increase acceleration, ramping up over two seconds to | ||
508 | * a maximum speed. The acceleration curve is #defined above. | ||
509 | */ | ||
510 | if (time_after(jiffies, ati_remote->old_jiffies + (HZ >> 2))) { | ||
511 | acc = 1; | ||
512 | ati_remote->acc_jiffies = jiffies; | ||
513 | } | ||
514 | else if (time_before(jiffies, ati_remote->acc_jiffies + (HZ >> 3))) acc = accel[0]; | ||
515 | else if (time_before(jiffies, ati_remote->acc_jiffies + (HZ >> 2))) acc = accel[1]; | ||
516 | else if (time_before(jiffies, ati_remote->acc_jiffies + (HZ >> 1))) acc = accel[2]; | ||
517 | else if (time_before(jiffies, ati_remote->acc_jiffies + HZ)) acc = accel[3]; | ||
518 | else if (time_before(jiffies, ati_remote->acc_jiffies + HZ+(HZ>>1))) acc = accel[4]; | ||
519 | else if (time_before(jiffies, ati_remote->acc_jiffies + (HZ << 1))) acc = accel[5]; | ||
520 | else acc = accel[6]; | ||
521 | |||
522 | input_regs(dev, regs); | ||
523 | switch (ati_remote_tbl[index].kind) { | ||
524 | case KIND_ACCEL: | ||
525 | input_event(dev, ati_remote_tbl[index].type, | ||
526 | ati_remote_tbl[index].code, | ||
527 | ati_remote_tbl[index].value * acc); | ||
528 | break; | ||
529 | case KIND_LU: | ||
530 | input_report_rel(dev, REL_X, -acc); | ||
531 | input_report_rel(dev, REL_Y, -acc); | ||
532 | break; | ||
533 | case KIND_RU: | ||
534 | input_report_rel(dev, REL_X, acc); | ||
535 | input_report_rel(dev, REL_Y, -acc); | ||
536 | break; | ||
537 | case KIND_LD: | ||
538 | input_report_rel(dev, REL_X, -acc); | ||
539 | input_report_rel(dev, REL_Y, acc); | ||
540 | break; | ||
541 | case KIND_RD: | ||
542 | input_report_rel(dev, REL_X, acc); | ||
543 | input_report_rel(dev, REL_Y, acc); | ||
544 | break; | ||
545 | default: | ||
546 | dev_dbg(&ati_remote->interface->dev, "ati_remote kind=%d\n", | ||
547 | ati_remote_tbl[index].kind); | ||
548 | } | ||
549 | input_sync(dev); | ||
550 | 539 | ||
551 | ati_remote->old_jiffies = jiffies; | 540 | input_regs(dev, regs); |
552 | ati_remote->old_data[0] = data[1]; | 541 | switch (ati_remote_tbl[index].kind) { |
553 | ati_remote->old_data[1] = data[2]; | 542 | case KIND_ACCEL: |
543 | input_event(dev, ati_remote_tbl[index].type, | ||
544 | ati_remote_tbl[index].code, | ||
545 | ati_remote_tbl[index].value * acc); | ||
546 | break; | ||
547 | case KIND_LU: | ||
548 | input_report_rel(dev, REL_X, -acc); | ||
549 | input_report_rel(dev, REL_Y, -acc); | ||
550 | break; | ||
551 | case KIND_RU: | ||
552 | input_report_rel(dev, REL_X, acc); | ||
553 | input_report_rel(dev, REL_Y, -acc); | ||
554 | break; | ||
555 | case KIND_LD: | ||
556 | input_report_rel(dev, REL_X, -acc); | ||
557 | input_report_rel(dev, REL_Y, acc); | ||
558 | break; | ||
559 | case KIND_RD: | ||
560 | input_report_rel(dev, REL_X, acc); | ||
561 | input_report_rel(dev, REL_Y, acc); | ||
562 | break; | ||
563 | default: | ||
564 | dev_dbg(&ati_remote->interface->dev, "ati_remote kind=%d\n", | ||
565 | ati_remote_tbl[index].kind); | ||
566 | } | ||
567 | input_sync(dev); | ||
568 | |||
569 | ati_remote->old_jiffies = jiffies; | ||
570 | ati_remote->old_data[0] = data[1]; | ||
571 | ati_remote->old_data[1] = data[2]; | ||
572 | } | ||
554 | } | 573 | } |
555 | 574 | ||
556 | /* | 575 | /* |