aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/media/v4l2-core/v4l2-event.c
diff options
context:
space:
mode:
authorArun Kumar K <arun.kk@samsung.com>2014-05-14 02:59:42 -0400
committerMauro Carvalho Chehab <m.chehab@samsung.com>2014-05-23 18:50:40 -0400
commit3cbe6e5bcad0b102c06b9c6029fda75630045475 (patch)
treea71d0f73af174620f82fd1b5469fef70e9075fe7 /drivers/media/v4l2-core/v4l2-event.c
parent5b340ea0caac4c123a3bb989a43c021a2dc06fb2 (diff)
[media] v4l: Add source change event
This event indicates that the video device has encountered a source parameter change during runtime. This can typically be a resolution change detected by a video decoder OR a format change detected by an input connector. This needs to be nofified to the userspace and the application may be expected to reallocate buffers before proceeding. The application can subscribe to events on a specific pad or input port which it is interested in. Signed-off-by: Arun Kumar K <arun.kk@samsung.com> Acked-by: Sylwester Nawrocki <s.nawrocki@samsung.com> Signed-off-by: Hans Verkuil <hans.verkuil@cisco.com> Signed-off-by: Mauro Carvalho Chehab <m.chehab@samsung.com>
Diffstat (limited to 'drivers/media/v4l2-core/v4l2-event.c')
-rw-r--r--drivers/media/v4l2-core/v4l2-event.c36
1 files changed, 36 insertions, 0 deletions
diff --git a/drivers/media/v4l2-core/v4l2-event.c b/drivers/media/v4l2-core/v4l2-event.c
index 86dcb5483c42..8761aab99de9 100644
--- a/drivers/media/v4l2-core/v4l2-event.c
+++ b/drivers/media/v4l2-core/v4l2-event.c
@@ -318,3 +318,39 @@ int v4l2_event_subdev_unsubscribe(struct v4l2_subdev *sd, struct v4l2_fh *fh,
318 return v4l2_event_unsubscribe(fh, sub); 318 return v4l2_event_unsubscribe(fh, sub);
319} 319}
320EXPORT_SYMBOL_GPL(v4l2_event_subdev_unsubscribe); 320EXPORT_SYMBOL_GPL(v4l2_event_subdev_unsubscribe);
321
322static void v4l2_event_src_replace(struct v4l2_event *old,
323 const struct v4l2_event *new)
324{
325 u32 old_changes = old->u.src_change.changes;
326
327 old->u.src_change = new->u.src_change;
328 old->u.src_change.changes |= old_changes;
329}
330
331static void v4l2_event_src_merge(const struct v4l2_event *old,
332 struct v4l2_event *new)
333{
334 new->u.src_change.changes |= old->u.src_change.changes;
335}
336
337static const struct v4l2_subscribed_event_ops v4l2_event_src_ch_ops = {
338 .replace = v4l2_event_src_replace,
339 .merge = v4l2_event_src_merge,
340};
341
342int v4l2_src_change_event_subscribe(struct v4l2_fh *fh,
343 const struct v4l2_event_subscription *sub)
344{
345 if (sub->type == V4L2_EVENT_SOURCE_CHANGE)
346 return v4l2_event_subscribe(fh, sub, 0, &v4l2_event_src_ch_ops);
347 return -EINVAL;
348}
349EXPORT_SYMBOL_GPL(v4l2_src_change_event_subscribe);
350
351int v4l2_src_change_event_subdev_subscribe(struct v4l2_subdev *sd,
352 struct v4l2_fh *fh, struct v4l2_event_subscription *sub)
353{
354 return v4l2_src_change_event_subscribe(fh, sub);
355}
356EXPORT_SYMBOL_GPL(v4l2_src_change_event_subdev_subscribe);