diff options
author | Dmitry Torokhov <dmitry.torokhov@gmail.com> | 2010-07-16 08:28:42 +0200 |
---|---|---|
committer | Dmitry Torokhov <dmitry.torokhov@gmail.com> | 2010-07-16 08:53:00 +0200 |
commit | c18fb1396eb809dbc16e51da273a1789f9d799bf (patch) | |
tree | 43a8f5a321dc625e4cf269a68ccd72fe3b93bcba /drivers/input/evdev.c | |
parent | Input: mousedev - signal that device is writable in mousedev_poll() (diff) | |
download | linux-c18fb1396eb809dbc16e51da273a1789f9d799bf.tar.xz linux-c18fb1396eb809dbc16e51da273a1789f9d799bf.zip |
Input: evdev - signal that device is writable in evdev_poll()
Signed-off-by: Dmitry Torokhov <dtor@mail.ru>
Diffstat (limited to 'drivers/input/evdev.c')
-rw-r--r-- | drivers/input/evdev.c | 9 |
1 files changed, 7 insertions, 2 deletions
diff --git a/drivers/input/evdev.c b/drivers/input/evdev.c index 70c0eb52ca96..054edf346e0b 100644 --- a/drivers/input/evdev.c +++ b/drivers/input/evdev.c @@ -403,10 +403,15 @@ static unsigned int evdev_poll(struct file *file, poll_table *wait) { struct evdev_client *client = file->private_data; struct evdev *evdev = client->evdev; + unsigned int mask; poll_wait(file, &evdev->wait, wait); - return ((client->head == client->tail) ? 0 : (POLLIN | POLLRDNORM)) | - (evdev->exist ? 0 : (POLLHUP | POLLERR)); + + mask = evdev->exist ? POLLOUT | POLLWRNORM : POLLHUP | POLLERR; + if (client->head != client->tail) + mask |= POLLIN | POLLRDNORM; + + return mask; } #ifdef CONFIG_COMPAT |