Commit 00159f19 authored by Dmitry Torokhov's avatar Dmitry Torokhov

Input: do not emit unneeded EV_SYN when suspending

Do not emit EV_SYN/SYN_REPORT on suspend if there were no keys that are
still pressed as we are suspending the device (and in all other cases when
input core is forcibly releasing keys via input_dev_release_keys() call).
Reviewed-by: default avatarBenson Leung <bleung@chromium.org>
Signed-off-by: default avatarDmitry Torokhov <dmitry.torokhov@gmail.com>
parent 6fd38502
...@@ -674,13 +674,19 @@ EXPORT_SYMBOL(input_close_device); ...@@ -674,13 +674,19 @@ EXPORT_SYMBOL(input_close_device);
*/ */
static void input_dev_release_keys(struct input_dev *dev) static void input_dev_release_keys(struct input_dev *dev)
{ {
bool need_sync = false;
int code; int code;
if (is_event_supported(EV_KEY, dev->evbit, EV_MAX)) { if (is_event_supported(EV_KEY, dev->evbit, EV_MAX)) {
for_each_set_bit(code, dev->key, KEY_CNT) for_each_set_bit(code, dev->key, KEY_CNT) {
input_pass_event(dev, EV_KEY, code, 0); input_pass_event(dev, EV_KEY, code, 0);
memset(dev->key, 0, sizeof(dev->key)); need_sync = true;
}
if (need_sync)
input_pass_event(dev, EV_SYN, SYN_REPORT, 1); input_pass_event(dev, EV_SYN, SYN_REPORT, 1);
memset(dev->key, 0, sizeof(dev->key));
} }
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment