Blame view

include/media/v4l2-event.h 7.77 KB
c3b5b0241   Sakari Ailus   V4L/DVB: V4L: Eve...
1
2
3
4
5
6
7
  /*
   * v4l2-event.h
   *
   * V4L2 events.
   *
   * Copyright (C) 2009--2010 Nokia Corporation.
   *
8c5dff905   Sakari Ailus   [media] v4l, smia...
8
   * Contact: Sakari Ailus <sakari.ailus@iki.fi>
c3b5b0241   Sakari Ailus   V4L/DVB: V4L: Eve...
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
   *
   * This program is free software; you can redistribute it and/or
   * modify it under the terms of the GNU General Public License
   * version 2 as published by the Free Software Foundation.
   *
   * This program is distributed in the hope that it will be useful, but
   * WITHOUT ANY WARRANTY; without even the implied warranty of
   * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
   * General Public License for more details.
   *
   * You should have received a copy of the GNU General Public License
   * along with this program; if not, write to the Free Software
   * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
   * 02110-1301 USA
   */
  
  #ifndef V4L2_EVENT_H
  #define V4L2_EVENT_H
  
  #include <linux/types.h>
  #include <linux/videodev2.h>
  #include <linux/wait.h>
3ad57c338   Hans Verkuil   [media] v4l2-even...
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
  /*
   * Overview:
   *
   * Events are subscribed per-filehandle. An event specification consists of a
   * type and is optionally associated with an object identified through the
   * 'id' field. So an event is uniquely identified by the (type, id) tuple.
   *
   * The v4l2-fh struct has a list of subscribed events. The v4l2_subscribed_event
   * struct is added to that list, one for every subscribed event.
   *
   * Each v4l2_subscribed_event struct ends with an array of v4l2_kevent structs.
   * This array (ringbuffer, really) is used to store any events raised by the
   * driver. The v4l2_kevent struct links into the 'available' list of the
   * v4l2_fh struct so VIDIOC_DQEVENT will know which event to dequeue first.
   *
   * Finally, if the event subscription is associated with a particular object
   * such as a V4L2 control, then that object needs to know about that as well
   * so that an event can be raised by that object. So the 'node' field can
   * be used to link the v4l2_subscribed_event struct into a list of that
   * object.
   *
   * So to summarize:
   *
   * struct v4l2_fh has two lists: one of the subscribed events, and one of the
   * pending events.
   *
   * struct v4l2_subscribed_event has a ringbuffer of raised (pending) events of
   * that particular type.
   *
   * If struct v4l2_subscribed_event is associated with a specific object, then
   * that object will have an internal list of struct v4l2_subscribed_event so
   * it knows who subscribed an event to that object.
   */
c3b5b0241   Sakari Ailus   V4L/DVB: V4L: Eve...
64
  struct v4l2_fh;
4f4d14b70   Sylwester Nawrocki   [media] V4L: Add ...
65
  struct v4l2_subdev;
f1e393de3   Hans Verkuil   [media] v4l2-even...
66
  struct v4l2_subscribed_event;
c3b5b0241   Sakari Ailus   V4L/DVB: V4L: Eve...
67
  struct video_device;
b6fce850d   Mauro Carvalho Chehab   [media] v4l2-even...
68
69
70
71
72
  /**
   * 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.
9d4ee1ad9   Mauro Carvalho Chehab   [media] v4l2-even...
73
   */
c3b5b0241   Sakari Ailus   V4L/DVB: V4L: Eve...
74
75
  struct v4l2_kevent {
  	struct list_head	list;
f1e393de3   Hans Verkuil   [media] v4l2-even...
76
  	struct v4l2_subscribed_event *sev;
c3b5b0241   Sakari Ailus   V4L/DVB: V4L: Eve...
77
78
  	struct v4l2_event	event;
  };
9d4ee1ad9   Mauro Carvalho Chehab   [media] v4l2-even...
79
80
  /**
   * struct v4l2_subscribed_event_ops - Subscribed event operations.
b6fce850d   Mauro Carvalho Chehab   [media] v4l2-even...
81
82
83
84
85
86
   *
   * @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'.
   */
c53c25493   Hans de Goede   [media] v4l2-even...
87
  struct v4l2_subscribed_event_ops {
9d4ee1ad9   Mauro Carvalho Chehab   [media] v4l2-even...
88
  	int  (*add)(struct v4l2_subscribed_event *sev, unsigned int elems);
c53c25493   Hans de Goede   [media] v4l2-even...
89
90
91
92
  	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);
  };
b6fce850d   Mauro Carvalho Chehab   [media] v4l2-even...
93
  /**
9d4ee1ad9   Mauro Carvalho Chehab   [media] v4l2-even...
94
95
96
   * struct v4l2_subscribed_event - Internal struct representing a subscribed
   *		event.
   *
b6fce850d   Mauro Carvalho Chehab   [media] v4l2-even...
97
98
99
100
101
   * @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.
9d4ee1ad9   Mauro Carvalho Chehab   [media] v4l2-even...
102
103
   * @node:	List node that hooks into the object's event list
   *		(if there is one).
b6fce850d   Mauro Carvalho Chehab   [media] v4l2-even...
104
105
106
107
108
109
   * @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.
   */
