0001-dix-Add-unaccelerated-valuators-to-the-ValuatorMask.patch 7.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211
  1. From e1a7f4bb5333b0271d29f785eb55f1c3273e626a Mon Sep 17 00:00:00 2001
  2. From: Peter Hutterer <peter.hutterer@who-t.net>
  3. Date: Tue, 5 May 2015 14:18:54 +1000
  4. Subject: [PATCH] dix: Add unaccelerated valuators to the ValuatorMask
  5. Allows a mask to carry both accelerated and unaccelerated motion at the same
  6. time.
  7. This is required for xf86-input-libinput where the pointer acceleration
  8. happens in libinput already, but parts of the server, specifically raw events
  9. and DGA rely on device-specific unaccelerated data.
  10. To ease integration add this as a second set to the ValuatorMask rather than
  11. extending all APIs to carry a second, possibly NULL set of valuators.
  12. Note that a valuator mask should only be used in either accel/unaccel or
  13. standard mode at any time. Switching requires either a valuator_mask_zero()
  14. call or unsetting all valuators one-by-one. Trying to mix the two will produce
  15. a warning.
  16. The server has a shortcut for changing a mask with the
  17. valuator_mask_drop_unaccelerated() call. This saves us from having to loop
  18. through all valuators on every event, we can just drop the bits we know we
  19. don't want.
  20. Signed-off-by: Peter Hutterer <peter.hutterer@who-t.net>
  21. Reviewed-by: Hans de Goede <hdegoede@redhat.com>
  22. ---
  23. dix/inpututils.c | 82 +++++++++++++++++++++++++++++++++++++++---
  24. hw/xfree86/common/xf86Module.h | 2 +-
  25. include/input.h | 15 ++++++++
  26. include/inpututils.h | 2 ++
  27. 4 files changed, 95 insertions(+), 6 deletions(-)
  28. diff --git a/dix/inpututils.c b/dix/inpututils.c
  29. index 5c2a32d..1363988 100644
  30. --- a/dix/inpututils.c
  31. +++ b/dix/inpututils.c
  32. @@ -505,11 +505,8 @@ valuator_mask_isset(const ValuatorMask *mask, int valuator)
  33. return mask->last_bit >= valuator && BitIsOn(mask->mask, valuator);
  34. }
  35. -/**
  36. - * Set the valuator to the given floating-point data.
  37. - */
  38. -void
  39. -valuator_mask_set_double(ValuatorMask *mask, int valuator, double data)
  40. +static inline void
  41. +_valuator_mask_set_double(ValuatorMask *mask, int valuator, double data)
  42. {
  43. mask->last_bit = max(valuator, mask->last_bit);
  44. SetBit(mask->mask, valuator);
  45. @@ -517,6 +514,17 @@ valuator_mask_set_double(ValuatorMask *mask, int valuator, double data)
  46. }
  47. /**
  48. + * Set the valuator to the given floating-point data.
  49. + */
  50. +void
  51. +valuator_mask_set_double(ValuatorMask *mask, int valuator, double data)
  52. +{
  53. + BUG_WARN_MSG(mask->has_unaccelerated,
  54. + "Do not mix valuator types, zero mask first\n");
  55. + _valuator_mask_set_double(mask, valuator, data);
  56. +}
  57. +
  58. +/**
  59. * Set the valuator to the given integer data.
  60. */
  61. void
  62. @@ -594,11 +602,15 @@ valuator_mask_unset(ValuatorMask *mask, int valuator)
  63. ClearBit(mask->mask, valuator);
  64. mask->valuators[valuator] = 0.0;
  65. + mask->unaccelerated[valuator] = 0.0;
  66. for (i = 0; i <= mask->last_bit; i++)
  67. if (valuator_mask_isset(mask, i))
  68. lastbit = max(lastbit, i);
  69. mask->last_bit = lastbit;
  70. +
  71. + if (mask->last_bit == -1)
  72. + mask->has_unaccelerated = FALSE;
  73. }
  74. }
  75. @@ -611,6 +623,66 @@ valuator_mask_copy(ValuatorMask *dest, const ValuatorMask *src)
  76. valuator_mask_zero(dest);
  77. }
  78. +Bool
  79. +valuator_mask_has_unaccelerated(const ValuatorMask *mask)
  80. +{
  81. + return mask->has_unaccelerated;
  82. +}
  83. +
  84. +void
  85. +valuator_mask_drop_unaccelerated(ValuatorMask *mask)
  86. +{
  87. + memset(mask->unaccelerated, 0, sizeof(mask->unaccelerated));
  88. + mask->has_unaccelerated = FALSE;
  89. +}
  90. +
  91. +/**
  92. + * Set both accelerated and unaccelerated value for this mask.
  93. + */
  94. +void
  95. +valuator_mask_set_unaccelerated(ValuatorMask *mask,
  96. + int valuator,
  97. + double accel,
  98. + double unaccel)
  99. +{
  100. + BUG_WARN_MSG(mask->last_bit != -1 && !mask->has_unaccelerated,
  101. + "Do not mix valuator types, zero mask first\n");
  102. + _valuator_mask_set_double(mask, valuator, accel);
  103. + mask->has_unaccelerated = TRUE;
  104. + mask->unaccelerated[valuator] = unaccel;
  105. +}
  106. +
  107. +double
  108. +valuator_mask_get_accelerated(const ValuatorMask *mask,
  109. + int valuator)
  110. +{
  111. + return valuator_mask_get_double(mask, valuator);
  112. +}
  113. +
  114. +double
  115. +valuator_mask_get_unaccelerated(const ValuatorMask *mask,
  116. + int valuator)
  117. +{
  118. + return mask->unaccelerated[valuator];
  119. +}
  120. +
  121. +Bool
  122. +valuator_mask_fetch_unaccelerated(const ValuatorMask *mask,
  123. + int valuator,
  124. + double *accel,
  125. + double *unaccel)
  126. +{
  127. + if (valuator_mask_isset(mask, valuator)) {
  128. + if (accel)
  129. + *accel = valuator_mask_get_accelerated(mask, valuator);
  130. + if (unaccel)
  131. + *unaccel = valuator_mask_get_unaccelerated(mask, valuator);
  132. + return TRUE;
  133. + }
  134. + else
  135. + return FALSE;
  136. +}
  137. +
  138. int
  139. CountBits(const uint8_t * mask, int len)
  140. {
  141. diff --git a/hw/xfree86/common/xf86Module.h b/hw/xfree86/common/xf86Module.h
  142. index e68fe9c..6133641 100644
  143. --- a/hw/xfree86/common/xf86Module.h
  144. +++ b/hw/xfree86/common/xf86Module.h
  145. @@ -81,7 +81,7 @@ typedef enum {
  146. */
  147. #define ABI_ANSIC_VERSION SET_ABI_VERSION(0, 4)
  148. #define ABI_VIDEODRV_VERSION SET_ABI_VERSION(19, 0)
  149. -#define ABI_XINPUT_VERSION SET_ABI_VERSION(21, 0)
  150. +#define ABI_XINPUT_VERSION SET_ABI_VERSION(21, 1)
  151. #define ABI_EXTENSION_VERSION SET_ABI_VERSION(9, 0)
  152. #define ABI_FONT_VERSION SET_ABI_VERSION(0, 6)
  153. diff --git a/include/input.h b/include/input.h
  154. index bf22dc7..0a4c4f7 100644
  155. --- a/include/input.h
  156. +++ b/include/input.h
  157. @@ -674,6 +674,21 @@ extern _X_EXPORT Bool valuator_mask_fetch(const ValuatorMask *mask,
  158. extern _X_EXPORT Bool valuator_mask_fetch_double(const ValuatorMask *mask,
  159. int valnum, double *val);
  160. +extern _X_EXPORT Bool valuator_mask_has_unaccelerated(const ValuatorMask *mask);
  161. +extern _X_EXPORT void valuator_mask_set_unaccelerated(ValuatorMask *mask,
  162. + int valuator,
  163. + double accel,
  164. + double unaccel);
  165. +extern _X_EXPORT double valuator_mask_get_accelerated(const ValuatorMask *mask,
  166. + int valuator);
  167. +extern _X_EXPORT double valuator_mask_get_unaccelerated(const ValuatorMask *mask,
  168. + int valuator);
  169. +extern _X_EXPORT Bool valuator_mask_fetch_unaccelerated(const ValuatorMask *mask,
  170. + int valuator,
  171. + double *accel,
  172. + double *unaccel);
  173. +extern _X_HIDDEN void valuator_mask_drop_unaccelerated(ValuatorMask *mask);
  174. +
  175. /* InputOption handling interface */
  176. extern _X_EXPORT InputOption *input_option_new(InputOption *list,
  177. const char *key,
  178. diff --git a/include/inpututils.h b/include/inpututils.h
  179. index 53c96ba..4e90815 100644
  180. --- a/include/inpututils.h
  181. +++ b/include/inpututils.h
  182. @@ -36,8 +36,10 @@ extern Mask event_filters[MAXDEVICES][MAXEVENTS];
  183. struct _ValuatorMask {
  184. int8_t last_bit; /* highest bit set in mask */
  185. + int8_t has_unaccelerated;
  186. uint8_t mask[(MAX_VALUATORS + 7) / 8];
  187. double valuators[MAX_VALUATORS]; /* valuator data */
  188. + double unaccelerated[MAX_VALUATORS]; /* valuator data */
  189. };
  190. extern void verify_internal_event(const InternalEvent *ev);
  191. --
  192. 2.4.1