0002-dix-hook-up-the-unaccelerated-valuator-masks.patch 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135
  1. From 7504fbd2239257f1a00a1a15d02862eea81f167c Mon Sep 17 00:00:00 2001
  2. From: Peter Hutterer <peter.hutterer@who-t.net>
  3. Date: Tue, 5 May 2015 14:48:41 +1000
  4. Subject: [PATCH] dix: hook up the unaccelerated valuator masks
  5. If present, access the unaccelerated valuator mask values for DGA and XI2 raw
  6. events.
  7. Signed-off-by: Peter Hutterer <peter.hutterer@who-t.net>
  8. Reviewed-by: Hans de Goede <hdegoede@redhat.com>
  9. ---
  10. dix/getevents.c | 31 ++++++++++++++++++++++---------
  11. hw/xfree86/common/xf86Xinput.c | 4 ++++
  12. 2 files changed, 26 insertions(+), 9 deletions(-)
  13. diff --git a/dix/getevents.c b/dix/getevents.c
  14. index 6fb12c5..64bf76e 100644
  15. --- a/dix/getevents.c
  16. +++ b/dix/getevents.c
  17. @@ -213,14 +213,25 @@ init_raw(DeviceIntPtr dev, RawDeviceEvent *event, Time ms, int type, int detail)
  18. }
  19. static void
  20. -set_raw_valuators(RawDeviceEvent *event, ValuatorMask *mask, double *data)
  21. +set_raw_valuators(RawDeviceEvent *event, ValuatorMask *mask,
  22. + BOOL use_unaccel, double *data)
  23. {
  24. int i;
  25. + use_unaccel = use_unaccel && valuator_mask_has_unaccelerated(mask);
  26. +
  27. for (i = 0; i < valuator_mask_size(mask); i++) {
  28. if (valuator_mask_isset(mask, i)) {
  29. + double v;
  30. +
  31. SetBit(event->valuators.mask, i);
  32. - data[i] = valuator_mask_get_double(mask, i);
  33. +
  34. + if (use_unaccel)
  35. + v = valuator_mask_get_unaccelerated(mask, i);
  36. + else
  37. + v = valuator_mask_get_double(mask, i);
  38. +
  39. + data[i] = v;
  40. }
  41. }
  42. }
  43. @@ -1138,11 +1149,11 @@ GetKeyboardEvents(InternalEvent *events, DeviceIntPtr pDev, int type,
  44. valuator_mask_copy(&mask, mask_in);
  45. init_raw(pDev, raw, ms, type, key_code);
  46. - set_raw_valuators(raw, &mask, raw->valuators.data_raw);
  47. + set_raw_valuators(raw, &mask, TRUE, raw->valuators.data_raw);
  48. clipValuators(pDev, &mask);
  49. - set_raw_valuators(raw, &mask, raw->valuators.data);
  50. + set_raw_valuators(raw, &mask, FALSE, raw->valuators.data);
  51. event = &events->device_event;
  52. init_device_event(event, pDev, ms);
  53. @@ -1423,9 +1434,11 @@ fill_pointer_events(InternalEvent *events, DeviceIntPtr pDev, int type,
  54. num_events++;
  55. init_raw(pDev, raw, ms, type, buttons);
  56. - set_raw_valuators(raw, &mask, raw->valuators.data_raw);
  57. + set_raw_valuators(raw, &mask, TRUE, raw->valuators.data_raw);
  58. }
  59. + valuator_mask_drop_unaccelerated(&mask);
  60. +
  61. /* valuators are in driver-native format (rel or abs) */
  62. if (flags & POINTER_ABSOLUTE) {
  63. @@ -1438,7 +1451,7 @@ fill_pointer_events(InternalEvent *events, DeviceIntPtr pDev, int type,
  64. transformAbsolute(pDev, &mask);
  65. clipAbsolute(pDev, &mask);
  66. if ((flags & POINTER_NORAW) == 0 && raw)
  67. - set_raw_valuators(raw, &mask, raw->valuators.data);
  68. + set_raw_valuators(raw, &mask, FALSE, raw->valuators.data);
  69. }
  70. else {
  71. transformRelative(pDev, &mask);
  72. @@ -1446,7 +1459,7 @@ fill_pointer_events(InternalEvent *events, DeviceIntPtr pDev, int type,
  73. if (flags & POINTER_ACCELERATE)
  74. accelPointer(pDev, &mask, ms);
  75. if ((flags & POINTER_NORAW) == 0 && raw)
  76. - set_raw_valuators(raw, &mask, raw->valuators.data);
  77. + set_raw_valuators(raw, &mask, FALSE, raw->valuators.data);
  78. moveRelative(pDev, flags, &mask);
  79. }
  80. @@ -1951,7 +1964,7 @@ GetTouchEvents(InternalEvent *events, DeviceIntPtr dev, uint32_t ddx_touchid,
  81. events++;
  82. num_events++;
  83. init_raw(dev, raw, ms, type, client_id);
  84. - set_raw_valuators(raw, &mask, raw->valuators.data_raw);
  85. + set_raw_valuators(raw, &mask, TRUE, raw->valuators.data_raw);
  86. }
  87. event = &events->device_event;
  88. @@ -2013,7 +2026,7 @@ GetTouchEvents(InternalEvent *events, DeviceIntPtr dev, uint32_t ddx_touchid,
  89. screeny = dev->spriteInfo->sprite->hotPhys.y;
  90. }
  91. if (need_rawevent)
  92. - set_raw_valuators(raw, &mask, raw->valuators.data);
  93. + set_raw_valuators(raw, &mask, FALSE, raw->valuators.data);
  94. /* Indirect device touch coordinates are not used for cursor positioning.
  95. * They are merely informational, and are provided in device coordinates.
  96. diff --git a/hw/xfree86/common/xf86Xinput.c b/hw/xfree86/common/xf86Xinput.c
  97. index 1fb5b16..5ce4c71 100644
  98. --- a/hw/xfree86/common/xf86Xinput.c
  99. +++ b/hw/xfree86/common/xf86Xinput.c
  100. @@ -1137,12 +1137,16 @@ xf86CheckMotionEvent4DGA(DeviceIntPtr device, int is_absolute,
  101. dx = valuator_mask_get(mask, 0);
  102. if (is_absolute)
  103. dx -= device->last.valuators[0];
  104. + else if (valuator_mask_has_unaccelerated(mask))
  105. + dx = valuator_mask_get_unaccelerated(mask, 0);
  106. }
  107. if (valuator_mask_isset(mask, 1)) {
  108. dy = valuator_mask_get(mask, 1);
  109. if (is_absolute)
  110. dy -= device->last.valuators[1];
  111. + else if (valuator_mask_has_unaccelerated(mask))
  112. + dy = valuator_mask_get_unaccelerated(mask, 1);
  113. }
  114. if (DGAStealMotionEvent(device, idx, dx, dy))
  115. --
  116. 2.4.1