c3b5b0241   Sakari Ailus   V4L/DVB: V4L: Eve...
110
111
112
  struct v4l2_subscribed_event {
  	struct list_head	list;
  	u32			type;
6e239399e   Hans Verkuil   [media] v4l2-ctrl...
113
  	u32			id;
77068d36d   Hans Verkuil   [media] v4l2-ctrl...
114
  	u32			flags;
77068d36d   Hans Verkuil   [media] v4l2-ctrl...
115
  	struct v4l2_fh		*fh;
77068d36d   Hans Verkuil   [media] v4l2-ctrl...
116
  	struct list_head	node;
c53c25493   Hans de Goede   [media] v4l2-even...
117
  	const struct v4l2_subscribed_event_ops *ops;
9d4ee1ad9   Mauro Carvalho Chehab   [media] v4l2-even...
118
119
120
  	unsigned int		elems;
  	unsigned int		first;
  	unsigned int		in_use;
f1e393de3   Hans Verkuil   [media] v4l2-even...
121
  	struct v4l2_kevent	events[];
c3b5b0241   Sakari Ailus   V4L/DVB: V4L: Eve...
122
  };
9d4ee1ad9   Mauro Carvalho Chehab   [media] v4l2-even...
123
124
125
126
127
128
129
  /**
   * 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
   */
c3b5b0241   Sakari Ailus   V4L/DVB: V4L: Eve...
130
131
  int v4l2_event_dequeue(struct v4l2_fh *fh, struct v4l2_event *event,
  		       int nonblocking);
9d4ee1ad9   Mauro Carvalho Chehab   [media] v4l2-even...
132
133
134
135
136
137
138
139
140
141
142
143
144
  
  /**
   * 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
   *    fields.The other fields will be filled in by  V4L2.
   */
c3b5b0241   Sakari Ailus   V4L/DVB: V4L: Eve...
145
  void v4l2_event_queue(struct video_device *vdev, const struct v4l2_event *ev);
9d4ee1ad9   Mauro Carvalho Chehab   [media] v4l2-even...
146
147
148
149
150
151
152
153
154
155
156
157
158
159
  
  /**
   * 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
   *    fields.The other fields will be filled in by  V4L2.
   */
6e239399e   Hans Verkuil   [media] v4l2-ctrl...
160
  void v4l2_event_queue_fh(struct v4l2_fh *fh, const struct v4l2_event *ev);
9d4ee1ad9   Mauro Carvalho Chehab   [media] v4l2-even...
161
162
163
164
165
166
167
168
  
  /**
   * v4l2_event_pending - Check if an event is available
   *
   * @fh: pointer to &struct v4l2_fh
   *
   * Returns the number of pending events.
   */
c3b5b0241   Sakari Ailus   V4L/DVB: V4L: Eve...
169
  int v4l2_event_pending(struct v4l2_fh *fh);
9d4ee1ad9   Mauro Carvalho Chehab   [media] v4l2-even...
170
171
172
173
174
175
176
177
178
179
180
181
182
183
  
  /**
   * 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.
   */
c3b5b0241   Sakari Ailus   V4L/DVB: V4L: Eve...
184
  int v4l2_event_subscribe(struct v4l2_fh *fh,
9d4ee1ad9   Mauro Carvalho Chehab   [media] v4l2-even...
185
186
  			 const struct v4l2_event_subscription *sub,
  			 unsigned int elems,
c53c25493   Hans de Goede   [media] v4l2-even...
187
  			 const struct v4l2_subscribed_event_ops *ops);
9d4ee1ad9   Mauro Carvalho Chehab   [media] v4l2-even...
188
189
190
191
192
193
  /**
   * v4l2_event_unsubscribe - Unsubscribes to an event
   *
   * @fh: pointer to &struct v4l2_fh
   * @sub: pointer to &struct v4l2_event_subscription
   */
c3b5b0241   Sakari Ailus   V4L/DVB: V4L: Eve...
194
  int v4l2_event_unsubscribe(struct v4l2_fh *fh,
85f5fe396   Hans Verkuil   [media] v4l2: mak...
195
  			   const struct v4l2_event_subscription *sub);
9d4ee1ad9   Mauro Carvalho Chehab   [media] v4l2-even...
196
197
198
199
200
  /**
   * v4l2_event_unsubscribe_all - Unsubscribes to all events
   *
   * @fh: pointer to &struct v4l2_fh
   */
f1e393de3   Hans Verkuil   [media] v4l2-even...
201
  void v4l2_event_unsubscribe_all(struct v4l2_fh *fh);
9d4ee1ad9   Mauro Carvalho Chehab   [media] v4l2-even...
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
  
  /**
   * 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,
4f4d14b70   Sylwester Nawrocki   [media] V4L: Add ...
217
  				  struct v4l2_event_subscription *sub);
9d4ee1ad9   Mauro Carvalho Chehab   [media] v4l2-even...
218
  /**
e383ce073   Mauro Carvalho Chehab   [media] get rid o...
219
220
   * v4l2_src_change_event_subscribe - helper function that calls
   * 	v4l2_event_subscribe() if the event is %V4L2_EVENT_SOURCE_CHANGE.
9d4ee1ad9   Mauro Carvalho Chehab   [media] v4l2-even...
221
222
223
224
   *
   * @fh: pointer to struct v4l2_fh
   * @sub: pointer to &struct v4l2_event_subscription
   */
3cbe6e5bc   Arun Kumar K   [media] v4l: Add ...
225
  int v4l2_src_change_event_subscribe(struct v4l2_fh *fh,
9d4ee1ad9   Mauro Carvalho Chehab   [media] v4l2-even...
226
227
228
229
230
231
232
233
234
  				    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
   */
3cbe6e5bc   Arun Kumar K   [media] v4l: Add ...
235
  int v4l2_src_change_event_subdev_subscribe(struct v4l2_subdev *sd,
9d4ee1ad9   Mauro Carvalho Chehab   [media] v4l2-even...
236
237
  					   struct v4l2_fh *fh,
  					   struct v4l2_event_subscription *sub);
c3b5b0241   Sakari Ailus   V4L/DVB: V4L: Eve...
238
  #endif /* V4L2_EVENT_H */