diff options
Diffstat (limited to 'drivers/input/input-mt.c')
-rw-r--r-- | drivers/input/input-mt.c | 10 |
1 files changed, 8 insertions, 2 deletions
diff --git a/drivers/input/input-mt.c b/drivers/input/input-mt.c index 53eaf89f2db5..d398f1321f14 100644 --- a/drivers/input/input-mt.c +++ b/drivers/input/input-mt.c | |||
@@ -79,6 +79,8 @@ int input_mt_init_slots(struct input_dev *dev, unsigned int num_slots, | |||
79 | } | 79 | } |
80 | if (flags & INPUT_MT_DIRECT) | 80 | if (flags & INPUT_MT_DIRECT) |
81 | __set_bit(INPUT_PROP_DIRECT, dev->propbit); | 81 | __set_bit(INPUT_PROP_DIRECT, dev->propbit); |
82 | if (flags & INPUT_MT_SEMI_MT) | ||
83 | __set_bit(INPUT_PROP_SEMI_MT, dev->propbit); | ||
82 | if (flags & INPUT_MT_TRACK) { | 84 | if (flags & INPUT_MT_TRACK) { |
83 | unsigned int n2 = num_slots * num_slots; | 85 | unsigned int n2 = num_slots * num_slots; |
84 | mt->red = kcalloc(n2, sizeof(*mt->red), GFP_KERNEL); | 86 | mt->red = kcalloc(n2, sizeof(*mt->red), GFP_KERNEL); |
@@ -246,20 +248,24 @@ void input_mt_sync_frame(struct input_dev *dev) | |||
246 | { | 248 | { |
247 | struct input_mt *mt = dev->mt; | 249 | struct input_mt *mt = dev->mt; |
248 | struct input_mt_slot *s; | 250 | struct input_mt_slot *s; |
251 | bool use_count = false; | ||
249 | 252 | ||
250 | if (!mt) | 253 | if (!mt) |
251 | return; | 254 | return; |
252 | 255 | ||
253 | if (mt->flags & INPUT_MT_DROP_UNUSED) { | 256 | if (mt->flags & INPUT_MT_DROP_UNUSED) { |
254 | for (s = mt->slots; s != mt->slots + mt->num_slots; s++) { | 257 | for (s = mt->slots; s != mt->slots + mt->num_slots; s++) { |
255 | if (s->frame == mt->frame) | 258 | if (input_mt_is_used(mt, s)) |
256 | continue; | 259 | continue; |
257 | input_mt_slot(dev, s - mt->slots); | 260 | input_mt_slot(dev, s - mt->slots); |
258 | input_event(dev, EV_ABS, ABS_MT_TRACKING_ID, -1); | 261 | input_event(dev, EV_ABS, ABS_MT_TRACKING_ID, -1); |
259 | } | 262 | } |
260 | } | 263 | } |
261 | 264 | ||
262 | input_mt_report_pointer_emulation(dev, (mt->flags & INPUT_MT_POINTER)); | 265 | if ((mt->flags & INPUT_MT_POINTER) && !(mt->flags & INPUT_MT_SEMI_MT)) |
266 | use_count = true; | ||
267 | |||
268 | input_mt_report_pointer_emulation(dev, use_count); | ||
263 | 269 | ||
264 | mt->frame++; | 270 | mt->frame++; |
265 | } | 271 | } |