diff options
author | Hans Verkuil <hans.verkuil@cisco.com> | 2013-01-30 11:29:02 -0500 |
---|---|---|
committer | Mauro Carvalho Chehab <mchehab@redhat.com> | 2013-02-05 15:22:15 -0500 |
commit | cd13823f5db3e66552801c04f0e761408ef17eb0 (patch) | |
tree | 78bc3dac7efc1db8129a759f44718bcabb8ea771 /drivers | |
parent | 971dfc678114d61c07bd6f8ff8380558b6e12d5d (diff) |
[media] videobuf2: don't return POLLERR when only polling for events
If you only poll for events, then vb2_poll will return POLLPRI | POLLERR if
no streaming is in progress. That's not right, it's perfectly valid to
poll just for events.
Cc: Pawel Osciak <pawel@osciak.com>
Cc: Marek Szyprowski <m.szyprowski@samsung.com>
Cc: Kyungmin Park <kyungmin.park@samsung.com>
Signed-off-by: Hans Verkuil <hans.verkuil@cisco.com>
Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/media/v4l2-core/videobuf2-core.c | 5 |
1 files changed, 5 insertions, 0 deletions
diff --git a/drivers/media/v4l2-core/videobuf2-core.c b/drivers/media/v4l2-core/videobuf2-core.c index d09be38dd377..db1235dcb328 100644 --- a/drivers/media/v4l2-core/videobuf2-core.c +++ b/drivers/media/v4l2-core/videobuf2-core.c | |||
@@ -1965,6 +1965,11 @@ unsigned int vb2_poll(struct vb2_queue *q, struct file *file, poll_table *wait) | |||
1965 | poll_wait(file, &fh->wait, wait); | 1965 | poll_wait(file, &fh->wait, wait); |
1966 | } | 1966 | } |
1967 | 1967 | ||
1968 | if (!V4L2_TYPE_IS_OUTPUT(q->type) && !(req_events & (POLLIN | POLLRDNORM))) | ||
1969 | return res; | ||
1970 | if (V4L2_TYPE_IS_OUTPUT(q->type) && !(req_events & (POLLOUT | POLLWRNORM))) | ||
1971 | return res; | ||
1972 | |||
1968 | /* | 1973 | /* |
1969 | * Start file I/O emulator only if streaming API has not been used yet. | 1974 | * Start file I/O emulator only if streaming API has not been used yet. |
1970 | */ | 1975 | */ |