提交 0d9d93c4 编写于 作者: D Dmitry Torokhov

Input: mousedev - fix sudden warps with touchpads

Pete Zaitcev reports that with his touchpad, if he lifts the finger
and places it elsewhere, the pointer sometimes warps dramatically.
This happens because we don't store coordinates unless we detect a
touch so sometimes we have stale coordinates in queue (from where
the finger left the pad) and averaging makes cursor to jump across
the screen. The solution is to always store the latest coordinates.
Signed-off-by: NDmitry Torokhov <dtor@mail.ru>
上级 f42649e8
...@@ -124,32 +124,33 @@ static void mousedev_touchpad_event(struct input_dev *dev, struct mousedev *mous ...@@ -124,32 +124,33 @@ static void mousedev_touchpad_event(struct input_dev *dev, struct mousedev *mous
int size, tmp; int size, tmp;
enum { FRACTION_DENOM = 128 }; enum { FRACTION_DENOM = 128 };
if (mousedev->touch) { switch (code) {
size = dev->absmax[ABS_X] - dev->absmin[ABS_X]; case ABS_X:
if (size == 0) fx(0) = value;
size = 256 * 2; if (mousedev->touch && mousedev->pkt_count >= 2) {
size = dev->absmax[ABS_X] - dev->absmin[ABS_X];
switch (code) { if (size == 0)
case ABS_X: size = 256 * 2;
fx(0) = value; tmp = ((value - fx(2)) * (256 * FRACTION_DENOM)) / size;
if (mousedev->pkt_count >= 2) { tmp += mousedev->frac_dx;
tmp = ((value - fx(2)) * (256 * FRACTION_DENOM)) / size; mousedev->packet.dx = tmp / FRACTION_DENOM;
tmp += mousedev->frac_dx; mousedev->frac_dx = tmp - mousedev->packet.dx * FRACTION_DENOM;
mousedev->packet.dx = tmp / FRACTION_DENOM; }
mousedev->frac_dx = tmp - mousedev->packet.dx * FRACTION_DENOM; break;
}
break;
case ABS_Y: case ABS_Y:
fy(0) = value; fy(0) = value;
if (mousedev->pkt_count >= 2) { if (mousedev->touch && mousedev->pkt_count >= 2) {
tmp = -((value - fy(2)) * (256 * FRACTION_DENOM)) / size; /* use X size to keep the same scale */
tmp += mousedev->frac_dy; size = dev->absmax[ABS_X] - dev->absmin[ABS_X];
mousedev->packet.dy = tmp / FRACTION_DENOM; if (size == 0)
mousedev->frac_dy = tmp - mousedev->packet.dy * FRACTION_DENOM; size = 256 * 2;
} tmp = -((value - fy(2)) * (256 * FRACTION_DENOM)) / size;
break; tmp += mousedev->frac_dy;
} mousedev->packet.dy = tmp / FRACTION_DENOM;
mousedev->frac_dy = tmp - mousedev->packet.dy * FRACTION_DENOM;
}
break;
} }
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册