diff options
author | Sakari Ailus <sakari.ailus@nokia.com> | 2007-07-18 16:59:15 -0400 |
---|---|---|
committer | Mauro Carvalho Chehab <mchehab@infradead.org> | 2007-10-09 21:02:51 -0400 |
commit | 9b5d0f1e6dd6b4a67d0851a1c5a4bcf9b0c2f258 (patch) | |
tree | 66760f3419e8c631fb03f0c37619a88f9b7155c1 /include/media | |
parent | bbf25010f1a6b761914430f5fca081ec8c7accd1 (diff) |
V4L/DVB (5862): V4L: Add internal ioctl-like interface.
This patch adds an internal ioctl-like interface which can be used in
situations where a single Video4Linux device is implemented by multiple
device drivers. One master device controls one or more slave devices.
The slaves provide Video4Linux ioctl-like interface for the use of the
master.
Only a handful of ioctls are implemented at the moment. More can (and
should) be added as more functionality is required.
Signed-off-by: Sakari Ailus <sakari.ailus@nokia.com>
Signed-off-by: Mauro Carvalho Chehab <mchehab@infradead.org>
Diffstat (limited to 'include/media')
-rw-r--r-- | include/media/v4l2-int-device.h | 210 |
1 files changed, 210 insertions, 0 deletions
diff --git a/include/media/v4l2-int-device.h b/include/media/v4l2-int-device.h new file mode 100644 index 000000000000..2b6fc1122f6c --- /dev/null +++ b/include/media/v4l2-int-device.h | |||
@@ -0,0 +1,210 @@ | |||
1 | /* | ||
2 | * include/media/v4l2-int-device.h | ||
3 | * | ||
4 | * V4L2 internal ioctl interface. | ||
5 | * | ||
6 | * Copyright (C) 2007 Nokia Corporation. | ||
7 | * | ||
8 | * Contact: Sakari Ailus <sakari.ailus@nokia.com> | ||
9 | * | ||
10 | * This program is free software; you can redistribute it and/or | ||
11 | * modify it under the terms of the GNU General Public License | ||
12 | * version 2 as published by the Free Software Foundation. | ||
13 | * | ||
14 | * This program is distributed in the hope that it will be useful, but | ||
15 | * WITHOUT ANY WARRANTY; without even the implied warranty of | ||
16 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | ||
17 | * General Public License for more details. | ||
18 | * | ||
19 | * You should have received a copy of the GNU General Public License | ||
20 | * along with this program; if not, write to the Free Software | ||
21 | * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA | ||
22 | * 02110-1301 USA | ||
23 | */ | ||
24 | |||
25 | #ifndef V4L2_INT_DEVICE_H | ||
26 | #define V4L2_INT_DEVICE_H | ||
27 | |||
28 | #include <linux/module.h> | ||
29 | #include <media/v4l2-common.h> | ||
30 | |||
31 | #define V4L2NAMESIZE 32 | ||
32 | |||
33 | enum v4l2_int_type { | ||
34 | v4l2_int_type_master = 1, | ||
35 | v4l2_int_type_slave | ||
36 | }; | ||
37 | |||
38 | enum v4l2_int_ioctl_num { | ||
39 | /* | ||
40 | * | ||
41 | * "Proper" V4L ioctls, as in struct video_device. | ||
42 | * | ||
43 | */ | ||
44 | vidioc_int_enum_fmt_cap_num = 1, | ||
45 | vidioc_int_g_fmt_cap_num, | ||
46 | vidioc_int_s_fmt_cap_num, | ||
47 | vidioc_int_try_fmt_cap_num, | ||
48 | vidioc_int_queryctrl_num, | ||
49 | vidioc_int_g_ctrl_num, | ||
50 | vidioc_int_s_ctrl_num, | ||
51 | vidioc_int_g_parm_num, | ||
52 | vidioc_int_s_parm_num, | ||
53 | |||
54 | /* | ||
55 | * | ||
56 | * Strictly internal ioctls. | ||
57 | * | ||
58 | */ | ||
59 | /* Initialise the device when slave attaches to the master. */ | ||
60 | vidioc_int_dev_init_num = 1000, | ||
61 | /* Delinitialise the device at slave detach. */ | ||
62 | vidioc_int_dev_exit_num, | ||
63 | /* Set device power state: 0 is off, non-zero is on. */ | ||
64 | vidioc_int_s_power_num, | ||
65 | /* Get parallel interface clock speed for current settings. */ | ||
66 | vidioc_int_g_ext_clk_num, | ||
67 | /* | ||
68 | * Tell what the parallel interface clock speed actually is. | ||
69 | */ | ||
70 | vidioc_int_s_ext_clk_num, | ||
71 | /* Does the slave need to be reset after VIDIOC_DQBUF? */ | ||
72 | vidioc_int_g_needs_reset_num, | ||
73 | |||
74 | /* | ||
75 | * | ||
76 | * VIDIOC_INT_* ioctls. | ||
77 | * | ||
78 | */ | ||
79 | /* VIDIOC_INT_RESET */ | ||
80 | vidioc_int_reset_num, | ||
81 | /* VIDIOC_INT_INIT */ | ||
82 | vidioc_int_init_num, | ||
83 | /* VIDIOC_INT_G_CHIP_IDENT */ | ||
84 | vidioc_int_g_chip_ident_num, | ||
85 | |||
86 | /* | ||
87 | * | ||
88 | * Start of private ioctls. | ||
89 | * | ||
90 | */ | ||
91 | vidioc_int_priv_start_num = 2000, | ||
92 | }; | ||
93 | |||
94 | struct v4l2_int_device; | ||
95 | |||
96 | struct v4l2_int_master { | ||
97 | int (*attach)(struct v4l2_int_device *master, | ||
98 | struct v4l2_int_device *slave); | ||
99 | void (*detach)(struct v4l2_int_device *master); | ||
100 | }; | ||
101 | |||
102 | typedef int (v4l2_int_ioctl_func)(struct v4l2_int_device *); | ||
103 | typedef int (v4l2_int_ioctl_func_0)(struct v4l2_int_device *); | ||
104 | typedef int (v4l2_int_ioctl_func_1)(struct v4l2_int_device *, void *); | ||
105 | |||
106 | struct v4l2_int_ioctl_desc { | ||
107 | int num; | ||
108 | v4l2_int_ioctl_func *func; | ||
109 | }; | ||
110 | |||
111 | struct v4l2_int_slave { | ||
112 | /* Don't touch master. */ | ||
113 | struct v4l2_int_device *master; | ||
114 | |||
115 | char attach_to[V4L2NAMESIZE]; | ||
116 | |||
117 | int num_ioctls; | ||
118 | struct v4l2_int_ioctl_desc *ioctls; | ||
119 | }; | ||
120 | |||
121 | struct v4l2_int_device { | ||
122 | /* Don't touch head. */ | ||
123 | struct list_head head; | ||
124 | |||
125 | struct module *module; | ||
126 | |||
127 | char name[V4L2NAMESIZE]; | ||
128 | |||
129 | enum v4l2_int_type type; | ||
130 | union { | ||
131 | struct v4l2_int_master *master; | ||
132 | struct v4l2_int_slave *slave; | ||
133 | } u; | ||
134 | |||
135 | void *priv; | ||
136 | }; | ||
137 | |||
138 | int v4l2_int_device_register(struct v4l2_int_device *d); | ||
139 | void v4l2_int_device_unregister(struct v4l2_int_device *d); | ||
140 | |||
141 | int v4l2_int_ioctl_0(struct v4l2_int_device *d, int cmd); | ||
142 | int v4l2_int_ioctl_1(struct v4l2_int_device *d, int cmd, void *arg); | ||
143 | |||
144 | /* | ||
145 | * | ||
146 | * IOCTL wrapper functions for better type checking. | ||
147 | * | ||
148 | */ | ||
149 | |||
150 | #define V4L2_INT_WRAPPER_0(name) \ | ||
151 | static inline int vidioc_int_##name(struct v4l2_int_device *d) \ | ||
152 | { \ | ||
153 | return v4l2_int_ioctl_0(d, vidioc_int_##name##_num); \ | ||
154 | } \ | ||
155 | \ | ||
156 | static inline struct v4l2_int_ioctl_desc \ | ||
157 | vidioc_int_##name##_cb(int (*func) \ | ||
158 | (struct v4l2_int_device *)) \ | ||
159 | { \ | ||
160 | struct v4l2_int_ioctl_desc desc; \ | ||
161 | \ | ||
162 | desc.num = vidioc_int_##name##_num; \ | ||
163 | desc.func = (v4l2_int_ioctl_func *)func; \ | ||
164 | \ | ||
165 | return desc; \ | ||
166 | } | ||
167 | |||
168 | #define V4L2_INT_WRAPPER_1(name, arg_type, asterisk) \ | ||
169 | static inline int vidioc_int_##name(struct v4l2_int_device *d, \ | ||
170 | arg_type asterisk arg) \ | ||
171 | { \ | ||
172 | return v4l2_int_ioctl_1(d, vidioc_int_##name##_num, \ | ||
173 | (void *)arg); \ | ||
174 | } \ | ||
175 | \ | ||
176 | static inline struct v4l2_int_ioctl_desc \ | ||
177 | vidioc_int_##name##_cb(int (*func) \ | ||
178 | (struct v4l2_int_device *, \ | ||
179 | arg_type asterisk)) \ | ||
180 | { \ | ||
181 | struct v4l2_int_ioctl_desc desc; \ | ||
182 | \ | ||
183 | desc.num = vidioc_int_##name##_num; \ | ||
184 | desc.func = (v4l2_int_ioctl_func *)func; \ | ||
185 | \ | ||
186 | return desc; \ | ||
187 | } | ||
188 | |||
189 | V4L2_INT_WRAPPER_1(enum_fmt_cap, struct v4l2_fmtdesc, *); | ||
190 | V4L2_INT_WRAPPER_1(g_fmt_cap, struct v4l2_format, *); | ||
191 | V4L2_INT_WRAPPER_1(s_fmt_cap, struct v4l2_format, *); | ||
192 | V4L2_INT_WRAPPER_1(try_fmt_cap, struct v4l2_format, *); | ||
193 | V4L2_INT_WRAPPER_1(queryctrl, struct v4l2_queryctrl, *); | ||
194 | V4L2_INT_WRAPPER_1(g_ctrl, struct v4l2_control, *); | ||
195 | V4L2_INT_WRAPPER_1(s_ctrl, struct v4l2_control, *); | ||
196 | V4L2_INT_WRAPPER_1(g_parm, struct v4l2_streamparm, *); | ||
197 | V4L2_INT_WRAPPER_1(s_parm, struct v4l2_streamparm, *); | ||
198 | |||
199 | V4L2_INT_WRAPPER_0(dev_init); | ||
200 | V4L2_INT_WRAPPER_0(dev_exit); | ||
201 | V4L2_INT_WRAPPER_1(s_power, int, ); | ||
202 | V4L2_INT_WRAPPER_1(s_ext_clk, u32, ); | ||
203 | V4L2_INT_WRAPPER_1(g_ext_clk, u32, *); | ||
204 | V4L2_INT_WRAPPER_1(g_needs_reset, void, *); | ||
205 | |||
206 | V4L2_INT_WRAPPER_0(reset); | ||
207 | V4L2_INT_WRAPPER_0(init); | ||
208 | V4L2_INT_WRAPPER_1(g_chip_ident, int, *); | ||
209 | |||
210 | #endif | ||