1 // SPDX-License-Identifier: GPL-2.0-only
2 
3 /*
4  * vivid-core.c - A Virtual Video Test Driver, core initialization
5  *
6  * Copyright 2014 Cisco Systems, Inc. and/or its affiliates. All rights reserved.
7  */
8 
9 #include <linux/module.h>
10 #include <linux/errno.h>
11 #include <linux/kernel.h>
12 #include <linux/init.h>
13 #include <linux/sched.h>
14 #include <linux/slab.h>
15 #include <linux/vmalloc.h>
16 #include <linux/font.h>
17 #include <linux/mutex.h>
18 #include <linux/platform_device.h>
19 #include <linux/videodev2.h>
20 #include <linux/v4l2-dv-timings.h>
21 #include <media/videobuf2-vmalloc.h>
22 #include <media/videobuf2-dma-contig.h>
23 #include <media/v4l2-dv-timings.h>
24 #include <media/v4l2-ioctl.h>
25 #include <media/v4l2-fh.h>
26 #include <media/v4l2-event.h>
27 
28 #include "vivid-core.h"
29 #include "vivid-vid-common.h"
30 #include "vivid-vid-cap.h"
31 #include "vivid-vid-out.h"
32 #include "vivid-radio-common.h"
33 #include "vivid-radio-rx.h"
34 #include "vivid-radio-tx.h"
35 #include "vivid-sdr-cap.h"
36 #include "vivid-vbi-cap.h"
37 #include "vivid-vbi-out.h"
38 #include "vivid-osd.h"
39 #include "vivid-cec.h"
40 #include "vivid-ctrls.h"
41 #include "vivid-meta-cap.h"
42 #include "vivid-meta-out.h"
43 #include "vivid-touch-cap.h"
44 
45 #define VIVID_MODULE_NAME "vivid"
46 #define MAX_STRING_LENGTH 23
47 
48 MODULE_DESCRIPTION("Virtual Video Test Driver");
49 MODULE_AUTHOR("Hans Verkuil");
50 MODULE_LICENSE("GPL");
51 
52 unsigned int n_devs = 1;
53 module_param(n_devs, uint, 0444);
54 MODULE_PARM_DESC(n_devs, " number of driver instances to create");
55 
56 static int vid_cap_nr[VIVID_MAX_DEVS] = { [0 ... (VIVID_MAX_DEVS - 1)] = -1 };
57 module_param_array(vid_cap_nr, int, NULL, 0444);
58 MODULE_PARM_DESC(vid_cap_nr, " videoX start number, -1 is autodetect");
59 
60 static int vid_out_nr[VIVID_MAX_DEVS] = { [0 ... (VIVID_MAX_DEVS - 1)] = -1 };
61 module_param_array(vid_out_nr, int, NULL, 0444);
62 MODULE_PARM_DESC(vid_out_nr, " videoX start number, -1 is autodetect");
63 
64 static int vbi_cap_nr[VIVID_MAX_DEVS] = { [0 ... (VIVID_MAX_DEVS - 1)] = -1 };
65 module_param_array(vbi_cap_nr, int, NULL, 0444);
66 MODULE_PARM_DESC(vbi_cap_nr, " vbiX start number, -1 is autodetect");
67 
68 static int vbi_out_nr[VIVID_MAX_DEVS] = { [0 ... (VIVID_MAX_DEVS - 1)] = -1 };
69 module_param_array(vbi_out_nr, int, NULL, 0444);
70 MODULE_PARM_DESC(vbi_out_nr, " vbiX start number, -1 is autodetect");
71 
72 static int sdr_cap_nr[VIVID_MAX_DEVS] = { [0 ... (VIVID_MAX_DEVS - 1)] = -1 };
73 module_param_array(sdr_cap_nr, int, NULL, 0444);
74 MODULE_PARM_DESC(sdr_cap_nr, " swradioX start number, -1 is autodetect");
75 
76 static int radio_rx_nr[VIVID_MAX_DEVS] = { [0 ... (VIVID_MAX_DEVS - 1)] = -1 };
77 module_param_array(radio_rx_nr, int, NULL, 0444);
78 MODULE_PARM_DESC(radio_rx_nr, " radioX start number, -1 is autodetect");
79 
80 static int radio_tx_nr[VIVID_MAX_DEVS] = { [0 ... (VIVID_MAX_DEVS - 1)] = -1 };
81 module_param_array(radio_tx_nr, int, NULL, 0444);
82 MODULE_PARM_DESC(radio_tx_nr, " radioX start number, -1 is autodetect");
83 
84 static int meta_cap_nr[VIVID_MAX_DEVS] = { [0 ... (VIVID_MAX_DEVS - 1)] = -1 };
85 module_param_array(meta_cap_nr, int, NULL, 0444);
86 MODULE_PARM_DESC(meta_cap_nr, " videoX start number, -1 is autodetect");
87 
88 static int meta_out_nr[VIVID_MAX_DEVS] = { [0 ... (VIVID_MAX_DEVS - 1)] = -1 };
89 module_param_array(meta_out_nr, int, NULL, 0444);
90 MODULE_PARM_DESC(meta_out_nr, " videoX start number, -1 is autodetect");
91 
92 static int touch_cap_nr[VIVID_MAX_DEVS] = { [0 ... (VIVID_MAX_DEVS - 1)] = -1 };
93 module_param_array(touch_cap_nr, int, NULL, 0444);
94 MODULE_PARM_DESC(touch_cap_nr, " v4l-touchX start number, -1 is autodetect");
95 
96 static int ccs_cap_mode[VIVID_MAX_DEVS] = { [0 ... (VIVID_MAX_DEVS - 1)] = -1 };
97 module_param_array(ccs_cap_mode, int, NULL, 0444);
98 MODULE_PARM_DESC(ccs_cap_mode, " capture crop/compose/scale mode:\n"
99 			   "\t\t    bit 0=crop, 1=compose, 2=scale,\n"
100 			   "\t\t    -1=user-controlled (default)");
101 
102 static int ccs_out_mode[VIVID_MAX_DEVS] = { [0 ... (VIVID_MAX_DEVS - 1)] = -1 };
103 module_param_array(ccs_out_mode, int, NULL, 0444);
104 MODULE_PARM_DESC(ccs_out_mode, " output crop/compose/scale mode:\n"
105 			   "\t\t    bit 0=crop, 1=compose, 2=scale,\n"
106 			   "\t\t    -1=user-controlled (default)");
107 
108 static unsigned multiplanar[VIVID_MAX_DEVS] = { [0 ... (VIVID_MAX_DEVS - 1)] = 1 };
109 module_param_array(multiplanar, uint, NULL, 0444);
110 MODULE_PARM_DESC(multiplanar, " 1 (default) creates a single planar device, 2 creates a multiplanar device.");
111 
112 /*
113  * Default: video + vbi-cap (raw and sliced) + radio rx + radio tx + sdr +
114  * vbi-out + vid-out + meta-cap
115  */
116 static unsigned int node_types[VIVID_MAX_DEVS] = {
117 	[0 ... (VIVID_MAX_DEVS - 1)] = 0xe1d3d
118 };
119 module_param_array(node_types, uint, NULL, 0444);
120 MODULE_PARM_DESC(node_types, " node types, default is 0xe1d3d. Bitmask with the following meaning:\n"
121 			     "\t\t    bit 0: Video Capture node\n"
122 			     "\t\t    bit 2-3: VBI Capture node: 0 = none, 1 = raw vbi, 2 = sliced vbi, 3 = both\n"
123 			     "\t\t    bit 4: Radio Receiver node\n"
124 			     "\t\t    bit 5: Software Defined Radio Receiver node\n"
125 			     "\t\t    bit 8: Video Output node\n"
126 			     "\t\t    bit 10-11: VBI Output node: 0 = none, 1 = raw vbi, 2 = sliced vbi, 3 = both\n"
127 			     "\t\t    bit 12: Radio Transmitter node\n"
128 			     "\t\t    bit 16: Framebuffer for testing output overlays\n"
129 			     "\t\t    bit 17: Metadata Capture node\n"
130 			     "\t\t    bit 18: Metadata Output node\n"
131 			     "\t\t    bit 19: Touch Capture node\n");
132 
133 /* Default: 4 inputs */
134 static unsigned num_inputs[VIVID_MAX_DEVS] = { [0 ... (VIVID_MAX_DEVS - 1)] = 4 };
135 module_param_array(num_inputs, uint, NULL, 0444);
136 MODULE_PARM_DESC(num_inputs, " number of inputs, default is 4");
137 
138 /* Default: input 0 = WEBCAM, 1 = TV, 2 = SVID, 3 = HDMI */
139 static unsigned input_types[VIVID_MAX_DEVS] = { [0 ... (VIVID_MAX_DEVS - 1)] = 0xe4 };
140 module_param_array(input_types, uint, NULL, 0444);
141 MODULE_PARM_DESC(input_types, " input types, default is 0xe4. Two bits per input,\n"
142 			      "\t\t    bits 0-1 == input 0, bits 31-30 == input 15.\n"
143 			      "\t\t    Type 0 == webcam, 1 == TV, 2 == S-Video, 3 == HDMI");
144 
145 /* Default: 2 outputs */
146 static unsigned num_outputs[VIVID_MAX_DEVS] = { [0 ... (VIVID_MAX_DEVS - 1)] = 2 };
147 module_param_array(num_outputs, uint, NULL, 0444);
148 MODULE_PARM_DESC(num_outputs, " number of outputs, default is 2");
149 
150 /* Default: output 0 = SVID, 1 = HDMI */
151 static unsigned output_types[VIVID_MAX_DEVS] = { [0 ... (VIVID_MAX_DEVS - 1)] = 2 };
152 module_param_array(output_types, uint, NULL, 0444);
153 MODULE_PARM_DESC(output_types, " output types, default is 0x02. One bit per output,\n"
154 			      "\t\t    bit 0 == output 0, bit 15 == output 15.\n"
155 			      "\t\t    Type 0 == S-Video, 1 == HDMI");
156 
157 unsigned vivid_debug;
158 module_param(vivid_debug, uint, 0644);
159 MODULE_PARM_DESC(vivid_debug, " activates debug info");
160 
161 static bool no_error_inj;
162 module_param(no_error_inj, bool, 0444);
163 MODULE_PARM_DESC(no_error_inj, " if set disable the error injecting controls");
164 
165 static unsigned int allocators[VIVID_MAX_DEVS] = { [0 ... (VIVID_MAX_DEVS - 1)] = 0 };
166 module_param_array(allocators, uint, NULL, 0444);
167 MODULE_PARM_DESC(allocators, " memory allocator selection, default is 0.\n"
168 			     "\t\t    0 == vmalloc\n"
169 			     "\t\t    1 == dma-contig");
170 
171 static unsigned int cache_hints[VIVID_MAX_DEVS] = {
172 	[0 ... (VIVID_MAX_DEVS - 1)] = 0
173 };
174 module_param_array(cache_hints, uint, NULL, 0444);
175 MODULE_PARM_DESC(cache_hints, " user-space cache hints, default is 0.\n"
176 			     "\t\t    0 == forbid\n"
177 			     "\t\t    1 == allow");
178 
179 static unsigned int supports_requests[VIVID_MAX_DEVS] = {
180 	[0 ... (VIVID_MAX_DEVS - 1)] = 1
181 };
182 module_param_array(supports_requests, uint, NULL, 0444);
183 MODULE_PARM_DESC(supports_requests, " support for requests, default is 1.\n"
184 			     "\t\t    0 == no support\n"
185 			     "\t\t    1 == supports requests\n"
186 			     "\t\t    2 == requires requests");
187 
188 struct vivid_dev *vivid_devs[VIVID_MAX_DEVS];
189 
190 DEFINE_SPINLOCK(hdmi_output_skip_mask_lock);
191 struct workqueue_struct *update_hdmi_ctrls_workqueue;
192 u64 hdmi_to_output_menu_skip_mask;
193 u64 hdmi_input_update_outputs_mask;
194 
195 struct vivid_dev *vivid_ctrl_hdmi_to_output_instance[MAX_MENU_ITEMS];
196 unsigned int vivid_ctrl_hdmi_to_output_index[MAX_MENU_ITEMS];
197 
198 char *vivid_ctrl_hdmi_to_output_strings[MAX_MENU_ITEMS + 1] = {
199 	"Test Pattern Generator",
200 	"None"
201 };
202 
203 DEFINE_SPINLOCK(svid_output_skip_mask_lock);
204 struct workqueue_struct *update_svid_ctrls_workqueue;
205 u64 svid_to_output_menu_skip_mask;
206 
207 struct vivid_dev *vivid_ctrl_svid_to_output_instance[MAX_MENU_ITEMS];
208 unsigned int vivid_ctrl_svid_to_output_index[MAX_MENU_ITEMS];
209 
210 char *vivid_ctrl_svid_to_output_strings[MAX_MENU_ITEMS + 1] = {
211 	"Test Pattern Generator",
212 	"None"
213 };
214 
215 const struct v4l2_rect vivid_min_rect = {
216 	0, 0, MIN_WIDTH, MIN_HEIGHT
217 };
218 
219 const struct v4l2_rect vivid_max_rect = {
220 	0, 0, MAX_WIDTH * MAX_ZOOM, MAX_HEIGHT * MAX_ZOOM
221 };
222 
223 static const u8 vivid_hdmi_edid[256] = {
224 	0x00, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00,
225 	0x31, 0xd8, 0x34, 0x12, 0x00, 0x00, 0x00, 0x00,
226 	0x22, 0x1a, 0x01, 0x03, 0x80, 0x60, 0x36, 0x78,
227 	0x0f, 0xee, 0x91, 0xa3, 0x54, 0x4c, 0x99, 0x26,
228 	0x0f, 0x50, 0x54, 0x2f, 0xcf, 0x00, 0x31, 0x59,
229 	0x45, 0x59, 0x81, 0x80, 0x81, 0x40, 0x90, 0x40,
230 	0x95, 0x00, 0xa9, 0x40, 0xb3, 0x00, 0x08, 0xe8,
231 	0x00, 0x30, 0xf2, 0x70, 0x5a, 0x80, 0xb0, 0x58,
232 	0x8a, 0x00, 0xc0, 0x1c, 0x32, 0x00, 0x00, 0x1e,
233 	0x00, 0x00, 0x00, 0xfd, 0x00, 0x18, 0x55, 0x18,
234 	0x87, 0x3c, 0x00, 0x0a, 0x20, 0x20, 0x20, 0x20,
235 	0x20, 0x20, 0x00, 0x00, 0x00, 0xfc, 0x00, 0x76,
236 	0x69, 0x76, 0x69, 0x64, 0x0a, 0x20, 0x20, 0x20,
237 	0x20, 0x20, 0x20, 0x20, 0x00, 0x00, 0x00, 0x10,
238 	0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
239 	0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x01, 0x7b,
240 
241 	0x02, 0x03, 0x3f, 0xf1, 0x51, 0x61, 0x60, 0x5f,
242 	0x5e, 0x5d, 0x10, 0x1f, 0x04, 0x13, 0x22, 0x21,
243 	0x20, 0x05, 0x14, 0x02, 0x11, 0x01, 0x23, 0x09,
244 	0x07, 0x07, 0x83, 0x01, 0x00, 0x00, 0x6d, 0x03,
245 	0x0c, 0x00, 0x00, 0x00, 0x00, 0x3c, 0x21, 0x00,
246 	0x60, 0x01, 0x02, 0x03, 0x67, 0xd8, 0x5d, 0xc4,
247 	0x01, 0x78, 0x00, 0x00, 0xe2, 0x00, 0xca, 0xe3,
248 	0x05, 0x00, 0x00, 0xe3, 0x06, 0x01, 0x00, 0x4d,
249 	0xd0, 0x00, 0xa0, 0xf0, 0x70, 0x3e, 0x80, 0x30,
250 	0x20, 0x35, 0x00, 0xc0, 0x1c, 0x32, 0x00, 0x00,
251 	0x1e, 0x1a, 0x36, 0x80, 0xa0, 0x70, 0x38, 0x1f,
252 	0x40, 0x30, 0x20, 0x35, 0x00, 0xc0, 0x1c, 0x32,
253 	0x00, 0x00, 0x1a, 0x1a, 0x1d, 0x00, 0x80, 0x51,
254 	0xd0, 0x1c, 0x20, 0x40, 0x80, 0x35, 0x00, 0xc0,
255 	0x1c, 0x32, 0x00, 0x00, 0x1c, 0x00, 0x00, 0x00,
256 	0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x92,
257 };
258 
vidioc_querycap(struct file * file,void * priv,struct v4l2_capability * cap)259 static int vidioc_querycap(struct file *file, void  *priv,
260 					struct v4l2_capability *cap)
261 {
262 	struct vivid_dev *dev = video_drvdata(file);
263 
264 	strscpy(cap->driver, "vivid", sizeof(cap->driver));
265 	strscpy(cap->card, "vivid", sizeof(cap->card));
266 	snprintf(cap->bus_info, sizeof(cap->bus_info),
267 		 "platform:%s-%03d", VIVID_MODULE_NAME, dev->inst);
268 
269 	cap->capabilities = dev->vid_cap_caps | dev->vid_out_caps |
270 		dev->vbi_cap_caps | dev->vbi_out_caps |
271 		dev->radio_rx_caps | dev->radio_tx_caps |
272 		dev->sdr_cap_caps | dev->meta_cap_caps |
273 		dev->meta_out_caps | dev->touch_cap_caps |
274 		V4L2_CAP_DEVICE_CAPS;
275 	return 0;
276 }
277 
vidioc_s_hw_freq_seek(struct file * file,void * fh,const struct v4l2_hw_freq_seek * a)278 static int vidioc_s_hw_freq_seek(struct file *file, void *fh, const struct v4l2_hw_freq_seek *a)
279 {
280 	struct video_device *vdev = video_devdata(file);
281 
282 	if (vdev->vfl_type == VFL_TYPE_RADIO)
283 		return vivid_radio_rx_s_hw_freq_seek(file, fh, a);
284 	return -ENOTTY;
285 }
286 
vidioc_enum_freq_bands(struct file * file,void * fh,struct v4l2_frequency_band * band)287 static int vidioc_enum_freq_bands(struct file *file, void *fh, struct v4l2_frequency_band *band)
288 {
289 	struct video_device *vdev = video_devdata(file);
290 
291 	if (vdev->vfl_type == VFL_TYPE_RADIO)
292 		return vivid_radio_rx_enum_freq_bands(file, fh, band);
293 	if (vdev->vfl_type == VFL_TYPE_SDR)
294 		return vivid_sdr_enum_freq_bands(file, fh, band);
295 	return -ENOTTY;
296 }
297 
vidioc_g_tuner(struct file * file,void * fh,struct v4l2_tuner * vt)298 static int vidioc_g_tuner(struct file *file, void *fh, struct v4l2_tuner *vt)
299 {
300 	struct video_device *vdev = video_devdata(file);
301 
302 	if (vdev->vfl_type == VFL_TYPE_RADIO)
303 		return vivid_radio_rx_g_tuner(file, fh, vt);
304 	if (vdev->vfl_type == VFL_TYPE_SDR)
305 		return vivid_sdr_g_tuner(file, fh, vt);
306 	return vivid_video_g_tuner(file, fh, vt);
307 }
308 
vidioc_s_tuner(struct file * file,void * fh,const struct v4l2_tuner * vt)309 static int vidioc_s_tuner(struct file *file, void *fh, const struct v4l2_tuner *vt)
310 {
311 	struct video_device *vdev = video_devdata(file);
312 
313 	if (vdev->vfl_type == VFL_TYPE_RADIO)
314 		return vivid_radio_rx_s_tuner(file, fh, vt);
315 	if (vdev->vfl_type == VFL_TYPE_SDR)
316 		return vivid_sdr_s_tuner(file, fh, vt);
317 	return vivid_video_s_tuner(file, fh, vt);
318 }
319 
vidioc_g_frequency(struct file * file,void * fh,struct v4l2_frequency * vf)320 static int vidioc_g_frequency(struct file *file, void *fh, struct v4l2_frequency *vf)
321 {
322 	struct vivid_dev *dev = video_drvdata(file);
323 	struct video_device *vdev = video_devdata(file);
324 
325 	if (vdev->vfl_type == VFL_TYPE_RADIO)
326 		return vivid_radio_g_frequency(file,
327 			vdev->vfl_dir == VFL_DIR_RX ?
328 			&dev->radio_rx_freq : &dev->radio_tx_freq, vf);
329 	if (vdev->vfl_type == VFL_TYPE_SDR)
330 		return vivid_sdr_g_frequency(file, fh, vf);
331 	return vivid_video_g_frequency(file, fh, vf);
332 }
333 
vidioc_s_frequency(struct file * file,void * fh,const struct v4l2_frequency * vf)334 static int vidioc_s_frequency(struct file *file, void *fh, const struct v4l2_frequency *vf)
335 {
336 	struct vivid_dev *dev = video_drvdata(file);
337 	struct video_device *vdev = video_devdata(file);
338 
339 	if (vdev->vfl_type == VFL_TYPE_RADIO)
340 		return vivid_radio_s_frequency(file,
341 			vdev->vfl_dir == VFL_DIR_RX ?
342 			&dev->radio_rx_freq : &dev->radio_tx_freq, vf);
343 	if (vdev->vfl_type == VFL_TYPE_SDR)
344 		return vivid_sdr_s_frequency(file, fh, vf);
345 	return vivid_video_s_frequency(file, fh, vf);
346 }
347 
vidioc_overlay(struct file * file,void * fh,unsigned i)348 static int vidioc_overlay(struct file *file, void *fh, unsigned i)
349 {
350 	struct video_device *vdev = video_devdata(file);
351 
352 	if (vdev->vfl_dir == VFL_DIR_RX)
353 		return -ENOTTY;
354 	return vivid_vid_out_overlay(file, fh, i);
355 }
356 
vidioc_g_fbuf(struct file * file,void * fh,struct v4l2_framebuffer * a)357 static int vidioc_g_fbuf(struct file *file, void *fh, struct v4l2_framebuffer *a)
358 {
359 	struct video_device *vdev = video_devdata(file);
360 
361 	if (vdev->vfl_dir == VFL_DIR_RX)
362 		return -ENOTTY;
363 	return vivid_vid_out_g_fbuf(file, fh, a);
364 }
365 
vidioc_s_fbuf(struct file * file,void * fh,const struct v4l2_framebuffer * a)366 static int vidioc_s_fbuf(struct file *file, void *fh, const struct v4l2_framebuffer *a)
367 {
368 	struct video_device *vdev = video_devdata(file);
369 
370 	if (vdev->vfl_dir == VFL_DIR_RX)
371 		return -ENOTTY;
372 	return vivid_vid_out_s_fbuf(file, fh, a);
373 }
374 
vidioc_s_std(struct file * file,void * fh,v4l2_std_id id)375 static int vidioc_s_std(struct file *file, void *fh, v4l2_std_id id)
376 {
377 	struct video_device *vdev = video_devdata(file);
378 
379 	if (vdev->vfl_dir == VFL_DIR_RX)
380 		return vivid_vid_cap_s_std(file, fh, id);
381 	return vivid_vid_out_s_std(file, fh, id);
382 }
383 
vidioc_s_dv_timings(struct file * file,void * fh,struct v4l2_dv_timings * timings)384 static int vidioc_s_dv_timings(struct file *file, void *fh, struct v4l2_dv_timings *timings)
385 {
386 	struct video_device *vdev = video_devdata(file);
387 
388 	if (vdev->vfl_dir == VFL_DIR_RX)
389 		return vivid_vid_cap_s_dv_timings(file, fh, timings);
390 	return vivid_vid_out_s_dv_timings(file, fh, timings);
391 }
392 
vidioc_g_pixelaspect(struct file * file,void * fh,int type,struct v4l2_fract * f)393 static int vidioc_g_pixelaspect(struct file *file, void *fh,
394 				int type, struct v4l2_fract *f)
395 {
396 	struct video_device *vdev = video_devdata(file);
397 
398 	if (vdev->vfl_dir == VFL_DIR_RX)
399 		return vivid_vid_cap_g_pixelaspect(file, fh, type, f);
400 	return vivid_vid_out_g_pixelaspect(file, fh, type, f);
401 }
402 
vidioc_g_selection(struct file * file,void * fh,struct v4l2_selection * sel)403 static int vidioc_g_selection(struct file *file, void *fh,
404 			      struct v4l2_selection *sel)
405 {
406 	struct video_device *vdev = video_devdata(file);
407 
408 	if (vdev->vfl_dir == VFL_DIR_RX)
409 		return vivid_vid_cap_g_selection(file, fh, sel);
410 	return vivid_vid_out_g_selection(file, fh, sel);
411 }
412 
vidioc_s_selection(struct file * file,void * fh,struct v4l2_selection * sel)413 static int vidioc_s_selection(struct file *file, void *fh,
414 			      struct v4l2_selection *sel)
415 {
416 	struct video_device *vdev = video_devdata(file);
417 
418 	if (vdev->vfl_dir == VFL_DIR_RX)
419 		return vivid_vid_cap_s_selection(file, fh, sel);
420 	return vivid_vid_out_s_selection(file, fh, sel);
421 }
422 
vidioc_g_parm(struct file * file,void * fh,struct v4l2_streamparm * parm)423 static int vidioc_g_parm(struct file *file, void *fh,
424 			  struct v4l2_streamparm *parm)
425 {
426 	struct video_device *vdev = video_devdata(file);
427 
428 	if (vdev->vfl_type == VFL_TYPE_TOUCH)
429 		return vivid_g_parm_tch(file, fh, parm);
430 	if (vdev->vfl_dir == VFL_DIR_RX)
431 		return vivid_vid_cap_g_parm(file, fh, parm);
432 	return vivid_vid_out_g_parm(file, fh, parm);
433 }
434 
vidioc_s_parm(struct file * file,void * fh,struct v4l2_streamparm * parm)435 static int vidioc_s_parm(struct file *file, void *fh,
436 			  struct v4l2_streamparm *parm)
437 {
438 	struct video_device *vdev = video_devdata(file);
439 
440 	if (vdev->vfl_dir == VFL_DIR_RX)
441 		return vivid_vid_cap_s_parm(file, fh, parm);
442 	return -ENOTTY;
443 }
444 
vidioc_log_status(struct file * file,void * fh)445 static int vidioc_log_status(struct file *file, void *fh)
446 {
447 	struct vivid_dev *dev = video_drvdata(file);
448 	struct video_device *vdev = video_devdata(file);
449 
450 	v4l2_ctrl_log_status(file, fh);
451 	if (vdev->vfl_dir == VFL_DIR_RX && vdev->vfl_type == VFL_TYPE_VIDEO)
452 		tpg_log_status(&dev->tpg);
453 	return 0;
454 }
455 
vivid_radio_read(struct file * file,char __user * buf,size_t size,loff_t * offset)456 static ssize_t vivid_radio_read(struct file *file, char __user *buf,
457 			 size_t size, loff_t *offset)
458 {
459 	struct video_device *vdev = video_devdata(file);
460 
461 	if (vdev->vfl_dir == VFL_DIR_TX)
462 		return -EINVAL;
463 	return vivid_radio_rx_read(file, buf, size, offset);
464 }
465 
vivid_radio_write(struct file * file,const char __user * buf,size_t size,loff_t * offset)466 static ssize_t vivid_radio_write(struct file *file, const char __user *buf,
467 			  size_t size, loff_t *offset)
468 {
469 	struct video_device *vdev = video_devdata(file);
470 
471 	if (vdev->vfl_dir == VFL_DIR_RX)
472 		return -EINVAL;
473 	return vivid_radio_tx_write(file, buf, size, offset);
474 }
475 
vivid_radio_poll(struct file * file,struct poll_table_struct * wait)476 static __poll_t vivid_radio_poll(struct file *file, struct poll_table_struct *wait)
477 {
478 	struct video_device *vdev = video_devdata(file);
479 
480 	if (vdev->vfl_dir == VFL_DIR_RX)
481 		return vivid_radio_rx_poll(file, wait);
482 	return vivid_radio_tx_poll(file, wait);
483 }
484 
vivid_enum_input(struct file * file,void * priv,struct v4l2_input * inp)485 static int vivid_enum_input(struct file *file, void *priv,
486 			    struct v4l2_input *inp)
487 {
488 	struct video_device *vdev = video_devdata(file);
489 
490 	if (vdev->vfl_type == VFL_TYPE_TOUCH)
491 		return vivid_enum_input_tch(file, priv, inp);
492 	return vidioc_enum_input(file, priv, inp);
493 }
494 
vivid_g_input(struct file * file,void * priv,unsigned int * i)495 static int vivid_g_input(struct file *file, void *priv, unsigned int *i)
496 {
497 	struct video_device *vdev = video_devdata(file);
498 
499 	if (vdev->vfl_type == VFL_TYPE_TOUCH)
500 		return vivid_g_input_tch(file, priv, i);
501 	return vidioc_g_input(file, priv, i);
502 }
503 
vivid_s_input(struct file * file,void * priv,unsigned int i)504 static int vivid_s_input(struct file *file, void *priv, unsigned int i)
505 {
506 	struct video_device *vdev = video_devdata(file);
507 
508 	if (vdev->vfl_type == VFL_TYPE_TOUCH)
509 		return vivid_s_input_tch(file, priv, i);
510 	return vidioc_s_input(file, priv, i);
511 }
512 
vivid_enum_fmt_cap(struct file * file,void * priv,struct v4l2_fmtdesc * f)513 static int vivid_enum_fmt_cap(struct file *file, void  *priv,
514 			      struct v4l2_fmtdesc *f)
515 {
516 	struct video_device *vdev = video_devdata(file);
517 
518 	if (vdev->vfl_type == VFL_TYPE_TOUCH)
519 		return vivid_enum_fmt_tch(file, priv, f);
520 	return vivid_enum_fmt_vid(file, priv, f);
521 }
522 
vivid_g_fmt_cap(struct file * file,void * priv,struct v4l2_format * f)523 static int vivid_g_fmt_cap(struct file *file, void *priv,
524 			   struct v4l2_format *f)
525 {
526 	struct video_device *vdev = video_devdata(file);
527 
528 	if (vdev->vfl_type == VFL_TYPE_TOUCH)
529 		return vivid_g_fmt_tch(file, priv, f);
530 	return vidioc_g_fmt_vid_cap(file, priv, f);
531 }
532 
vivid_try_fmt_cap(struct file * file,void * priv,struct v4l2_format * f)533 static int vivid_try_fmt_cap(struct file *file, void *priv,
534 			     struct v4l2_format *f)
535 {
536 	struct video_device *vdev = video_devdata(file);
537 
538 	if (vdev->vfl_type == VFL_TYPE_TOUCH)
539 		return vivid_g_fmt_tch(file, priv, f);
540 	return vidioc_try_fmt_vid_cap(file, priv, f);
541 }
542 
vivid_s_fmt_cap(struct file * file,void * priv,struct v4l2_format * f)543 static int vivid_s_fmt_cap(struct file *file, void *priv,
544 			   struct v4l2_format *f)
545 {
546 	struct video_device *vdev = video_devdata(file);
547 
548 	if (vdev->vfl_type == VFL_TYPE_TOUCH)
549 		return vivid_g_fmt_tch(file, priv, f);
550 	return vidioc_s_fmt_vid_cap(file, priv, f);
551 }
552 
vivid_g_fmt_cap_mplane(struct file * file,void * priv,struct v4l2_format * f)553 static int vivid_g_fmt_cap_mplane(struct file *file, void *priv,
554 				  struct v4l2_format *f)
555 {
556 	struct video_device *vdev = video_devdata(file);
557 
558 	if (vdev->vfl_type == VFL_TYPE_TOUCH)
559 		return vivid_g_fmt_tch_mplane(file, priv, f);
560 	return vidioc_g_fmt_vid_cap_mplane(file, priv, f);
561 }
562 
vivid_try_fmt_cap_mplane(struct file * file,void * priv,struct v4l2_format * f)563 static int vivid_try_fmt_cap_mplane(struct file *file, void *priv,
564 				    struct v4l2_format *f)
565 {
566 	struct video_device *vdev = video_devdata(file);
567 
568 	if (vdev->vfl_type == VFL_TYPE_TOUCH)
569 		return vivid_g_fmt_tch_mplane(file, priv, f);
570 	return vidioc_try_fmt_vid_cap_mplane(file, priv, f);
571 }
572 
vivid_s_fmt_cap_mplane(struct file * file,void * priv,struct v4l2_format * f)573 static int vivid_s_fmt_cap_mplane(struct file *file, void *priv,
574 				  struct v4l2_format *f)
575 {
576 	struct video_device *vdev = video_devdata(file);
577 
578 	if (vdev->vfl_type == VFL_TYPE_TOUCH)
579 		return vivid_g_fmt_tch_mplane(file, priv, f);
580 	return vidioc_s_fmt_vid_cap_mplane(file, priv, f);
581 }
582 
vivid_is_in_use(bool valid,struct video_device * vdev)583 static bool vivid_is_in_use(bool valid, struct video_device *vdev)
584 {
585 	unsigned long flags;
586 	bool res;
587 
588 	if (!valid)
589 		return false;
590 	spin_lock_irqsave(&vdev->fh_lock, flags);
591 	res = !list_empty(&vdev->fh_list);
592 	spin_unlock_irqrestore(&vdev->fh_lock, flags);
593 	return res;
594 }
595 
vivid_is_last_user(struct vivid_dev * dev)596 static bool vivid_is_last_user(struct vivid_dev *dev)
597 {
598 	unsigned int uses =
599 		vivid_is_in_use(dev->has_vid_cap, &dev->vid_cap_dev) +
600 		vivid_is_in_use(dev->has_vid_out, &dev->vid_out_dev) +
601 		vivid_is_in_use(dev->has_vbi_cap, &dev->vbi_cap_dev) +
602 		vivid_is_in_use(dev->has_vbi_out, &dev->vbi_out_dev) +
603 		vivid_is_in_use(dev->has_radio_rx, &dev->radio_rx_dev) +
604 		vivid_is_in_use(dev->has_radio_tx, &dev->radio_tx_dev) +
605 		vivid_is_in_use(dev->has_sdr_cap, &dev->sdr_cap_dev) +
606 		vivid_is_in_use(dev->has_meta_cap, &dev->meta_cap_dev) +
607 		vivid_is_in_use(dev->has_meta_out, &dev->meta_out_dev) +
608 		vivid_is_in_use(dev->has_touch_cap, &dev->touch_cap_dev);
609 
610 	return uses == 1;
611 }
612 
vivid_reconnect(struct vivid_dev * dev)613 static void vivid_reconnect(struct vivid_dev *dev)
614 {
615 	if (dev->has_vid_cap)
616 		set_bit(V4L2_FL_REGISTERED, &dev->vid_cap_dev.flags);
617 	if (dev->has_vid_out)
618 		set_bit(V4L2_FL_REGISTERED, &dev->vid_out_dev.flags);
619 	if (dev->has_vbi_cap)
620 		set_bit(V4L2_FL_REGISTERED, &dev->vbi_cap_dev.flags);
621 	if (dev->has_vbi_out)
622 		set_bit(V4L2_FL_REGISTERED, &dev->vbi_out_dev.flags);
623 	if (dev->has_radio_rx)
624 		set_bit(V4L2_FL_REGISTERED, &dev->radio_rx_dev.flags);
625 	if (dev->has_radio_tx)
626 		set_bit(V4L2_FL_REGISTERED, &dev->radio_tx_dev.flags);
627 	if (dev->has_sdr_cap)
628 		set_bit(V4L2_FL_REGISTERED, &dev->sdr_cap_dev.flags);
629 	if (dev->has_meta_cap)
630 		set_bit(V4L2_FL_REGISTERED, &dev->meta_cap_dev.flags);
631 	if (dev->has_meta_out)
632 		set_bit(V4L2_FL_REGISTERED, &dev->meta_out_dev.flags);
633 	if (dev->has_touch_cap)
634 		set_bit(V4L2_FL_REGISTERED, &dev->touch_cap_dev.flags);
635 	dev->disconnect_error = false;
636 }
637 
vivid_fop_release(struct file * file)638 static int vivid_fop_release(struct file *file)
639 {
640 	struct vivid_dev *dev = video_drvdata(file);
641 	struct video_device *vdev = video_devdata(file);
642 
643 	mutex_lock(&dev->mutex);
644 	if (!no_error_inj && v4l2_fh_is_singular_file(file) &&
645 	    dev->disconnect_error && !video_is_registered(vdev) &&
646 	    vivid_is_last_user(dev)) {
647 		/*
648 		 * I am the last user of this driver, and a disconnect
649 		 * was forced (since this video_device is unregistered),
650 		 * so re-register all video_device's again.
651 		 */
652 		v4l2_info(&dev->v4l2_dev, "reconnect\n");
653 		vivid_reconnect(dev);
654 	}
655 	if (file->private_data == dev->radio_rx_rds_owner) {
656 		dev->radio_rx_rds_last_block = 0;
657 		dev->radio_rx_rds_owner = NULL;
658 	}
659 	if (file->private_data == dev->radio_tx_rds_owner) {
660 		dev->radio_tx_rds_last_block = 0;
661 		dev->radio_tx_rds_owner = NULL;
662 	}
663 	mutex_unlock(&dev->mutex);
664 	if (vdev->queue)
665 		return vb2_fop_release(file);
666 	return v4l2_fh_release(file);
667 }
668 
669 static const struct v4l2_file_operations vivid_fops = {
670 	.owner		= THIS_MODULE,
671 	.open           = v4l2_fh_open,
672 	.release        = vivid_fop_release,
673 	.read           = vb2_fop_read,
674 	.write          = vb2_fop_write,
675 	.poll		= vb2_fop_poll,
676 	.unlocked_ioctl = video_ioctl2,
677 	.mmap           = vb2_fop_mmap,
678 };
679 
680 static const struct v4l2_file_operations vivid_radio_fops = {
681 	.owner		= THIS_MODULE,
682 	.open           = v4l2_fh_open,
683 	.release        = vivid_fop_release,
684 	.read           = vivid_radio_read,
685 	.write          = vivid_radio_write,
686 	.poll		= vivid_radio_poll,
687 	.unlocked_ioctl = video_ioctl2,
688 };
689 
vidioc_reqbufs(struct file * file,void * priv,struct v4l2_requestbuffers * p)690 static int vidioc_reqbufs(struct file *file, void *priv,
691 			  struct v4l2_requestbuffers *p)
692 {
693 	struct video_device *vdev = video_devdata(file);
694 	int r;
695 
696 	/*
697 	 * Sliced and raw VBI capture share the same queue so we must
698 	 * change the type.
699 	 */
700 	if (p->type == V4L2_BUF_TYPE_SLICED_VBI_CAPTURE ||
701 	    p->type == V4L2_BUF_TYPE_VBI_CAPTURE) {
702 		r = vb2_queue_change_type(vdev->queue, p->type);
703 		if (r)
704 			return r;
705 	}
706 
707 	return vb2_ioctl_reqbufs(file, priv, p);
708 }
709 
vidioc_create_bufs(struct file * file,void * priv,struct v4l2_create_buffers * p)710 static int vidioc_create_bufs(struct file *file, void *priv,
711 			      struct v4l2_create_buffers *p)
712 {
713 	struct video_device *vdev = video_devdata(file);
714 	int r;
715 
716 	/*
717 	 * Sliced and raw VBI capture share the same queue so we must
718 	 * change the type.
719 	 */
720 	if (p->format.type == V4L2_BUF_TYPE_SLICED_VBI_CAPTURE ||
721 	    p->format.type == V4L2_BUF_TYPE_VBI_CAPTURE) {
722 		r = vb2_queue_change_type(vdev->queue, p->format.type);
723 		if (r)
724 			return r;
725 	}
726 
727 	return vb2_ioctl_create_bufs(file, priv, p);
728 }
729 
730 static const struct v4l2_ioctl_ops vivid_ioctl_ops = {
731 	.vidioc_querycap		= vidioc_querycap,
732 
733 	.vidioc_enum_fmt_vid_cap	= vivid_enum_fmt_cap,
734 	.vidioc_g_fmt_vid_cap		= vivid_g_fmt_cap,
735 	.vidioc_try_fmt_vid_cap		= vivid_try_fmt_cap,
736 	.vidioc_s_fmt_vid_cap		= vivid_s_fmt_cap,
737 	.vidioc_g_fmt_vid_cap_mplane	= vivid_g_fmt_cap_mplane,
738 	.vidioc_try_fmt_vid_cap_mplane	= vivid_try_fmt_cap_mplane,
739 	.vidioc_s_fmt_vid_cap_mplane	= vivid_s_fmt_cap_mplane,
740 
741 	.vidioc_enum_fmt_vid_out	= vivid_enum_fmt_vid,
742 	.vidioc_g_fmt_vid_out		= vidioc_g_fmt_vid_out,
743 	.vidioc_try_fmt_vid_out		= vidioc_try_fmt_vid_out,
744 	.vidioc_s_fmt_vid_out		= vidioc_s_fmt_vid_out,
745 	.vidioc_g_fmt_vid_out_mplane	= vidioc_g_fmt_vid_out_mplane,
746 	.vidioc_try_fmt_vid_out_mplane	= vidioc_try_fmt_vid_out_mplane,
747 	.vidioc_s_fmt_vid_out_mplane	= vidioc_s_fmt_vid_out_mplane,
748 
749 	.vidioc_g_selection		= vidioc_g_selection,
750 	.vidioc_s_selection		= vidioc_s_selection,
751 	.vidioc_g_pixelaspect		= vidioc_g_pixelaspect,
752 
753 	.vidioc_g_fmt_vbi_cap		= vidioc_g_fmt_vbi_cap,
754 	.vidioc_try_fmt_vbi_cap		= vidioc_g_fmt_vbi_cap,
755 	.vidioc_s_fmt_vbi_cap		= vidioc_s_fmt_vbi_cap,
756 
757 	.vidioc_g_fmt_sliced_vbi_cap    = vidioc_g_fmt_sliced_vbi_cap,
758 	.vidioc_try_fmt_sliced_vbi_cap  = vidioc_try_fmt_sliced_vbi_cap,
759 	.vidioc_s_fmt_sliced_vbi_cap    = vidioc_s_fmt_sliced_vbi_cap,
760 	.vidioc_g_sliced_vbi_cap	= vidioc_g_sliced_vbi_cap,
761 
762 	.vidioc_g_fmt_vbi_out		= vidioc_g_fmt_vbi_out,
763 	.vidioc_try_fmt_vbi_out		= vidioc_g_fmt_vbi_out,
764 	.vidioc_s_fmt_vbi_out		= vidioc_s_fmt_vbi_out,
765 
766 	.vidioc_g_fmt_sliced_vbi_out    = vidioc_g_fmt_sliced_vbi_out,
767 	.vidioc_try_fmt_sliced_vbi_out  = vidioc_try_fmt_sliced_vbi_out,
768 	.vidioc_s_fmt_sliced_vbi_out    = vidioc_s_fmt_sliced_vbi_out,
769 
770 	.vidioc_enum_fmt_sdr_cap	= vidioc_enum_fmt_sdr_cap,
771 	.vidioc_g_fmt_sdr_cap		= vidioc_g_fmt_sdr_cap,
772 	.vidioc_try_fmt_sdr_cap		= vidioc_try_fmt_sdr_cap,
773 	.vidioc_s_fmt_sdr_cap		= vidioc_s_fmt_sdr_cap,
774 
775 	.vidioc_overlay			= vidioc_overlay,
776 	.vidioc_enum_framesizes		= vidioc_enum_framesizes,
777 	.vidioc_enum_frameintervals	= vidioc_enum_frameintervals,
778 	.vidioc_g_parm			= vidioc_g_parm,
779 	.vidioc_s_parm			= vidioc_s_parm,
780 
781 	.vidioc_g_fmt_vid_out_overlay	= vidioc_g_fmt_vid_out_overlay,
782 	.vidioc_try_fmt_vid_out_overlay	= vidioc_try_fmt_vid_out_overlay,
783 	.vidioc_s_fmt_vid_out_overlay	= vidioc_s_fmt_vid_out_overlay,
784 	.vidioc_g_fbuf			= vidioc_g_fbuf,
785 	.vidioc_s_fbuf			= vidioc_s_fbuf,
786 
787 	.vidioc_reqbufs			= vidioc_reqbufs,
788 	.vidioc_create_bufs		= vidioc_create_bufs,
789 	.vidioc_prepare_buf		= vb2_ioctl_prepare_buf,
790 	.vidioc_querybuf		= vb2_ioctl_querybuf,
791 	.vidioc_qbuf			= vb2_ioctl_qbuf,
792 	.vidioc_dqbuf			= vb2_ioctl_dqbuf,
793 	.vidioc_expbuf			= vb2_ioctl_expbuf,
794 	.vidioc_streamon		= vb2_ioctl_streamon,
795 	.vidioc_streamoff		= vb2_ioctl_streamoff,
796 	.vidioc_remove_bufs		= vb2_ioctl_remove_bufs,
797 
798 	.vidioc_enum_input		= vivid_enum_input,
799 	.vidioc_g_input			= vivid_g_input,
800 	.vidioc_s_input			= vivid_s_input,
801 	.vidioc_s_audio			= vidioc_s_audio,
802 	.vidioc_g_audio			= vidioc_g_audio,
803 	.vidioc_enumaudio		= vidioc_enumaudio,
804 	.vidioc_s_frequency		= vidioc_s_frequency,
805 	.vidioc_g_frequency		= vidioc_g_frequency,
806 	.vidioc_s_tuner			= vidioc_s_tuner,
807 	.vidioc_g_tuner			= vidioc_g_tuner,
808 	.vidioc_s_modulator		= vidioc_s_modulator,
809 	.vidioc_g_modulator		= vidioc_g_modulator,
810 	.vidioc_s_hw_freq_seek		= vidioc_s_hw_freq_seek,
811 	.vidioc_enum_freq_bands		= vidioc_enum_freq_bands,
812 
813 	.vidioc_enum_output		= vidioc_enum_output,
814 	.vidioc_g_output		= vidioc_g_output,
815 	.vidioc_s_output		= vidioc_s_output,
816 	.vidioc_s_audout		= vidioc_s_audout,
817 	.vidioc_g_audout		= vidioc_g_audout,
818 	.vidioc_enumaudout		= vidioc_enumaudout,
819 
820 	.vidioc_querystd		= vidioc_querystd,
821 	.vidioc_g_std			= vidioc_g_std,
822 	.vidioc_s_std			= vidioc_s_std,
823 	.vidioc_s_dv_timings		= vidioc_s_dv_timings,
824 	.vidioc_g_dv_timings		= vidioc_g_dv_timings,
825 	.vidioc_query_dv_timings	= vidioc_query_dv_timings,
826 	.vidioc_enum_dv_timings		= vidioc_enum_dv_timings,
827 	.vidioc_dv_timings_cap		= vidioc_dv_timings_cap,
828 	.vidioc_g_edid			= vidioc_g_edid,
829 	.vidioc_s_edid			= vidioc_s_edid,
830 
831 	.vidioc_log_status		= vidioc_log_status,
832 	.vidioc_subscribe_event		= vidioc_subscribe_event,
833 	.vidioc_unsubscribe_event	= v4l2_event_unsubscribe,
834 
835 	.vidioc_enum_fmt_meta_cap	= vidioc_enum_fmt_meta_cap,
836 	.vidioc_g_fmt_meta_cap		= vidioc_g_fmt_meta_cap,
837 	.vidioc_s_fmt_meta_cap		= vidioc_g_fmt_meta_cap,
838 	.vidioc_try_fmt_meta_cap	= vidioc_g_fmt_meta_cap,
839 
840 	.vidioc_enum_fmt_meta_out       = vidioc_enum_fmt_meta_out,
841 	.vidioc_g_fmt_meta_out          = vidioc_g_fmt_meta_out,
842 	.vidioc_s_fmt_meta_out          = vidioc_g_fmt_meta_out,
843 	.vidioc_try_fmt_meta_out        = vidioc_g_fmt_meta_out,
844 };
845 
846 /* -----------------------------------------------------------------
847 	Initialization and module stuff
848    ------------------------------------------------------------------*/
849 
vivid_dev_release(struct v4l2_device * v4l2_dev)850 static void vivid_dev_release(struct v4l2_device *v4l2_dev)
851 {
852 	struct vivid_dev *dev = container_of(v4l2_dev, struct vivid_dev, v4l2_dev);
853 
854 	cancel_work_sync(&dev->update_hdmi_ctrl_work);
855 	vivid_free_controls(dev);
856 	v4l2_device_unregister(&dev->v4l2_dev);
857 #ifdef CONFIG_MEDIA_CONTROLLER
858 	media_device_cleanup(&dev->mdev);
859 #endif
860 	vfree(dev->scaled_line);
861 	vfree(dev->blended_line);
862 	vfree(dev->edid);
863 	tpg_free(&dev->tpg);
864 	kfree(dev->query_dv_timings_qmenu);
865 	kfree(dev->query_dv_timings_qmenu_strings);
866 	kfree(dev);
867 }
868 
869 #ifdef CONFIG_MEDIA_CONTROLLER
vivid_req_validate(struct media_request * req)870 static int vivid_req_validate(struct media_request *req)
871 {
872 	struct vivid_dev *dev = container_of(req->mdev, struct vivid_dev, mdev);
873 
874 	if (dev->req_validate_error) {
875 		dev->req_validate_error = false;
876 		return -EINVAL;
877 	}
878 	return vb2_request_validate(req);
879 }
880 
881 static const struct media_device_ops vivid_media_ops = {
882 	.req_validate = vivid_req_validate,
883 	.req_queue = vb2_request_queue,
884 };
885 #endif
886 
vivid_create_queue(struct vivid_dev * dev,struct vb2_queue * q,u32 buf_type,unsigned int min_reqbufs_allocation,const struct vb2_ops * ops)887 static int vivid_create_queue(struct vivid_dev *dev,
888 			      struct vb2_queue *q,
889 			      u32 buf_type,
890 			      unsigned int min_reqbufs_allocation,
891 			      const struct vb2_ops *ops)
892 {
893 	if (buf_type == V4L2_BUF_TYPE_VIDEO_CAPTURE && dev->multiplanar)
894 		buf_type = V4L2_BUF_TYPE_VIDEO_CAPTURE_MPLANE;
895 	else if (buf_type == V4L2_BUF_TYPE_VIDEO_OUTPUT && dev->multiplanar)
896 		buf_type = V4L2_BUF_TYPE_VIDEO_OUTPUT_MPLANE;
897 	else if (buf_type == V4L2_BUF_TYPE_VBI_CAPTURE && !dev->has_raw_vbi_cap)
898 		buf_type = V4L2_BUF_TYPE_SLICED_VBI_CAPTURE;
899 	else if (buf_type == V4L2_BUF_TYPE_VBI_OUTPUT && !dev->has_raw_vbi_out)
900 		buf_type = V4L2_BUF_TYPE_SLICED_VBI_OUTPUT;
901 
902 	q->type = buf_type;
903 	q->io_modes = VB2_MMAP | VB2_DMABUF;
904 	q->io_modes |= V4L2_TYPE_IS_OUTPUT(buf_type) ?  VB2_WRITE : VB2_READ;
905 
906 	/*
907 	 * The maximum number of buffers is 32768 if PAGE_SHIFT == 12,
908 	 * see also MAX_BUFFER_INDEX in videobuf2-core.c. It will be less if
909 	 * PAGE_SHIFT > 12, but then max_num_buffers will be clamped by
910 	 * videobuf2-core.c to MAX_BUFFER_INDEX.
911 	 */
912 	if (buf_type == V4L2_BUF_TYPE_VIDEO_CAPTURE)
913 		q->max_num_buffers = MAX_VID_CAP_BUFFERS;
914 	if (buf_type == V4L2_BUF_TYPE_SDR_CAPTURE)
915 		q->max_num_buffers = 1024;
916 	if (buf_type == V4L2_BUF_TYPE_VBI_CAPTURE)
917 		q->max_num_buffers = 32768;
918 
919 	if (allocators[dev->inst] != 1)
920 		q->io_modes |= VB2_USERPTR;
921 	q->drv_priv = dev;
922 	q->buf_struct_size = sizeof(struct vivid_buffer);
923 	q->ops = ops;
924 	q->mem_ops = allocators[dev->inst] == 1 ? &vb2_dma_contig_memops :
925 						  &vb2_vmalloc_memops;
926 	q->timestamp_flags = V4L2_BUF_FLAG_TIMESTAMP_MONOTONIC;
927 	q->min_reqbufs_allocation = min_reqbufs_allocation;
928 	q->lock = &dev->mutex;
929 	q->dev = dev->v4l2_dev.dev;
930 	q->supports_requests = supports_requests[dev->inst];
931 	q->requires_requests = supports_requests[dev->inst] >= 2;
932 	q->allow_cache_hints = (cache_hints[dev->inst] == 1);
933 
934 	return vb2_queue_init(q);
935 }
936 
vivid_detect_feature_set(struct vivid_dev * dev,int inst,unsigned node_type,bool * has_tuner,bool * has_modulator,int * ccs_cap,int * ccs_out,unsigned in_type_counter[4],unsigned out_type_counter[4])937 static int vivid_detect_feature_set(struct vivid_dev *dev, int inst,
938 				    unsigned node_type,
939 				    bool *has_tuner,
940 				    bool *has_modulator,
941 				    int *ccs_cap,
942 				    int *ccs_out,
943 				    unsigned in_type_counter[4],
944 				    unsigned out_type_counter[4])
945 {
946 	int i;
947 
948 	/* do we use single- or multi-planar? */
949 	dev->multiplanar = multiplanar[inst] > 1;
950 	v4l2_info(&dev->v4l2_dev, "using %splanar format API\n",
951 			dev->multiplanar ? "multi" : "single ");
952 
953 	/* how many inputs do we have and of what type? */
954 	dev->num_inputs = num_inputs[inst];
955 	if (node_type & 0x20007) {
956 		if (dev->num_inputs < 1)
957 			dev->num_inputs = 1;
958 	} else {
959 		dev->num_inputs = 0;
960 	}
961 	if (dev->num_inputs >= MAX_INPUTS)
962 		dev->num_inputs = MAX_INPUTS;
963 	for (i = 0; i < dev->num_inputs; i++) {
964 		dev->input_type[i] = (input_types[inst] >> (i * 2)) & 0x3;
965 		dev->input_name_counter[i] = in_type_counter[dev->input_type[i]]++;
966 	}
967 	dev->has_audio_inputs = in_type_counter[TV] && in_type_counter[SVID];
968 	if (in_type_counter[HDMI] == 16) {
969 		/* The CEC physical address only allows for max 15 inputs */
970 		in_type_counter[HDMI]--;
971 		dev->num_inputs--;
972 	}
973 	dev->num_hdmi_inputs = in_type_counter[HDMI];
974 	dev->num_svid_inputs = in_type_counter[SVID];
975 
976 	/* how many outputs do we have and of what type? */
977 	dev->num_outputs = num_outputs[inst];
978 	if (node_type & 0x40300) {
979 		if (dev->num_outputs < 1)
980 			dev->num_outputs = 1;
981 	} else {
982 		dev->num_outputs = 0;
983 	}
984 	if (dev->num_outputs >= MAX_OUTPUTS)
985 		dev->num_outputs = MAX_OUTPUTS;
986 	for (i = 0; i < dev->num_outputs; i++) {
987 		dev->output_type[i] = ((output_types[inst] >> i) & 1) ? HDMI : SVID;
988 		dev->output_name_counter[i] = out_type_counter[dev->output_type[i]]++;
989 	}
990 	dev->has_audio_outputs = out_type_counter[SVID];
991 	if (out_type_counter[HDMI] == 16) {
992 		/*
993 		 * The CEC physical address only allows for max 15 inputs,
994 		 * so outputs are also limited to 15 to allow for easy
995 		 * CEC output to input mapping.
996 		 */
997 		out_type_counter[HDMI]--;
998 		dev->num_outputs--;
999 	}
1000 	dev->num_hdmi_outputs = out_type_counter[HDMI];
1001 
1002 	/* do we create a video capture device? */
1003 	dev->has_vid_cap = node_type & 0x0001;
1004 
1005 	/* do we create a vbi capture device? */
1006 	if (in_type_counter[TV] || in_type_counter[SVID]) {
1007 		dev->has_raw_vbi_cap = node_type & 0x0004;
1008 		dev->has_sliced_vbi_cap = node_type & 0x0008;
1009 		dev->has_vbi_cap = dev->has_raw_vbi_cap | dev->has_sliced_vbi_cap;
1010 	}
1011 
1012 	/* do we create a meta capture device */
1013 	dev->has_meta_cap = node_type & 0x20000;
1014 
1015 	/* sanity checks */
1016 	if ((in_type_counter[WEBCAM] || in_type_counter[HDMI]) &&
1017 	    !dev->has_vid_cap && !dev->has_meta_cap) {
1018 		v4l2_warn(&dev->v4l2_dev,
1019 			  "Webcam or HDMI input without video or metadata nodes\n");
1020 		return -EINVAL;
1021 	}
1022 	if ((in_type_counter[TV] || in_type_counter[SVID]) &&
1023 	    !dev->has_vid_cap && !dev->has_vbi_cap && !dev->has_meta_cap) {
1024 		v4l2_warn(&dev->v4l2_dev,
1025 			  "TV or S-Video input without video, VBI or metadata nodes\n");
1026 		return -EINVAL;
1027 	}
1028 
1029 	/* do we create a video output device? */
1030 	dev->has_vid_out = node_type & 0x0100;
1031 
1032 	/* do we create a vbi output device? */
1033 	if (out_type_counter[SVID]) {
1034 		dev->has_raw_vbi_out = node_type & 0x0400;
1035 		dev->has_sliced_vbi_out = node_type & 0x0800;
1036 		dev->has_vbi_out = dev->has_raw_vbi_out | dev->has_sliced_vbi_out;
1037 	}
1038 
1039 	/* do we create a metadata output device */
1040 	dev->has_meta_out = node_type & 0x40000;
1041 
1042 	/* sanity checks */
1043 	if (out_type_counter[SVID] &&
1044 	    !dev->has_vid_out && !dev->has_vbi_out && !dev->has_meta_out) {
1045 		v4l2_warn(&dev->v4l2_dev,
1046 			  "S-Video output without video, VBI or metadata nodes\n");
1047 		return -EINVAL;
1048 	}
1049 	if (out_type_counter[HDMI] && !dev->has_vid_out && !dev->has_meta_out) {
1050 		v4l2_warn(&dev->v4l2_dev,
1051 			  "HDMI output without video or metadata nodes\n");
1052 		return -EINVAL;
1053 	}
1054 
1055 	/* do we create a radio receiver device? */
1056 	dev->has_radio_rx = node_type & 0x0010;
1057 
1058 	/* do we create a radio transmitter device? */
1059 	dev->has_radio_tx = node_type & 0x1000;
1060 
1061 	/* do we create a software defined radio capture device? */
1062 	dev->has_sdr_cap = node_type & 0x0020;
1063 
1064 	/* do we have a TV tuner? */
1065 	dev->has_tv_tuner = in_type_counter[TV];
1066 
1067 	/* do we have a tuner? */
1068 	*has_tuner = ((dev->has_vid_cap || dev->has_vbi_cap) && in_type_counter[TV]) ||
1069 		      dev->has_radio_rx || dev->has_sdr_cap;
1070 
1071 	/* do we have a modulator? */
1072 	*has_modulator = dev->has_radio_tx;
1073 
1074 	if (dev->has_vid_cap)
1075 		/* do we have a framebuffer for overlay testing? */
1076 		dev->has_fb = node_type & 0x10000;
1077 
1078 	/* can we do crop/compose/scaling while capturing? */
1079 	if (no_error_inj && *ccs_cap == -1)
1080 		*ccs_cap = 7;
1081 
1082 	/* if ccs_cap == -1, then the user can select it using controls */
1083 	if (*ccs_cap != -1) {
1084 		dev->has_crop_cap = *ccs_cap & 1;
1085 		dev->has_compose_cap = *ccs_cap & 2;
1086 		dev->has_scaler_cap = *ccs_cap & 4;
1087 		v4l2_info(&dev->v4l2_dev, "Capture Crop: %c Compose: %c Scaler: %c\n",
1088 			dev->has_crop_cap ? 'Y' : 'N',
1089 			dev->has_compose_cap ? 'Y' : 'N',
1090 			dev->has_scaler_cap ? 'Y' : 'N');
1091 	}
1092 
1093 	/* can we do crop/compose/scaling with video output? */
1094 	if (no_error_inj && *ccs_out == -1)
1095 		*ccs_out = 7;
1096 
1097 	/* if ccs_out == -1, then the user can select it using controls */
1098 	if (*ccs_out != -1) {
1099 		dev->has_crop_out = *ccs_out & 1;
1100 		dev->has_compose_out = *ccs_out & 2;
1101 		dev->has_scaler_out = *ccs_out & 4;
1102 		v4l2_info(&dev->v4l2_dev, "Output Crop: %c Compose: %c Scaler: %c\n",
1103 			dev->has_crop_out ? 'Y' : 'N',
1104 			dev->has_compose_out ? 'Y' : 'N',
1105 			dev->has_scaler_out ? 'Y' : 'N');
1106 	}
1107 
1108 	/* do we create a touch capture device */
1109 	dev->has_touch_cap = node_type & 0x80000;
1110 
1111 	return 0;
1112 }
1113 
vivid_set_capabilities(struct vivid_dev * dev)1114 static void vivid_set_capabilities(struct vivid_dev *dev)
1115 {
1116 	if (dev->has_vid_cap) {
1117 		/* set up the capabilities of the video capture device */
1118 		dev->vid_cap_caps = dev->multiplanar ?
1119 			V4L2_CAP_VIDEO_CAPTURE_MPLANE :
1120 			V4L2_CAP_VIDEO_CAPTURE;
1121 		dev->vid_cap_caps |= V4L2_CAP_STREAMING | V4L2_CAP_READWRITE;
1122 		if (dev->has_audio_inputs)
1123 			dev->vid_cap_caps |= V4L2_CAP_AUDIO;
1124 		if (dev->has_tv_tuner)
1125 			dev->vid_cap_caps |= V4L2_CAP_TUNER;
1126 	}
1127 	if (dev->has_vid_out) {
1128 		/* set up the capabilities of the video output device */
1129 		dev->vid_out_caps = dev->multiplanar ?
1130 			V4L2_CAP_VIDEO_OUTPUT_MPLANE :
1131 			V4L2_CAP_VIDEO_OUTPUT;
1132 		if (dev->has_fb)
1133 			dev->vid_out_caps |= V4L2_CAP_VIDEO_OUTPUT_OVERLAY;
1134 		dev->vid_out_caps |= V4L2_CAP_STREAMING | V4L2_CAP_READWRITE;
1135 		if (dev->has_audio_outputs)
1136 			dev->vid_out_caps |= V4L2_CAP_AUDIO;
1137 	}
1138 	if (dev->has_vbi_cap) {
1139 		/* set up the capabilities of the vbi capture device */
1140 		dev->vbi_cap_caps = (dev->has_raw_vbi_cap ? V4L2_CAP_VBI_CAPTURE : 0) |
1141 				    (dev->has_sliced_vbi_cap ? V4L2_CAP_SLICED_VBI_CAPTURE : 0);
1142 		dev->vbi_cap_caps |= V4L2_CAP_STREAMING | V4L2_CAP_READWRITE;
1143 		if (dev->has_audio_inputs)
1144 			dev->vbi_cap_caps |= V4L2_CAP_AUDIO;
1145 		if (dev->has_tv_tuner)
1146 			dev->vbi_cap_caps |= V4L2_CAP_TUNER;
1147 	}
1148 	if (dev->has_vbi_out) {
1149 		/* set up the capabilities of the vbi output device */
1150 		dev->vbi_out_caps = (dev->has_raw_vbi_out ? V4L2_CAP_VBI_OUTPUT : 0) |
1151 				    (dev->has_sliced_vbi_out ? V4L2_CAP_SLICED_VBI_OUTPUT : 0);
1152 		dev->vbi_out_caps |= V4L2_CAP_STREAMING | V4L2_CAP_READWRITE;
1153 		if (dev->has_audio_outputs)
1154 			dev->vbi_out_caps |= V4L2_CAP_AUDIO;
1155 	}
1156 	if (dev->has_sdr_cap) {
1157 		/* set up the capabilities of the sdr capture device */
1158 		dev->sdr_cap_caps = V4L2_CAP_SDR_CAPTURE | V4L2_CAP_TUNER;
1159 		dev->sdr_cap_caps |= V4L2_CAP_STREAMING | V4L2_CAP_READWRITE;
1160 	}
1161 	/* set up the capabilities of the radio receiver device */
1162 	if (dev->has_radio_rx)
1163 		dev->radio_rx_caps = V4L2_CAP_RADIO | V4L2_CAP_RDS_CAPTURE |
1164 				     V4L2_CAP_HW_FREQ_SEEK | V4L2_CAP_TUNER |
1165 				     V4L2_CAP_READWRITE;
1166 	/* set up the capabilities of the radio transmitter device */
1167 	if (dev->has_radio_tx)
1168 		dev->radio_tx_caps = V4L2_CAP_RDS_OUTPUT | V4L2_CAP_MODULATOR |
1169 				     V4L2_CAP_READWRITE;
1170 
1171 	/* set up the capabilities of meta capture device */
1172 	if (dev->has_meta_cap) {
1173 		dev->meta_cap_caps = V4L2_CAP_META_CAPTURE |
1174 				     V4L2_CAP_STREAMING | V4L2_CAP_READWRITE;
1175 		if (dev->has_audio_inputs)
1176 			dev->meta_cap_caps |= V4L2_CAP_AUDIO;
1177 		if (dev->has_tv_tuner)
1178 			dev->meta_cap_caps |= V4L2_CAP_TUNER;
1179 	}
1180 	/* set up the capabilities of meta output device */
1181 	if (dev->has_meta_out) {
1182 		dev->meta_out_caps = V4L2_CAP_META_OUTPUT |
1183 				     V4L2_CAP_STREAMING | V4L2_CAP_READWRITE;
1184 		if (dev->has_audio_outputs)
1185 			dev->meta_out_caps |= V4L2_CAP_AUDIO;
1186 	}
1187 	/* set up the capabilities of the touch capture device */
1188 	if (dev->has_touch_cap) {
1189 		dev->touch_cap_caps = V4L2_CAP_TOUCH | V4L2_CAP_STREAMING |
1190 				      V4L2_CAP_READWRITE;
1191 		dev->touch_cap_caps |= dev->multiplanar ?
1192 			V4L2_CAP_VIDEO_CAPTURE_MPLANE : V4L2_CAP_VIDEO_CAPTURE;
1193 	}
1194 }
1195 
vivid_disable_unused_ioctls(struct vivid_dev * dev,bool has_tuner,bool has_modulator,unsigned in_type_counter[4],unsigned out_type_counter[4])1196 static void vivid_disable_unused_ioctls(struct vivid_dev *dev,
1197 					bool has_tuner,
1198 					bool has_modulator,
1199 					unsigned in_type_counter[4],
1200 					unsigned out_type_counter[4])
1201 {
1202 	/* disable invalid ioctls based on the feature set */
1203 	if (!dev->has_audio_inputs) {
1204 		v4l2_disable_ioctl(&dev->vid_cap_dev, VIDIOC_S_AUDIO);
1205 		v4l2_disable_ioctl(&dev->vid_cap_dev, VIDIOC_G_AUDIO);
1206 		v4l2_disable_ioctl(&dev->vid_cap_dev, VIDIOC_ENUMAUDIO);
1207 		v4l2_disable_ioctl(&dev->vbi_cap_dev, VIDIOC_S_AUDIO);
1208 		v4l2_disable_ioctl(&dev->vbi_cap_dev, VIDIOC_G_AUDIO);
1209 		v4l2_disable_ioctl(&dev->vbi_cap_dev, VIDIOC_ENUMAUDIO);
1210 		v4l2_disable_ioctl(&dev->meta_cap_dev, VIDIOC_S_AUDIO);
1211 		v4l2_disable_ioctl(&dev->meta_cap_dev, VIDIOC_G_AUDIO);
1212 		v4l2_disable_ioctl(&dev->meta_cap_dev, VIDIOC_ENUMAUDIO);
1213 	}
1214 	if (!dev->has_audio_outputs) {
1215 		v4l2_disable_ioctl(&dev->vid_out_dev, VIDIOC_S_AUDOUT);
1216 		v4l2_disable_ioctl(&dev->vid_out_dev, VIDIOC_G_AUDOUT);
1217 		v4l2_disable_ioctl(&dev->vid_out_dev, VIDIOC_ENUMAUDOUT);
1218 		v4l2_disable_ioctl(&dev->vbi_out_dev, VIDIOC_S_AUDOUT);
1219 		v4l2_disable_ioctl(&dev->vbi_out_dev, VIDIOC_G_AUDOUT);
1220 		v4l2_disable_ioctl(&dev->vbi_out_dev, VIDIOC_ENUMAUDOUT);
1221 		v4l2_disable_ioctl(&dev->meta_out_dev, VIDIOC_S_AUDOUT);
1222 		v4l2_disable_ioctl(&dev->meta_out_dev, VIDIOC_G_AUDOUT);
1223 		v4l2_disable_ioctl(&dev->meta_out_dev, VIDIOC_ENUMAUDOUT);
1224 	}
1225 	if (!in_type_counter[TV] && !in_type_counter[SVID]) {
1226 		v4l2_disable_ioctl(&dev->vid_cap_dev, VIDIOC_S_STD);
1227 		v4l2_disable_ioctl(&dev->vid_cap_dev, VIDIOC_G_STD);
1228 		v4l2_disable_ioctl(&dev->vid_cap_dev, VIDIOC_ENUMSTD);
1229 		v4l2_disable_ioctl(&dev->vid_cap_dev, VIDIOC_QUERYSTD);
1230 	}
1231 	if (!out_type_counter[SVID]) {
1232 		v4l2_disable_ioctl(&dev->vid_out_dev, VIDIOC_S_STD);
1233 		v4l2_disable_ioctl(&dev->vid_out_dev, VIDIOC_G_STD);
1234 		v4l2_disable_ioctl(&dev->vid_out_dev, VIDIOC_ENUMSTD);
1235 	}
1236 	if (!has_tuner && !has_modulator) {
1237 		v4l2_disable_ioctl(&dev->vid_cap_dev, VIDIOC_S_FREQUENCY);
1238 		v4l2_disable_ioctl(&dev->vid_cap_dev, VIDIOC_G_FREQUENCY);
1239 		v4l2_disable_ioctl(&dev->vbi_cap_dev, VIDIOC_S_FREQUENCY);
1240 		v4l2_disable_ioctl(&dev->vbi_cap_dev, VIDIOC_G_FREQUENCY);
1241 		v4l2_disable_ioctl(&dev->meta_cap_dev, VIDIOC_S_FREQUENCY);
1242 		v4l2_disable_ioctl(&dev->meta_cap_dev, VIDIOC_G_FREQUENCY);
1243 	}
1244 	if (!has_tuner) {
1245 		v4l2_disable_ioctl(&dev->vid_cap_dev, VIDIOC_S_TUNER);
1246 		v4l2_disable_ioctl(&dev->vid_cap_dev, VIDIOC_G_TUNER);
1247 		v4l2_disable_ioctl(&dev->vbi_cap_dev, VIDIOC_S_TUNER);
1248 		v4l2_disable_ioctl(&dev->vbi_cap_dev, VIDIOC_G_TUNER);
1249 		v4l2_disable_ioctl(&dev->meta_cap_dev, VIDIOC_S_TUNER);
1250 		v4l2_disable_ioctl(&dev->meta_cap_dev, VIDIOC_G_TUNER);
1251 	}
1252 	if (in_type_counter[HDMI] == 0) {
1253 		v4l2_disable_ioctl(&dev->vid_cap_dev, VIDIOC_S_EDID);
1254 		v4l2_disable_ioctl(&dev->vid_cap_dev, VIDIOC_G_EDID);
1255 		v4l2_disable_ioctl(&dev->vid_cap_dev, VIDIOC_DV_TIMINGS_CAP);
1256 		v4l2_disable_ioctl(&dev->vid_cap_dev, VIDIOC_G_DV_TIMINGS);
1257 		v4l2_disable_ioctl(&dev->vid_cap_dev, VIDIOC_S_DV_TIMINGS);
1258 		v4l2_disable_ioctl(&dev->vid_cap_dev, VIDIOC_ENUM_DV_TIMINGS);
1259 		v4l2_disable_ioctl(&dev->vid_cap_dev, VIDIOC_QUERY_DV_TIMINGS);
1260 	}
1261 	if (out_type_counter[HDMI] == 0) {
1262 		v4l2_disable_ioctl(&dev->vid_out_dev, VIDIOC_G_EDID);
1263 		v4l2_disable_ioctl(&dev->vid_out_dev, VIDIOC_DV_TIMINGS_CAP);
1264 		v4l2_disable_ioctl(&dev->vid_out_dev, VIDIOC_G_DV_TIMINGS);
1265 		v4l2_disable_ioctl(&dev->vid_out_dev, VIDIOC_S_DV_TIMINGS);
1266 		v4l2_disable_ioctl(&dev->vid_out_dev, VIDIOC_ENUM_DV_TIMINGS);
1267 	}
1268 	if (!dev->has_fb) {
1269 		v4l2_disable_ioctl(&dev->vid_out_dev, VIDIOC_G_FBUF);
1270 		v4l2_disable_ioctl(&dev->vid_out_dev, VIDIOC_S_FBUF);
1271 		v4l2_disable_ioctl(&dev->vid_out_dev, VIDIOC_OVERLAY);
1272 	}
1273 	v4l2_disable_ioctl(&dev->vid_cap_dev, VIDIOC_S_HW_FREQ_SEEK);
1274 	v4l2_disable_ioctl(&dev->vbi_cap_dev, VIDIOC_S_HW_FREQ_SEEK);
1275 	v4l2_disable_ioctl(&dev->sdr_cap_dev, VIDIOC_S_HW_FREQ_SEEK);
1276 	v4l2_disable_ioctl(&dev->meta_cap_dev, VIDIOC_S_HW_FREQ_SEEK);
1277 	v4l2_disable_ioctl(&dev->vid_out_dev, VIDIOC_S_FREQUENCY);
1278 	v4l2_disable_ioctl(&dev->vid_out_dev, VIDIOC_G_FREQUENCY);
1279 	v4l2_disable_ioctl(&dev->vid_out_dev, VIDIOC_ENUM_FRAMESIZES);
1280 	v4l2_disable_ioctl(&dev->vid_out_dev, VIDIOC_ENUM_FRAMEINTERVALS);
1281 	v4l2_disable_ioctl(&dev->vbi_out_dev, VIDIOC_S_FREQUENCY);
1282 	v4l2_disable_ioctl(&dev->vbi_out_dev, VIDIOC_G_FREQUENCY);
1283 	v4l2_disable_ioctl(&dev->meta_out_dev, VIDIOC_S_FREQUENCY);
1284 	v4l2_disable_ioctl(&dev->meta_out_dev, VIDIOC_G_FREQUENCY);
1285 	v4l2_disable_ioctl(&dev->touch_cap_dev, VIDIOC_S_PARM);
1286 	v4l2_disable_ioctl(&dev->touch_cap_dev, VIDIOC_ENUM_FRAMESIZES);
1287 	v4l2_disable_ioctl(&dev->touch_cap_dev, VIDIOC_ENUM_FRAMEINTERVALS);
1288 }
1289 
vivid_init_dv_timings(struct vivid_dev * dev)1290 static int vivid_init_dv_timings(struct vivid_dev *dev)
1291 {
1292 	int i;
1293 
1294 	while (v4l2_dv_timings_presets[dev->query_dv_timings_size].bt.width)
1295 		dev->query_dv_timings_size++;
1296 
1297 	/*
1298 	 * Create a char pointer array that points to the names of all the
1299 	 * preset timings
1300 	 */
1301 	dev->query_dv_timings_qmenu = kmalloc_array(dev->query_dv_timings_size,
1302 						    sizeof(char *), GFP_KERNEL);
1303 	/*
1304 	 * Create a string array containing the names of all the preset
1305 	 * timings. Each name is max 31 chars long (+ terminating 0).
1306 	 */
1307 	dev->query_dv_timings_qmenu_strings =
1308 		kmalloc_array(dev->query_dv_timings_size, 32, GFP_KERNEL);
1309 
1310 	if (!dev->query_dv_timings_qmenu ||
1311 	    !dev->query_dv_timings_qmenu_strings)
1312 		return -ENOMEM;
1313 
1314 	for (i = 0; i < dev->query_dv_timings_size; i++) {
1315 		const struct v4l2_bt_timings *bt = &v4l2_dv_timings_presets[i].bt;
1316 		char *p = dev->query_dv_timings_qmenu_strings + i * 32;
1317 		u32 htot, vtot;
1318 
1319 		dev->query_dv_timings_qmenu[i] = p;
1320 
1321 		htot = V4L2_DV_BT_FRAME_WIDTH(bt);
1322 		vtot = V4L2_DV_BT_FRAME_HEIGHT(bt);
1323 		snprintf(p, 32, "%ux%u%s%u",
1324 			bt->width, bt->height, bt->interlaced ? "i" : "p",
1325 			(u32)bt->pixelclock / (htot * vtot));
1326 	}
1327 
1328 	return 0;
1329 }
1330 
vivid_create_queues(struct vivid_dev * dev)1331 static int vivid_create_queues(struct vivid_dev *dev)
1332 {
1333 	int ret;
1334 
1335 	/* start creating the vb2 queues */
1336 	if (dev->has_vid_cap) {
1337 		/* initialize vid_cap queue */
1338 		ret = vivid_create_queue(dev, &dev->vb_vid_cap_q,
1339 					 V4L2_BUF_TYPE_VIDEO_CAPTURE, 2,
1340 					 &vivid_vid_cap_qops);
1341 		if (ret)
1342 			return ret;
1343 	}
1344 
1345 	if (dev->has_vid_out) {
1346 		/* initialize vid_out queue */
1347 		ret = vivid_create_queue(dev, &dev->vb_vid_out_q,
1348 					 V4L2_BUF_TYPE_VIDEO_OUTPUT, 2,
1349 					 &vivid_vid_out_qops);
1350 		if (ret)
1351 			return ret;
1352 	}
1353 
1354 	if (dev->has_vbi_cap) {
1355 		/* initialize vbi_cap queue */
1356 		ret = vivid_create_queue(dev, &dev->vb_vbi_cap_q,
1357 					 V4L2_BUF_TYPE_VBI_CAPTURE, 2,
1358 					 &vivid_vbi_cap_qops);
1359 		if (ret)
1360 			return ret;
1361 	}
1362 
1363 	if (dev->has_vbi_out) {
1364 		/* initialize vbi_out queue */
1365 		ret = vivid_create_queue(dev, &dev->vb_vbi_out_q,
1366 					 V4L2_BUF_TYPE_VBI_OUTPUT, 2,
1367 					 &vivid_vbi_out_qops);
1368 		if (ret)
1369 			return ret;
1370 	}
1371 
1372 	if (dev->has_sdr_cap) {
1373 		/* initialize sdr_cap queue */
1374 		ret = vivid_create_queue(dev, &dev->vb_sdr_cap_q,
1375 					 V4L2_BUF_TYPE_SDR_CAPTURE, 8,
1376 					 &vivid_sdr_cap_qops);
1377 		if (ret)
1378 			return ret;
1379 	}
1380 
1381 	if (dev->has_meta_cap) {
1382 		/* initialize meta_cap queue */
1383 		ret = vivid_create_queue(dev, &dev->vb_meta_cap_q,
1384 					 V4L2_BUF_TYPE_META_CAPTURE, 2,
1385 					 &vivid_meta_cap_qops);
1386 		if (ret)
1387 			return ret;
1388 	}
1389 
1390 	if (dev->has_meta_out) {
1391 		/* initialize meta_out queue */
1392 		ret = vivid_create_queue(dev, &dev->vb_meta_out_q,
1393 					 V4L2_BUF_TYPE_META_OUTPUT, 2,
1394 					 &vivid_meta_out_qops);
1395 		if (ret)
1396 			return ret;
1397 	}
1398 
1399 	if (dev->has_touch_cap) {
1400 		/* initialize touch_cap queue */
1401 		ret = vivid_create_queue(dev, &dev->vb_touch_cap_q,
1402 					 V4L2_BUF_TYPE_VIDEO_CAPTURE, 2,
1403 					 &vivid_touch_cap_qops);
1404 		if (ret)
1405 			return ret;
1406 	}
1407 
1408 	if (dev->has_fb) {
1409 		/* Create framebuffer for testing output overlay */
1410 		ret = vivid_fb_init(dev);
1411 		if (ret)
1412 			return ret;
1413 		v4l2_info(&dev->v4l2_dev, "Framebuffer device registered as fb%d\n",
1414 			  dev->fb_info.node);
1415 	}
1416 	return 0;
1417 }
1418 
vivid_create_devnodes(struct platform_device * pdev,struct vivid_dev * dev,int inst,v4l2_std_id tvnorms_cap,v4l2_std_id tvnorms_out,unsigned in_type_counter[4],unsigned out_type_counter[4])1419 static int vivid_create_devnodes(struct platform_device *pdev,
1420 				 struct vivid_dev *dev, int inst,
1421 				 v4l2_std_id tvnorms_cap,
1422 				 v4l2_std_id tvnorms_out,
1423 				 unsigned in_type_counter[4],
1424 				 unsigned out_type_counter[4])
1425 {
1426 	struct video_device *vfd;
1427 	int ret;
1428 
1429 	if (dev->has_vid_cap) {
1430 		vfd = &dev->vid_cap_dev;
1431 		snprintf(vfd->name, sizeof(vfd->name),
1432 			 "vivid-%03d-vid-cap", inst);
1433 		vfd->fops = &vivid_fops;
1434 		vfd->ioctl_ops = &vivid_ioctl_ops;
1435 		vfd->device_caps = dev->vid_cap_caps;
1436 		vfd->release = video_device_release_empty;
1437 		vfd->v4l2_dev = &dev->v4l2_dev;
1438 		vfd->queue = &dev->vb_vid_cap_q;
1439 		vfd->tvnorms = tvnorms_cap;
1440 
1441 		/*
1442 		 * Provide a mutex to v4l2 core. It will be used to protect
1443 		 * all fops and v4l2 ioctls.
1444 		 */
1445 		vfd->lock = &dev->mutex;
1446 		video_set_drvdata(vfd, dev);
1447 
1448 #ifdef CONFIG_MEDIA_CONTROLLER
1449 		dev->vid_cap_pad.flags = MEDIA_PAD_FL_SINK;
1450 		ret = media_entity_pads_init(&vfd->entity, 1, &dev->vid_cap_pad);
1451 		if (ret)
1452 			return ret;
1453 #endif
1454 
1455 #ifdef CONFIG_VIDEO_VIVID_CEC
1456 		if (in_type_counter[HDMI]) {
1457 			ret = cec_register_adapter(dev->cec_rx_adap, &pdev->dev);
1458 			if (ret < 0) {
1459 				cec_delete_adapter(dev->cec_rx_adap);
1460 				dev->cec_rx_adap = NULL;
1461 				return ret;
1462 			}
1463 			cec_s_phys_addr(dev->cec_rx_adap, 0, false);
1464 			v4l2_info(&dev->v4l2_dev, "CEC adapter %s registered for HDMI input\n",
1465 				  dev_name(&dev->cec_rx_adap->devnode.dev));
1466 		}
1467 #endif
1468 
1469 		ret = video_register_device(vfd, VFL_TYPE_VIDEO, vid_cap_nr[inst]);
1470 		if (ret < 0)
1471 			return ret;
1472 		v4l2_info(&dev->v4l2_dev, "V4L2 capture device registered as %s\n",
1473 					  video_device_node_name(vfd));
1474 	}
1475 
1476 	if (dev->has_vid_out) {
1477 #ifdef CONFIG_VIDEO_VIVID_CEC
1478 		int i;
1479 #endif
1480 		vfd = &dev->vid_out_dev;
1481 		snprintf(vfd->name, sizeof(vfd->name),
1482 			 "vivid-%03d-vid-out", inst);
1483 		vfd->vfl_dir = VFL_DIR_TX;
1484 		vfd->fops = &vivid_fops;
1485 		vfd->ioctl_ops = &vivid_ioctl_ops;
1486 		vfd->device_caps = dev->vid_out_caps;
1487 		vfd->release = video_device_release_empty;
1488 		vfd->v4l2_dev = &dev->v4l2_dev;
1489 		vfd->queue = &dev->vb_vid_out_q;
1490 		vfd->tvnorms = tvnorms_out;
1491 
1492 		/*
1493 		 * Provide a mutex to v4l2 core. It will be used to protect
1494 		 * all fops and v4l2 ioctls.
1495 		 */
1496 		vfd->lock = &dev->mutex;
1497 		video_set_drvdata(vfd, dev);
1498 
1499 #ifdef CONFIG_MEDIA_CONTROLLER
1500 		dev->vid_out_pad.flags = MEDIA_PAD_FL_SOURCE;
1501 		ret = media_entity_pads_init(&vfd->entity, 1, &dev->vid_out_pad);
1502 		if (ret)
1503 			return ret;
1504 #endif
1505 
1506 #ifdef CONFIG_VIDEO_VIVID_CEC
1507 		for (i = 0; i < dev->num_hdmi_outputs; i++) {
1508 			ret = cec_register_adapter(dev->cec_tx_adap[i], &pdev->dev);
1509 			if (ret < 0) {
1510 				for (; i >= 0; i--) {
1511 					cec_delete_adapter(dev->cec_tx_adap[i]);
1512 					dev->cec_tx_adap[i] = NULL;
1513 				}
1514 				return ret;
1515 			}
1516 			v4l2_info(&dev->v4l2_dev, "CEC adapter %s registered for HDMI output %d\n",
1517 				  dev_name(&dev->cec_tx_adap[i]->devnode.dev), i);
1518 		}
1519 #endif
1520 
1521 		ret = video_register_device(vfd, VFL_TYPE_VIDEO, vid_out_nr[inst]);
1522 		if (ret < 0)
1523 			return ret;
1524 		v4l2_info(&dev->v4l2_dev, "V4L2 output device registered as %s\n",
1525 					  video_device_node_name(vfd));
1526 	}
1527 
1528 	if (dev->has_vbi_cap) {
1529 		vfd = &dev->vbi_cap_dev;
1530 		snprintf(vfd->name, sizeof(vfd->name),
1531 			 "vivid-%03d-vbi-cap", inst);
1532 		vfd->fops = &vivid_fops;
1533 		vfd->ioctl_ops = &vivid_ioctl_ops;
1534 		vfd->device_caps = dev->vbi_cap_caps;
1535 		vfd->release = video_device_release_empty;
1536 		vfd->v4l2_dev = &dev->v4l2_dev;
1537 		vfd->queue = &dev->vb_vbi_cap_q;
1538 		vfd->lock = &dev->mutex;
1539 		vfd->tvnorms = tvnorms_cap;
1540 		video_set_drvdata(vfd, dev);
1541 
1542 #ifdef CONFIG_MEDIA_CONTROLLER
1543 		dev->vbi_cap_pad.flags = MEDIA_PAD_FL_SINK;
1544 		ret = media_entity_pads_init(&vfd->entity, 1, &dev->vbi_cap_pad);
1545 		if (ret)
1546 			return ret;
1547 #endif
1548 
1549 		ret = video_register_device(vfd, VFL_TYPE_VBI, vbi_cap_nr[inst]);
1550 		if (ret < 0)
1551 			return ret;
1552 		v4l2_info(&dev->v4l2_dev, "V4L2 capture device registered as %s, supports %s VBI\n",
1553 					  video_device_node_name(vfd),
1554 					  (dev->has_raw_vbi_cap && dev->has_sliced_vbi_cap) ?
1555 					  "raw and sliced" :
1556 					  (dev->has_raw_vbi_cap ? "raw" : "sliced"));
1557 	}
1558 
1559 	if (dev->has_vbi_out) {
1560 		vfd = &dev->vbi_out_dev;
1561 		snprintf(vfd->name, sizeof(vfd->name),
1562 			 "vivid-%03d-vbi-out", inst);
1563 		vfd->vfl_dir = VFL_DIR_TX;
1564 		vfd->fops = &vivid_fops;
1565 		vfd->ioctl_ops = &vivid_ioctl_ops;
1566 		vfd->device_caps = dev->vbi_out_caps;
1567 		vfd->release = video_device_release_empty;
1568 		vfd->v4l2_dev = &dev->v4l2_dev;
1569 		vfd->queue = &dev->vb_vbi_out_q;
1570 		vfd->lock = &dev->mutex;
1571 		vfd->tvnorms = tvnorms_out;
1572 		video_set_drvdata(vfd, dev);
1573 
1574 #ifdef CONFIG_MEDIA_CONTROLLER
1575 		dev->vbi_out_pad.flags = MEDIA_PAD_FL_SOURCE;
1576 		ret = media_entity_pads_init(&vfd->entity, 1, &dev->vbi_out_pad);
1577 		if (ret)
1578 			return ret;
1579 #endif
1580 
1581 		ret = video_register_device(vfd, VFL_TYPE_VBI, vbi_out_nr[inst]);
1582 		if (ret < 0)
1583 			return ret;
1584 		v4l2_info(&dev->v4l2_dev, "V4L2 output device registered as %s, supports %s VBI\n",
1585 					  video_device_node_name(vfd),
1586 					  (dev->has_raw_vbi_out && dev->has_sliced_vbi_out) ?
1587 					  "raw and sliced" :
1588 					  (dev->has_raw_vbi_out ? "raw" : "sliced"));
1589 	}
1590 
1591 	if (dev->has_sdr_cap) {
1592 		vfd = &dev->sdr_cap_dev;
1593 		snprintf(vfd->name, sizeof(vfd->name),
1594 			 "vivid-%03d-sdr-cap", inst);
1595 		vfd->fops = &vivid_fops;
1596 		vfd->ioctl_ops = &vivid_ioctl_ops;
1597 		vfd->device_caps = dev->sdr_cap_caps;
1598 		vfd->release = video_device_release_empty;
1599 		vfd->v4l2_dev = &dev->v4l2_dev;
1600 		vfd->queue = &dev->vb_sdr_cap_q;
1601 		vfd->lock = &dev->mutex;
1602 		video_set_drvdata(vfd, dev);
1603 
1604 #ifdef CONFIG_MEDIA_CONTROLLER
1605 		dev->sdr_cap_pad.flags = MEDIA_PAD_FL_SINK;
1606 		ret = media_entity_pads_init(&vfd->entity, 1, &dev->sdr_cap_pad);
1607 		if (ret)
1608 			return ret;
1609 #endif
1610 
1611 		ret = video_register_device(vfd, VFL_TYPE_SDR, sdr_cap_nr[inst]);
1612 		if (ret < 0)
1613 			return ret;
1614 		v4l2_info(&dev->v4l2_dev, "V4L2 capture device registered as %s\n",
1615 					  video_device_node_name(vfd));
1616 	}
1617 
1618 	if (dev->has_radio_rx) {
1619 		vfd = &dev->radio_rx_dev;
1620 		snprintf(vfd->name, sizeof(vfd->name),
1621 			 "vivid-%03d-rad-rx", inst);
1622 		vfd->fops = &vivid_radio_fops;
1623 		vfd->ioctl_ops = &vivid_ioctl_ops;
1624 		vfd->device_caps = dev->radio_rx_caps;
1625 		vfd->release = video_device_release_empty;
1626 		vfd->v4l2_dev = &dev->v4l2_dev;
1627 		vfd->lock = &dev->mutex;
1628 		video_set_drvdata(vfd, dev);
1629 
1630 		ret = video_register_device(vfd, VFL_TYPE_RADIO, radio_rx_nr[inst]);
1631 		if (ret < 0)
1632 			return ret;
1633 		v4l2_info(&dev->v4l2_dev, "V4L2 receiver device registered as %s\n",
1634 					  video_device_node_name(vfd));
1635 	}
1636 
1637 	if (dev->has_radio_tx) {
1638 		vfd = &dev->radio_tx_dev;
1639 		snprintf(vfd->name, sizeof(vfd->name),
1640 			 "vivid-%03d-rad-tx", inst);
1641 		vfd->vfl_dir = VFL_DIR_TX;
1642 		vfd->fops = &vivid_radio_fops;
1643 		vfd->ioctl_ops = &vivid_ioctl_ops;
1644 		vfd->device_caps = dev->radio_tx_caps;
1645 		vfd->release = video_device_release_empty;
1646 		vfd->v4l2_dev = &dev->v4l2_dev;
1647 		vfd->lock = &dev->mutex;
1648 		video_set_drvdata(vfd, dev);
1649 
1650 		ret = video_register_device(vfd, VFL_TYPE_RADIO, radio_tx_nr[inst]);
1651 		if (ret < 0)
1652 			return ret;
1653 		v4l2_info(&dev->v4l2_dev, "V4L2 transmitter device registered as %s\n",
1654 					  video_device_node_name(vfd));
1655 	}
1656 
1657 	if (dev->has_meta_cap) {
1658 		vfd = &dev->meta_cap_dev;
1659 		snprintf(vfd->name, sizeof(vfd->name),
1660 			 "vivid-%03d-meta-cap", inst);
1661 		vfd->fops = &vivid_fops;
1662 		vfd->ioctl_ops = &vivid_ioctl_ops;
1663 		vfd->device_caps = dev->meta_cap_caps;
1664 		vfd->release = video_device_release_empty;
1665 		vfd->v4l2_dev = &dev->v4l2_dev;
1666 		vfd->queue = &dev->vb_meta_cap_q;
1667 		vfd->lock = &dev->mutex;
1668 		vfd->tvnorms = tvnorms_cap;
1669 		video_set_drvdata(vfd, dev);
1670 #ifdef CONFIG_MEDIA_CONTROLLER
1671 		dev->meta_cap_pad.flags = MEDIA_PAD_FL_SINK;
1672 		ret = media_entity_pads_init(&vfd->entity, 1,
1673 					     &dev->meta_cap_pad);
1674 		if (ret)
1675 			return ret;
1676 #endif
1677 		ret = video_register_device(vfd, VFL_TYPE_VIDEO,
1678 					    meta_cap_nr[inst]);
1679 		if (ret < 0)
1680 			return ret;
1681 		v4l2_info(&dev->v4l2_dev,
1682 			  "V4L2 metadata capture device registered as %s\n",
1683 			  video_device_node_name(vfd));
1684 	}
1685 
1686 	if (dev->has_meta_out) {
1687 		vfd = &dev->meta_out_dev;
1688 		snprintf(vfd->name, sizeof(vfd->name),
1689 			 "vivid-%03d-meta-out", inst);
1690 		vfd->vfl_dir = VFL_DIR_TX;
1691 		vfd->fops = &vivid_fops;
1692 		vfd->ioctl_ops = &vivid_ioctl_ops;
1693 		vfd->device_caps = dev->meta_out_caps;
1694 		vfd->release = video_device_release_empty;
1695 		vfd->v4l2_dev = &dev->v4l2_dev;
1696 		vfd->queue = &dev->vb_meta_out_q;
1697 		vfd->lock = &dev->mutex;
1698 		vfd->tvnorms = tvnorms_out;
1699 		video_set_drvdata(vfd, dev);
1700 #ifdef CONFIG_MEDIA_CONTROLLER
1701 		dev->meta_out_pad.flags = MEDIA_PAD_FL_SOURCE;
1702 		ret = media_entity_pads_init(&vfd->entity, 1,
1703 					     &dev->meta_out_pad);
1704 		if (ret)
1705 			return ret;
1706 #endif
1707 		ret = video_register_device(vfd, VFL_TYPE_VIDEO,
1708 					    meta_out_nr[inst]);
1709 		if (ret < 0)
1710 			return ret;
1711 		v4l2_info(&dev->v4l2_dev,
1712 			  "V4L2 metadata output device registered as %s\n",
1713 			  video_device_node_name(vfd));
1714 	}
1715 
1716 	if (dev->has_touch_cap) {
1717 		vfd = &dev->touch_cap_dev;
1718 		snprintf(vfd->name, sizeof(vfd->name),
1719 			 "vivid-%03d-touch-cap", inst);
1720 		vfd->fops = &vivid_fops;
1721 		vfd->ioctl_ops = &vivid_ioctl_ops;
1722 		vfd->device_caps = dev->touch_cap_caps;
1723 		vfd->release = video_device_release_empty;
1724 		vfd->v4l2_dev = &dev->v4l2_dev;
1725 		vfd->queue = &dev->vb_touch_cap_q;
1726 		vfd->tvnorms = tvnorms_cap;
1727 		vfd->lock = &dev->mutex;
1728 		video_set_drvdata(vfd, dev);
1729 #ifdef CONFIG_MEDIA_CONTROLLER
1730 		dev->touch_cap_pad.flags = MEDIA_PAD_FL_SINK;
1731 		ret = media_entity_pads_init(&vfd->entity, 1,
1732 					     &dev->touch_cap_pad);
1733 		if (ret)
1734 			return ret;
1735 #endif
1736 		ret = video_register_device(vfd, VFL_TYPE_TOUCH,
1737 					    touch_cap_nr[inst]);
1738 		if (ret < 0)
1739 			return ret;
1740 		v4l2_info(&dev->v4l2_dev,
1741 			  "V4L2 touch capture device registered as %s\n",
1742 			  video_device_node_name(vfd));
1743 	}
1744 
1745 #ifdef CONFIG_MEDIA_CONTROLLER
1746 	/* Register the media device */
1747 	ret = media_device_register(&dev->mdev);
1748 	if (ret) {
1749 		dev_err(dev->mdev.dev,
1750 			"media device register failed (err=%d)\n", ret);
1751 		return ret;
1752 	}
1753 #endif
1754 	return 0;
1755 }
1756 
update_hdmi_ctrls_work_handler(struct work_struct * work)1757 static void update_hdmi_ctrls_work_handler(struct work_struct *work)
1758 {
1759 	u64 skip_mask;
1760 	u64 update_mask;
1761 
1762 	spin_lock(&hdmi_output_skip_mask_lock);
1763 	skip_mask = hdmi_to_output_menu_skip_mask;
1764 	update_mask = hdmi_input_update_outputs_mask;
1765 	hdmi_input_update_outputs_mask = 0;
1766 	spin_unlock(&hdmi_output_skip_mask_lock);
1767 	for (int i = 0; i < n_devs && vivid_devs[i]; i++) {
1768 		if (update_mask & (1 << i))
1769 			vivid_update_connected_outputs(vivid_devs[i]);
1770 		for (int j = 0; j < vivid_devs[i]->num_hdmi_inputs; j++) {
1771 			struct v4l2_ctrl *c = vivid_devs[i]->ctrl_hdmi_to_output[j];
1772 
1773 			v4l2_ctrl_modify_range(c, c->minimum, c->maximum,
1774 					       skip_mask & ~(1ULL << c->cur.val),
1775 					       c->default_value);
1776 		}
1777 	}
1778 }
1779 
update_svid_ctrls_work_handler(struct work_struct * work)1780 static void update_svid_ctrls_work_handler(struct work_struct *work)
1781 {
1782 	u64 skip_mask;
1783 
1784 	spin_lock(&svid_output_skip_mask_lock);
1785 	skip_mask = svid_to_output_menu_skip_mask;
1786 	spin_unlock(&svid_output_skip_mask_lock);
1787 	for (int i = 0; i < n_devs && vivid_devs[i]; i++) {
1788 		for (int j = 0; j < vivid_devs[i]->num_svid_inputs; j++) {
1789 			struct v4l2_ctrl *c = vivid_devs[i]->ctrl_svid_to_output[j];
1790 
1791 			v4l2_ctrl_modify_range(c, c->minimum, c->maximum,
1792 					       skip_mask & ~(1ULL << c->cur.val),
1793 					       c->default_value);
1794 		}
1795 	}
1796 }
1797 
vivid_create_instance(struct platform_device * pdev,int inst)1798 static int vivid_create_instance(struct platform_device *pdev, int inst)
1799 {
1800 	static const struct v4l2_dv_timings def_dv_timings =
1801 					V4L2_DV_BT_CEA_1280X720P60;
1802 	unsigned in_type_counter[4] = { 0, 0, 0, 0 };
1803 	unsigned out_type_counter[4] = { 0, 0, 0, 0 };
1804 	int ccs_cap = ccs_cap_mode[inst];
1805 	int ccs_out = ccs_out_mode[inst];
1806 	bool has_tuner;
1807 	bool has_modulator;
1808 	struct vivid_dev *dev;
1809 	unsigned node_type = node_types[inst];
1810 	v4l2_std_id tvnorms_cap = 0, tvnorms_out = 0;
1811 	int ret;
1812 	int i;
1813 
1814 	/* allocate main vivid state structure */
1815 	dev = kzalloc(sizeof(*dev), GFP_KERNEL);
1816 	if (!dev)
1817 		return -ENOMEM;
1818 
1819 	dev->inst = inst;
1820 
1821 #ifdef CONFIG_MEDIA_CONTROLLER
1822 	dev->v4l2_dev.mdev = &dev->mdev;
1823 
1824 	/* Initialize media device */
1825 	strscpy(dev->mdev.model, VIVID_MODULE_NAME, sizeof(dev->mdev.model));
1826 	snprintf(dev->mdev.bus_info, sizeof(dev->mdev.bus_info),
1827 		 "platform:%s-%03d", VIVID_MODULE_NAME, inst);
1828 	dev->mdev.dev = &pdev->dev;
1829 	media_device_init(&dev->mdev);
1830 	dev->mdev.ops = &vivid_media_ops;
1831 #endif
1832 
1833 	/* register v4l2_device */
1834 	snprintf(dev->v4l2_dev.name, sizeof(dev->v4l2_dev.name),
1835 			"%s-%03d", VIVID_MODULE_NAME, inst);
1836 	ret = v4l2_device_register(&pdev->dev, &dev->v4l2_dev);
1837 	if (ret) {
1838 		kfree(dev);
1839 		return ret;
1840 	}
1841 	dev->v4l2_dev.release = vivid_dev_release;
1842 
1843 	ret = vivid_detect_feature_set(dev, inst, node_type,
1844 				       &has_tuner, &has_modulator,
1845 				       &ccs_cap, &ccs_out,
1846 				       in_type_counter, out_type_counter);
1847 	if (ret)
1848 		goto free_dev;
1849 
1850 	vivid_set_capabilities(dev);
1851 
1852 	ret = -ENOMEM;
1853 	/* initialize the test pattern generator */
1854 	tpg_init(&dev->tpg, 640, 360);
1855 	if (tpg_alloc(&dev->tpg, array_size(MAX_WIDTH, MAX_ZOOM)))
1856 		goto free_dev;
1857 	dev->scaled_line = vzalloc(array_size(MAX_WIDTH, MAX_ZOOM));
1858 	if (!dev->scaled_line)
1859 		goto free_dev;
1860 	dev->blended_line = vzalloc(array_size(MAX_WIDTH, MAX_ZOOM));
1861 	if (!dev->blended_line)
1862 		goto free_dev;
1863 
1864 	/* load the edid */
1865 	dev->edid = vmalloc(array_size(256, 128));
1866 	if (!dev->edid)
1867 		goto free_dev;
1868 
1869 	ret = vivid_init_dv_timings(dev);
1870 	if (ret < 0)
1871 		goto free_dev;
1872 
1873 	vivid_disable_unused_ioctls(dev, has_tuner, has_modulator,
1874 				    in_type_counter, out_type_counter);
1875 
1876 	/* configure internal data */
1877 	dev->fmt_cap = &vivid_formats[0];
1878 	dev->fmt_out = &vivid_formats[0];
1879 	if (!dev->multiplanar)
1880 		vivid_formats[0].data_offset[0] = 0;
1881 	dev->webcam_size_idx = 1;
1882 	dev->webcam_ival_idx = 3;
1883 	tpg_s_fourcc(&dev->tpg, dev->fmt_cap->fourcc);
1884 	dev->std_out = V4L2_STD_PAL;
1885 	if (dev->input_type[0] == TV || dev->input_type[0] == SVID)
1886 		tvnorms_cap = V4L2_STD_ALL;
1887 	if (dev->output_type[0] == SVID)
1888 		tvnorms_out = V4L2_STD_ALL;
1889 	for (i = 0; i < MAX_INPUTS; i++) {
1890 		dev->dv_timings_cap[i] = def_dv_timings;
1891 		dev->std_cap[i] = V4L2_STD_PAL;
1892 	}
1893 	dev->dv_timings_out = def_dv_timings;
1894 	dev->tv_freq = 2804 /* 175.25 * 16 */;
1895 	dev->tv_audmode = V4L2_TUNER_MODE_STEREO;
1896 	dev->tv_field_cap = V4L2_FIELD_INTERLACED;
1897 	dev->tv_field_out = V4L2_FIELD_INTERLACED;
1898 	dev->radio_rx_freq = 95000 * 16;
1899 	dev->radio_rx_audmode = V4L2_TUNER_MODE_STEREO;
1900 	if (dev->has_radio_tx) {
1901 		dev->radio_tx_freq = 95500 * 16;
1902 		dev->radio_rds_loop = false;
1903 	}
1904 	dev->radio_tx_subchans = V4L2_TUNER_SUB_STEREO | V4L2_TUNER_SUB_RDS;
1905 	dev->sdr_adc_freq = 300000;
1906 	dev->sdr_fm_freq = 50000000;
1907 	dev->sdr_pixelformat = V4L2_SDR_FMT_CU8;
1908 	dev->sdr_buffersize = SDR_CAP_SAMPLES_PER_BUF * 2;
1909 
1910 	dev->edid_max_blocks = dev->edid_blocks = 2;
1911 	memcpy(dev->edid, vivid_hdmi_edid, sizeof(vivid_hdmi_edid));
1912 	dev->radio_rds_init_time = ktime_get();
1913 	INIT_WORK(&dev->update_hdmi_ctrl_work, update_hdmi_ctrls_work_handler);
1914 	INIT_WORK(&dev->update_svid_ctrl_work, update_svid_ctrls_work_handler);
1915 	for (int j = 0, k = 0; j < dev->num_inputs; ++j)
1916 		if (dev->input_type[j] == HDMI)
1917 			dev->hdmi_index_to_input_index[k++] = j;
1918 	for (int j = 0, k = 0; j < dev->num_outputs; ++j)
1919 		if (dev->output_type[j] == HDMI) {
1920 			dev->output_to_iface_index[j] = k;
1921 			dev->hdmi_index_to_output_index[k++] = j;
1922 		}
1923 	for (int j = 0, k = 0; j < dev->num_inputs; ++j)
1924 		if (dev->input_type[j] == SVID)
1925 			dev->svid_index_to_input_index[k++] = j;
1926 	for (int j = 0, k = 0; j < dev->num_outputs; ++j)
1927 		if (dev->output_type[j] == SVID)
1928 			dev->output_to_iface_index[j] = k++;
1929 
1930 	/* create all controls */
1931 	ret = vivid_create_controls(dev, ccs_cap == -1, ccs_out == -1, no_error_inj,
1932 			in_type_counter[TV] || in_type_counter[SVID] ||
1933 			out_type_counter[SVID],
1934 			in_type_counter[HDMI] || out_type_counter[HDMI]);
1935 	if (ret)
1936 		goto unreg_dev;
1937 
1938 	/* enable/disable interface specific controls */
1939 	if (dev->num_inputs && dev->input_type[0] != HDMI) {
1940 		v4l2_ctrl_activate(dev->ctrl_dv_timings_signal_mode, false);
1941 		v4l2_ctrl_activate(dev->ctrl_dv_timings, false);
1942 	} else if (dev->num_inputs && dev->input_type[0] == HDMI) {
1943 		v4l2_ctrl_activate(dev->ctrl_std_signal_mode, false);
1944 		v4l2_ctrl_activate(dev->ctrl_standard, false);
1945 	}
1946 
1947 	/*
1948 	 * update the capture and output formats to do a proper initial
1949 	 * configuration.
1950 	 */
1951 	vivid_update_format_cap(dev, false);
1952 	vivid_update_format_out(dev);
1953 
1954 	/* update touch configuration */
1955 	dev->timeperframe_tch_cap.numerator = 1;
1956 	dev->timeperframe_tch_cap.denominator = 10;
1957 	vivid_set_touch(dev, 0);
1958 
1959 	/* initialize locks */
1960 	spin_lock_init(&dev->slock);
1961 	mutex_init(&dev->mutex);
1962 
1963 	/* init dma queues */
1964 	INIT_LIST_HEAD(&dev->vid_cap_active);
1965 	INIT_LIST_HEAD(&dev->vid_out_active);
1966 	INIT_LIST_HEAD(&dev->vbi_cap_active);
1967 	INIT_LIST_HEAD(&dev->vbi_out_active);
1968 	INIT_LIST_HEAD(&dev->sdr_cap_active);
1969 	INIT_LIST_HEAD(&dev->meta_cap_active);
1970 	INIT_LIST_HEAD(&dev->meta_out_active);
1971 	INIT_LIST_HEAD(&dev->touch_cap_active);
1972 
1973 	spin_lock_init(&dev->cec_xfers_slock);
1974 
1975 	if (allocators[inst] == 1)
1976 		dma_coerce_mask_and_coherent(&pdev->dev, DMA_BIT_MASK(32));
1977 
1978 	ret = vivid_create_queues(dev);
1979 	if (ret)
1980 		goto unreg_dev;
1981 
1982 #ifdef CONFIG_VIDEO_VIVID_CEC
1983 	if (dev->has_vid_cap && in_type_counter[HDMI]) {
1984 		struct cec_adapter *adap;
1985 
1986 		adap = vivid_cec_alloc_adap(dev, 0, false);
1987 		ret = PTR_ERR_OR_ZERO(adap);
1988 		if (ret < 0)
1989 			goto unreg_dev;
1990 		dev->cec_rx_adap = adap;
1991 	}
1992 
1993 	if (dev->has_vid_out) {
1994 		int j;
1995 
1996 		for (i = j = 0; i < dev->num_outputs; i++) {
1997 			struct cec_adapter *adap;
1998 
1999 			if (dev->output_type[i] != HDMI)
2000 				continue;
2001 
2002 			adap = vivid_cec_alloc_adap(dev, j, true);
2003 			ret = PTR_ERR_OR_ZERO(adap);
2004 			if (ret < 0) {
2005 				while (j--)
2006 					cec_delete_adapter(dev->cec_tx_adap[j]);
2007 				goto unreg_dev;
2008 			}
2009 
2010 			dev->cec_tx_adap[j++] = adap;
2011 		}
2012 	}
2013 
2014 	if (dev->cec_rx_adap || dev->num_hdmi_outputs) {
2015 		init_waitqueue_head(&dev->kthread_waitq_cec);
2016 		dev->kthread_cec = kthread_run(vivid_cec_bus_thread, dev,
2017 					       "vivid_cec-%s", dev->v4l2_dev.name);
2018 		if (IS_ERR(dev->kthread_cec)) {
2019 			ret = PTR_ERR(dev->kthread_cec);
2020 			dev->kthread_cec = NULL;
2021 			v4l2_err(&dev->v4l2_dev, "kernel_thread() failed\n");
2022 			goto unreg_dev;
2023 		}
2024 	}
2025 
2026 #endif
2027 
2028 	v4l2_ctrl_handler_setup(&dev->ctrl_hdl_vid_cap);
2029 	v4l2_ctrl_handler_setup(&dev->ctrl_hdl_vid_out);
2030 	v4l2_ctrl_handler_setup(&dev->ctrl_hdl_vbi_cap);
2031 	v4l2_ctrl_handler_setup(&dev->ctrl_hdl_vbi_out);
2032 	v4l2_ctrl_handler_setup(&dev->ctrl_hdl_radio_rx);
2033 	v4l2_ctrl_handler_setup(&dev->ctrl_hdl_radio_tx);
2034 	v4l2_ctrl_handler_setup(&dev->ctrl_hdl_sdr_cap);
2035 	v4l2_ctrl_handler_setup(&dev->ctrl_hdl_meta_cap);
2036 	v4l2_ctrl_handler_setup(&dev->ctrl_hdl_meta_out);
2037 	v4l2_ctrl_handler_setup(&dev->ctrl_hdl_touch_cap);
2038 
2039 	/* finally start creating the device nodes */
2040 	ret = vivid_create_devnodes(pdev, dev, inst,
2041 				    tvnorms_cap, tvnorms_out,
2042 				    in_type_counter, out_type_counter);
2043 	if (ret)
2044 		goto unreg_dev;
2045 
2046 	/* Now that everything is fine, let's add it to device list */
2047 	vivid_devs[inst] = dev;
2048 
2049 	return 0;
2050 
2051 unreg_dev:
2052 	vb2_video_unregister_device(&dev->touch_cap_dev);
2053 	vb2_video_unregister_device(&dev->meta_out_dev);
2054 	vb2_video_unregister_device(&dev->meta_cap_dev);
2055 	video_unregister_device(&dev->radio_tx_dev);
2056 	video_unregister_device(&dev->radio_rx_dev);
2057 	vb2_video_unregister_device(&dev->sdr_cap_dev);
2058 	vb2_video_unregister_device(&dev->vbi_out_dev);
2059 	vb2_video_unregister_device(&dev->vbi_cap_dev);
2060 	vb2_video_unregister_device(&dev->vid_out_dev);
2061 	vb2_video_unregister_device(&dev->vid_cap_dev);
2062 	cec_unregister_adapter(dev->cec_rx_adap);
2063 	for (i = 0; i < MAX_HDMI_OUTPUTS; i++)
2064 		cec_unregister_adapter(dev->cec_tx_adap[i]);
2065 	if (dev->kthread_cec)
2066 		kthread_stop(dev->kthread_cec);
2067 free_dev:
2068 	v4l2_device_put(&dev->v4l2_dev);
2069 	return ret;
2070 }
2071 
2072 /* This routine allocates from 1 to n_devs virtual drivers.
2073 
2074    The real maximum number of virtual drivers will depend on how many drivers
2075    will succeed. This is limited to the maximum number of devices that
2076    videodev supports, which is equal to VIDEO_NUM_DEVICES.
2077  */
vivid_probe(struct platform_device * pdev)2078 static int vivid_probe(struct platform_device *pdev)
2079 {
2080 	const struct font_desc *font = find_font("VGA8x16");
2081 	int ret = 0, i;
2082 
2083 	if (font == NULL) {
2084 		pr_err("vivid: could not find font\n");
2085 		return -ENODEV;
2086 	}
2087 
2088 	tpg_set_font(font->data);
2089 
2090 	n_devs = clamp_t(unsigned, n_devs, 1, VIVID_MAX_DEVS);
2091 
2092 	for (i = 0; i < n_devs; i++) {
2093 		ret = vivid_create_instance(pdev, i);
2094 		if (ret) {
2095 			/* If some instantiations succeeded, keep driver */
2096 			if (i)
2097 				ret = 0;
2098 			break;
2099 		}
2100 	}
2101 
2102 	if (ret < 0) {
2103 		pr_err("vivid: error %d while loading driver\n", ret);
2104 		return ret;
2105 	}
2106 
2107 	/* n_devs will reflect the actual number of allocated devices */
2108 	n_devs = i;
2109 
2110 	/* Determine qmenu items actually in use */
2111 	int hdmi_count = FIXED_MENU_ITEMS;
2112 	int svid_count = FIXED_MENU_ITEMS;
2113 
2114 	for (int i = 0; i < n_devs; i++) {
2115 		struct vivid_dev *dev = vivid_devs[i];
2116 
2117 		if (!dev->has_vid_out)
2118 			continue;
2119 		for (int j = 0; j < dev->num_outputs && hdmi_count < MAX_MENU_ITEMS; ++j) {
2120 			if (dev->output_type[j] == HDMI) {
2121 				vivid_ctrl_hdmi_to_output_instance[hdmi_count] = vivid_devs[i];
2122 				vivid_ctrl_hdmi_to_output_index[hdmi_count++] = j;
2123 			}
2124 		}
2125 		for (int j = 0; j < dev->num_outputs && svid_count < MAX_MENU_ITEMS; ++j) {
2126 			if (dev->output_type[j] == SVID) {
2127 				vivid_ctrl_svid_to_output_instance[svid_count] = vivid_devs[i];
2128 				vivid_ctrl_svid_to_output_index[svid_count++] = j;
2129 			}
2130 		}
2131 	}
2132 	hdmi_count = min(hdmi_count, MAX_MENU_ITEMS);
2133 	svid_count = min(svid_count, MAX_MENU_ITEMS);
2134 	for (int i = 0; i < n_devs; i++) {
2135 		for (int j = 0; j < vivid_devs[i]->num_hdmi_inputs; j++) {
2136 			struct v4l2_ctrl *c = vivid_devs[i]->ctrl_hdmi_to_output[j];
2137 
2138 			v4l2_ctrl_modify_range(c, c->minimum, hdmi_count - 1, 0, c->default_value);
2139 		}
2140 		for (int j = 0; j < vivid_devs[i]->num_svid_inputs; j++) {
2141 			struct v4l2_ctrl *c = vivid_devs[i]->ctrl_svid_to_output[j];
2142 
2143 			v4l2_ctrl_modify_range(c, c->minimum, svid_count - 1, 0, c->default_value);
2144 		}
2145 	}
2146 	return ret;
2147 }
2148 
vivid_remove(struct platform_device * pdev)2149 static void vivid_remove(struct platform_device *pdev)
2150 {
2151 	struct vivid_dev *dev;
2152 	unsigned int i, j;
2153 
2154 	for (i = 0; i < n_devs; i++) {
2155 		dev = vivid_devs[i];
2156 		if (!dev)
2157 			continue;
2158 
2159 		if (dev->disconnect_error)
2160 			vivid_reconnect(dev);
2161 #ifdef CONFIG_MEDIA_CONTROLLER
2162 		media_device_unregister(&dev->mdev);
2163 #endif
2164 
2165 		if (dev->has_vid_cap) {
2166 			v4l2_info(&dev->v4l2_dev, "unregistering %s\n",
2167 				video_device_node_name(&dev->vid_cap_dev));
2168 			vb2_video_unregister_device(&dev->vid_cap_dev);
2169 		}
2170 		if (dev->has_vid_out) {
2171 			v4l2_info(&dev->v4l2_dev, "unregistering %s\n",
2172 				video_device_node_name(&dev->vid_out_dev));
2173 			vb2_video_unregister_device(&dev->vid_out_dev);
2174 		}
2175 		if (dev->has_vbi_cap) {
2176 			v4l2_info(&dev->v4l2_dev, "unregistering %s\n",
2177 				video_device_node_name(&dev->vbi_cap_dev));
2178 			vb2_video_unregister_device(&dev->vbi_cap_dev);
2179 		}
2180 		if (dev->has_vbi_out) {
2181 			v4l2_info(&dev->v4l2_dev, "unregistering %s\n",
2182 				video_device_node_name(&dev->vbi_out_dev));
2183 			vb2_video_unregister_device(&dev->vbi_out_dev);
2184 		}
2185 		if (dev->has_sdr_cap) {
2186 			v4l2_info(&dev->v4l2_dev, "unregistering %s\n",
2187 				video_device_node_name(&dev->sdr_cap_dev));
2188 			vb2_video_unregister_device(&dev->sdr_cap_dev);
2189 		}
2190 		if (dev->has_radio_rx) {
2191 			v4l2_info(&dev->v4l2_dev, "unregistering %s\n",
2192 				video_device_node_name(&dev->radio_rx_dev));
2193 			video_unregister_device(&dev->radio_rx_dev);
2194 		}
2195 		if (dev->has_radio_tx) {
2196 			v4l2_info(&dev->v4l2_dev, "unregistering %s\n",
2197 				video_device_node_name(&dev->radio_tx_dev));
2198 			video_unregister_device(&dev->radio_tx_dev);
2199 		}
2200 		if (dev->has_fb) {
2201 			v4l2_info(&dev->v4l2_dev, "unregistering fb%d\n",
2202 				dev->fb_info.node);
2203 			unregister_framebuffer(&dev->fb_info);
2204 			vivid_fb_release_buffers(dev);
2205 		}
2206 		if (dev->has_meta_cap) {
2207 			v4l2_info(&dev->v4l2_dev, "unregistering %s\n",
2208 				  video_device_node_name(&dev->meta_cap_dev));
2209 			vb2_video_unregister_device(&dev->meta_cap_dev);
2210 		}
2211 		if (dev->has_meta_out) {
2212 			v4l2_info(&dev->v4l2_dev, "unregistering %s\n",
2213 				  video_device_node_name(&dev->meta_out_dev));
2214 			vb2_video_unregister_device(&dev->meta_out_dev);
2215 		}
2216 		if (dev->has_touch_cap) {
2217 			v4l2_info(&dev->v4l2_dev, "unregistering %s\n",
2218 				  video_device_node_name(&dev->touch_cap_dev));
2219 			vb2_video_unregister_device(&dev->touch_cap_dev);
2220 		}
2221 		cec_unregister_adapter(dev->cec_rx_adap);
2222 		for (j = 0; j < MAX_HDMI_OUTPUTS; j++)
2223 			cec_unregister_adapter(dev->cec_tx_adap[j]);
2224 		if (dev->kthread_cec)
2225 			kthread_stop(dev->kthread_cec);
2226 		v4l2_device_put(&dev->v4l2_dev);
2227 		vivid_devs[i] = NULL;
2228 	}
2229 }
2230 
vivid_pdev_release(struct device * dev)2231 static void vivid_pdev_release(struct device *dev)
2232 {
2233 }
2234 
2235 static struct platform_device vivid_pdev = {
2236 	.name		= "vivid",
2237 	.dev.release	= vivid_pdev_release,
2238 };
2239 
2240 static struct platform_driver vivid_pdrv = {
2241 	.probe		= vivid_probe,
2242 	.remove_new	= vivid_remove,
2243 	.driver		= {
2244 		.name	= "vivid",
2245 	},
2246 };
2247 
vivid_init(void)2248 static int __init vivid_init(void)
2249 {
2250 	int hdmi_count = FIXED_MENU_ITEMS;
2251 	int svid_count = FIXED_MENU_ITEMS;
2252 	int ret = -ENOMEM;
2253 	unsigned int ndevs;
2254 
2255 	/* Sanity check, prevent insane number of vivid instances */
2256 	if (n_devs > 64)
2257 		n_devs = 64;
2258 	ndevs = clamp_t(unsigned int, n_devs, 1, VIVID_MAX_DEVS);
2259 
2260 	for (unsigned int i = 0; i < ndevs; i++) {
2261 		if (!(node_types[i] & (1 << 8)))
2262 			continue;
2263 		unsigned int n_outputs = min(num_outputs[i], MAX_OUTPUTS);
2264 
2265 		for (u8 j = 0, k = 0; j < n_outputs && hdmi_count < MAX_MENU_ITEMS &&
2266 		     k < MAX_HDMI_OUTPUTS; ++j) {
2267 			if (output_types[i] & BIT(j)) {
2268 				vivid_ctrl_hdmi_to_output_strings[hdmi_count] =
2269 					kmalloc(MAX_STRING_LENGTH, GFP_KERNEL);
2270 				if (!vivid_ctrl_hdmi_to_output_strings[hdmi_count])
2271 					goto free_output_strings;
2272 				snprintf(vivid_ctrl_hdmi_to_output_strings[hdmi_count],
2273 					 MAX_STRING_LENGTH, "Output HDMI %03d-%d",
2274 					 i & 0xff, k);
2275 				k++;
2276 				hdmi_count++;
2277 			}
2278 		}
2279 		for (u8 j = 0, k = 0; j < n_outputs && svid_count < MAX_MENU_ITEMS; ++j) {
2280 			if (!(output_types[i] & BIT(j))) {
2281 				vivid_ctrl_svid_to_output_strings[svid_count] =
2282 					kmalloc(MAX_STRING_LENGTH, GFP_KERNEL);
2283 				if (!vivid_ctrl_svid_to_output_strings[svid_count])
2284 					goto free_output_strings;
2285 				snprintf(vivid_ctrl_svid_to_output_strings[svid_count],
2286 					 MAX_STRING_LENGTH, "Output S-Video %03d-%d",
2287 					 i & 0xff, k);
2288 				k++;
2289 				svid_count++;
2290 			}
2291 		}
2292 	}
2293 	ret = platform_device_register(&vivid_pdev);
2294 	if (ret)
2295 		goto free_output_strings;
2296 	ret = platform_driver_register(&vivid_pdrv);
2297 	if (ret)
2298 		goto unreg_device;
2299 
2300 	/* Initialize workqueue before module is loaded */
2301 	update_hdmi_ctrls_workqueue = create_workqueue("update_hdmi_ctrls_wq");
2302 	if (!update_hdmi_ctrls_workqueue) {
2303 		ret = -ENOMEM;
2304 		goto unreg_driver;
2305 	}
2306 	update_svid_ctrls_workqueue = create_workqueue("update_svid_ctrls_wq");
2307 	if (!update_svid_ctrls_workqueue) {
2308 		ret = -ENOMEM;
2309 		goto destroy_hdmi_wq;
2310 	}
2311 	return ret;
2312 
2313 destroy_hdmi_wq:
2314 	destroy_workqueue(update_hdmi_ctrls_workqueue);
2315 unreg_driver:
2316 	platform_driver_register(&vivid_pdrv);
2317 unreg_device:
2318 	platform_device_unregister(&vivid_pdev);
2319 free_output_strings:
2320 	for (int i = FIXED_MENU_ITEMS; i < MAX_MENU_ITEMS; i++) {
2321 		kfree(vivid_ctrl_hdmi_to_output_strings[i]);
2322 		kfree(vivid_ctrl_svid_to_output_strings[i]);
2323 	}
2324 	return ret;
2325 }
2326 
vivid_exit(void)2327 static void __exit vivid_exit(void)
2328 {
2329 	for (int i = FIXED_MENU_ITEMS; i < MAX_MENU_ITEMS; i++) {
2330 		kfree(vivid_ctrl_hdmi_to_output_strings[i]);
2331 		kfree(vivid_ctrl_svid_to_output_strings[i]);
2332 	}
2333 	destroy_workqueue(update_svid_ctrls_workqueue);
2334 	destroy_workqueue(update_hdmi_ctrls_workqueue);
2335 	platform_driver_unregister(&vivid_pdrv);
2336 	platform_device_unregister(&vivid_pdev);
2337 }
2338 
2339 module_init(vivid_init);
2340 module_exit(vivid_exit);
2341