diff options
Diffstat (limited to 'drivers/input/input.c')
-rw-r--r-- | drivers/input/input.c | 46 |
1 files changed, 42 insertions, 4 deletions
diff --git a/drivers/input/input.c b/drivers/input/input.c index e1243b4b32a5..a9b025f4147a 100644 --- a/drivers/input/input.c +++ b/drivers/input/input.c | |||
@@ -182,7 +182,7 @@ static int input_handle_abs_event(struct input_dev *dev, | |||
182 | is_mt_event = code >= ABS_MT_FIRST && code <= ABS_MT_LAST; | 182 | is_mt_event = code >= ABS_MT_FIRST && code <= ABS_MT_LAST; |
183 | 183 | ||
184 | if (!is_mt_event) { | 184 | if (!is_mt_event) { |
185 | pold = &dev->abs[code]; | 185 | pold = &dev->absinfo[code].value; |
186 | } else if (dev->mt) { | 186 | } else if (dev->mt) { |
187 | struct input_mt_slot *mtslot = &dev->mt[dev->slot]; | 187 | struct input_mt_slot *mtslot = &dev->mt[dev->slot]; |
188 | pold = &mtslot->abs[code - ABS_MT_FIRST]; | 188 | pold = &mtslot->abs[code - ABS_MT_FIRST]; |
@@ -196,7 +196,7 @@ static int input_handle_abs_event(struct input_dev *dev, | |||
196 | 196 | ||
197 | if (pold) { | 197 | if (pold) { |
198 | *pval = input_defuzz_abs_event(*pval, *pold, | 198 | *pval = input_defuzz_abs_event(*pval, *pold, |
199 | dev->absfuzz[code]); | 199 | dev->absinfo[code].fuzz); |
200 | if (*pold == *pval) | 200 | if (*pold == *pval) |
201 | return INPUT_IGNORE_EVENT; | 201 | return INPUT_IGNORE_EVENT; |
202 | 202 | ||
@@ -204,8 +204,8 @@ static int input_handle_abs_event(struct input_dev *dev, | |||
204 | } | 204 | } |
205 | 205 | ||
206 | /* Flush pending "slot" event */ | 206 | /* Flush pending "slot" event */ |
207 | if (is_mt_event && dev->slot != dev->abs[ABS_MT_SLOT]) { | 207 | if (is_mt_event && dev->slot != input_abs_get_val(dev, ABS_MT_SLOT)) { |
208 | dev->abs[ABS_MT_SLOT] = dev->slot; | 208 | input_abs_set_val(dev, ABS_MT_SLOT, dev->slot); |
209 | input_pass_event(dev, EV_ABS, ABS_MT_SLOT, dev->slot); | 209 | input_pass_event(dev, EV_ABS, ABS_MT_SLOT, dev->slot); |
210 | } | 210 | } |
211 | 211 | ||
@@ -391,6 +391,43 @@ void input_inject_event(struct input_handle *handle, | |||
391 | EXPORT_SYMBOL(input_inject_event); | 391 | EXPORT_SYMBOL(input_inject_event); |
392 | 392 | ||
393 | /** | 393 | /** |
394 | * input_alloc_absinfo - allocates array of input_absinfo structs | ||
395 | * @dev: the input device emitting absolute events | ||
396 | * | ||
397 | * If the absinfo struct the caller asked for is already allocated, this | ||
398 | * functions will not do anything. | ||
399 | */ | ||
400 | void input_alloc_absinfo(struct input_dev *dev) | ||
401 | { | ||
402 | if (!dev->absinfo) | ||
403 | dev->absinfo = kcalloc(ABS_CNT, sizeof(struct input_absinfo), | ||
404 | GFP_KERNEL); | ||
405 | |||
406 | WARN(!dev->absinfo, "%s(): kcalloc() failed?\n", __func__); | ||
407 | } | ||
408 | EXPORT_SYMBOL(input_alloc_absinfo); | ||
409 | |||
410 | void input_set_abs_params(struct input_dev *dev, unsigned int axis, | ||
411 | int min, int max, int fuzz, int flat) | ||
412 | { | ||
413 | struct input_absinfo *absinfo; | ||
414 | |||
415 | input_alloc_absinfo(dev); | ||
416 | if (!dev->absinfo) | ||
417 | return; | ||
418 | |||
419 | absinfo = &dev->absinfo[axis]; | ||
420 | absinfo->minimum = min; | ||
421 | absinfo->maximum = max; | ||
422 | absinfo->fuzz = fuzz; | ||
423 | absinfo->flat = flat; | ||
424 | |||
425 | dev->absbit[BIT_WORD(axis)] |= BIT_MASK(axis); | ||
426 | } | ||
427 | EXPORT_SYMBOL(input_set_abs_params); | ||
428 | |||
429 | |||
430 | /** | ||
394 | * input_grab_device - grabs device for exclusive use | 431 | * input_grab_device - grabs device for exclusive use |
395 | * @handle: input handle that wants to own the device | 432 | * @handle: input handle that wants to own the device |
396 | * | 433 | * |
@@ -1308,6 +1345,7 @@ static void input_dev_release(struct device *device) | |||
1308 | 1345 | ||
1309 | input_ff_destroy(dev); | 1346 | input_ff_destroy(dev); |
1310 | input_mt_destroy_slots(dev); | 1347 | input_mt_destroy_slots(dev); |
1348 | kfree(dev->absinfo); | ||
1311 | kfree(dev); | 1349 | kfree(dev); |
1312 | 1350 | ||
1313 | module_put(THIS_MODULE); | 1351 | module_put(THIS_MODULE); |