2019-05-27 08:55:21 +02:00
/* SPDX-License-Identifier: GPL-2.0-only */
2010-03-01 05:14:18 -03:00
/*
* v4l2 - event . h
*
* V4L2 events .
*
* Copyright ( C ) 2009 - - 2010 Nokia Corporation .
*
2012-10-28 06:44:17 -03:00
* Contact : Sakari Ailus < sakari . ailus @ iki . fi >
2010-03-01 05:14:18 -03:00
*/
# ifndef V4L2_EVENT_H
# define V4L2_EVENT_H
# include <linux/types.h>
# include <linux/videodev2.h>
# include <linux/wait.h>
struct v4l2_fh ;
2013-01-22 18:58:57 -03:00
struct v4l2_subdev ;
2011-06-13 19:24:17 -03:00
struct v4l2_subscribed_event ;
2010-03-01 05:14:18 -03:00
struct video_device ;
2015-08-22 08:28:39 -03:00
/**
* struct v4l2_kevent - Internal kernel event struct .
* @ list : List node for the v4l2_fh - > available list .
* @ sev : Pointer to parent v4l2_subscribed_event .
* @ event : The event itself .
2019-01-21 08:32:22 -05:00
* @ ts : The timestamp of the event .
2016-07-22 07:27:06 -03:00
*/
2010-03-01 05:14:18 -03:00
struct v4l2_kevent {
struct list_head list ;
2011-06-13 19:24:17 -03:00
struct v4l2_subscribed_event * sev ;
2010-03-01 05:14:18 -03:00
struct v4l2_event event ;
2019-01-21 08:32:22 -05:00
u64 ts ;
2010-03-01 05:14:18 -03:00
} ;
2016-07-22 07:27:06 -03:00
/**
* struct v4l2_subscribed_event_ops - Subscribed event operations .
2015-08-22 08:28:39 -03:00
*
* @ add : Optional callback , called when a new listener is added
* @ del : Optional callback , called when a listener stops listening
* @ replace : Optional callback that can replace event ' old ' with event ' new ' .
* @ merge : Optional callback that can merge event ' old ' into event ' new ' .
*/
2012-04-08 12:59:46 -03:00
struct v4l2_subscribed_event_ops {
2016-07-22 07:27:06 -03:00
int ( * add ) ( struct v4l2_subscribed_event * sev , unsigned int elems ) ;
2012-04-08 12:59:46 -03:00
void ( * del ) ( struct v4l2_subscribed_event * sev ) ;
void ( * replace ) ( struct v4l2_event * old , const struct v4l2_event * new ) ;
void ( * merge ) ( const struct v4l2_event * old , struct v4l2_event * new ) ;
} ;
2015-08-22 08:28:39 -03:00
/**
2016-07-22 07:27:06 -03:00
* struct v4l2_subscribed_event - Internal struct representing a subscribed
* event .
*
2015-08-22 08:28:39 -03:00
* @ list : List node for the v4l2_fh - > subscribed list .
* @ type : Event type .
* @ id : Associated object ID ( e . g . control ID ) . 0 if there isn ' t any .
* @ flags : Copy of v4l2_event_subscription - > flags .
* @ fh : Filehandle that subscribed to this event .
2016-07-22 07:27:06 -03:00
* @ node : List node that hooks into the object ' s event list
* ( if there is one ) .
2015-08-22 08:28:39 -03:00
* @ ops : v4l2_subscribed_event_ops
* @ elems : The number of elements in the events array .
* @ first : The index of the events containing the oldest available event .
* @ in_use : The number of queued events .
* @ events : An array of @ elems events .
*/
2010-03-01 05:14:18 -03:00
struct v4l2_subscribed_event {
struct list_head list ;
u32 type ;
2011-06-07 11:13:44 -03:00
u32 id ;
2011-06-13 18:55:58 -03:00
u32 flags ;
struct v4l2_fh * fh ;
struct list_head node ;
2012-04-08 12:59:46 -03:00
const struct v4l2_subscribed_event_ops * ops ;
2016-07-22 07:27:06 -03:00
unsigned int elems ;
unsigned int first ;
unsigned int in_use ;
2011-06-13 19:24:17 -03:00
struct v4l2_kevent events [ ] ;
2010-03-01 05:14:18 -03:00
} ;
2016-07-22 07:27:06 -03:00
/**
* v4l2_event_dequeue - Dequeue events from video device .
*
* @ fh : pointer to struct v4l2_fh
* @ event : pointer to struct v4l2_event
* @ nonblocking : if not zero , waits for an event to arrive
*/
2010-03-01 05:14:18 -03:00
int v4l2_event_dequeue ( struct v4l2_fh * fh , struct v4l2_event * event ,
int nonblocking ) ;
2016-07-22 07:27:06 -03:00
/**
* v4l2_event_queue - Queue events to video device .
*
* @ vdev : pointer to & struct video_device
* @ ev : pointer to & struct v4l2_event
*
* The event will be queued for all & struct v4l2_fh file handlers .
*
* . . note : :
* The driver ' s only responsibility is to fill in the type and the data
2020-12-01 13:44:43 +01:00
* fields . The other fields will be filled in by V4L2 .
2016-07-22 07:27:06 -03:00
*/
2010-03-01 05:14:18 -03:00
void v4l2_event_queue ( struct video_device * vdev , const struct v4l2_event * ev ) ;
2016-07-22 07:27:06 -03:00
/**
* v4l2_event_queue_fh - Queue events to video device .
*
* @ fh : pointer to & struct v4l2_fh
* @ ev : pointer to & struct v4l2_event
*
*
* The event will be queued only for the specified & struct v4l2_fh file handler .
*
* . . note : :
* The driver ' s only responsibility is to fill in the type and the data
2020-12-01 13:44:43 +01:00
* fields . The other fields will be filled in by V4L2 .
2016-07-22 07:27:06 -03:00
*/
2011-06-07 11:13:44 -03:00
void v4l2_event_queue_fh ( struct v4l2_fh * fh , const struct v4l2_event * ev ) ;
2016-07-22 07:27:06 -03:00
2020-12-01 13:44:43 +01:00
/**
* v4l2_event_wake_all - Wake all filehandles .
*
* Used when unregistering a video device .
*
* @ vdev : pointer to & struct video_device
*/
void v4l2_event_wake_all ( struct video_device * vdev ) ;
2016-07-22 07:27:06 -03:00
/**
* v4l2_event_pending - Check if an event is available
*
* @ fh : pointer to & struct v4l2_fh
*
* Returns the number of pending events .
*/
2010-03-01 05:14:18 -03:00
int v4l2_event_pending ( struct v4l2_fh * fh ) ;
2016-07-22 07:27:06 -03:00
/**
* v4l2_event_subscribe - Subscribes to an event
*
* @ fh : pointer to & struct v4l2_fh
* @ sub : pointer to & struct v4l2_event_subscription
* @ elems : size of the events queue
* @ ops : pointer to & v4l2_subscribed_event_ops
*
* . . note : :
*
* if @ elems is zero , the framework will fill in a default value ,
* with is currently 1 element .
*/
2010-03-01 05:14:18 -03:00
int v4l2_event_subscribe ( struct v4l2_fh * fh ,
2016-07-22 07:27:06 -03:00
const struct v4l2_event_subscription * sub ,
unsigned int elems ,
2012-04-08 12:59:46 -03:00
const struct v4l2_subscribed_event_ops * ops ) ;
2016-07-22 07:27:06 -03:00
/**
* v4l2_event_unsubscribe - Unsubscribes to an event
*
* @ fh : pointer to & struct v4l2_fh
* @ sub : pointer to & struct v4l2_event_subscription
*/
2010-03-01 05:14:18 -03:00
int v4l2_event_unsubscribe ( struct v4l2_fh * fh ,
2012-09-04 11:46:09 -03:00
const struct v4l2_event_subscription * sub ) ;
2016-07-22 07:27:06 -03:00
/**
* v4l2_event_unsubscribe_all - Unsubscribes to all events
*
* @ fh : pointer to & struct v4l2_fh
*/
2011-06-13 19:24:17 -03:00
void v4l2_event_unsubscribe_all ( struct v4l2_fh * fh ) ;
2016-07-22 07:27:06 -03:00
/**
* v4l2_event_subdev_unsubscribe - Subdev variant of v4l2_event_unsubscribe ( )
*
* @ sd : pointer to & struct v4l2_subdev
* @ fh : pointer to & struct v4l2_fh
* @ sub : pointer to & struct v4l2_event_subscription
*
* . . note : :
*
* This function should be used for the & struct v4l2_subdev_core_ops
* % unsubscribe_event field .
*/
int v4l2_event_subdev_unsubscribe ( struct v4l2_subdev * sd ,
struct v4l2_fh * fh ,
2013-01-22 18:58:57 -03:00
struct v4l2_event_subscription * sub ) ;
2016-07-22 07:27:06 -03:00
/**
2016-09-22 07:59:03 -03:00
* v4l2_src_change_event_subscribe - helper function that calls
2018-01-04 06:47:28 -05:00
* v4l2_event_subscribe ( ) if the event is % V4L2_EVENT_SOURCE_CHANGE .
2016-07-22 07:27:06 -03:00
*
* @ fh : pointer to struct v4l2_fh
* @ sub : pointer to & struct v4l2_event_subscription
*/
2014-05-14 03:59:42 -03:00
int v4l2_src_change_event_subscribe ( struct v4l2_fh * fh ,
2016-07-22 07:27:06 -03:00
const struct v4l2_event_subscription * sub ) ;
/**
* v4l2_src_change_event_subdev_subscribe - Variant of v4l2_event_subscribe ( ) ,
* meant to subscribe only events of the type % V4L2_EVENT_SOURCE_CHANGE .
*
* @ sd : pointer to & struct v4l2_subdev
* @ fh : pointer to & struct v4l2_fh
* @ sub : pointer to & struct v4l2_event_subscription
*/
2014-05-14 03:59:42 -03:00
int v4l2_src_change_event_subdev_subscribe ( struct v4l2_subdev * sd ,
2016-07-22 07:27:06 -03:00
struct v4l2_fh * fh ,
struct v4l2_event_subscription * sub ) ;
2010-03-01 05:14:18 -03:00
# endif /* V4L2_EVENT_H */