1 // SPDX-License-Identifier: GPL-2.0-or-later
2 /*
3 * V4L2 controls framework core implementation.
4 *
5 * Copyright (C) 2010-2021 Hans Verkuil <hverkuil-cisco@xs4all.nl>
6 */
7
8 #include <linux/export.h>
9 #include <linux/mm.h>
10 #include <linux/slab.h>
11 #include <media/v4l2-ctrls.h>
12 #include <media/v4l2-event.h>
13 #include <media/v4l2-fwnode.h>
14
15 #include "v4l2-ctrls-priv.h"
16
17 static const union v4l2_ctrl_ptr ptr_null;
18
fill_event(struct v4l2_event * ev,struct v4l2_ctrl * ctrl,u32 changes)19 static void fill_event(struct v4l2_event *ev, struct v4l2_ctrl *ctrl,
20 u32 changes)
21 {
22 memset(ev, 0, sizeof(*ev));
23 ev->type = V4L2_EVENT_CTRL;
24 ev->id = ctrl->id;
25 ev->u.ctrl.changes = changes;
26 ev->u.ctrl.type = ctrl->type;
27 ev->u.ctrl.flags = user_flags(ctrl);
28 if (ctrl->is_ptr)
29 ev->u.ctrl.value64 = 0;
30 else
31 ev->u.ctrl.value64 = *ctrl->p_cur.p_s64;
32 ev->u.ctrl.minimum = ctrl->minimum;
33 ev->u.ctrl.maximum = ctrl->maximum;
34 if (ctrl->type == V4L2_CTRL_TYPE_MENU
35 || ctrl->type == V4L2_CTRL_TYPE_INTEGER_MENU)
36 ev->u.ctrl.step = 1;
37 else
38 ev->u.ctrl.step = ctrl->step;
39 ev->u.ctrl.default_value = ctrl->default_value;
40 }
41
send_initial_event(struct v4l2_fh * fh,struct v4l2_ctrl * ctrl)42 void send_initial_event(struct v4l2_fh *fh, struct v4l2_ctrl *ctrl)
43 {
44 struct v4l2_event ev;
45 u32 changes = V4L2_EVENT_CTRL_CH_FLAGS;
46
47 if (!(ctrl->flags & V4L2_CTRL_FLAG_WRITE_ONLY))
48 changes |= V4L2_EVENT_CTRL_CH_VALUE;
49 fill_event(&ev, ctrl, changes);
50 v4l2_event_queue_fh(fh, &ev);
51 }
52
send_event(struct v4l2_fh * fh,struct v4l2_ctrl * ctrl,u32 changes)53 void send_event(struct v4l2_fh *fh, struct v4l2_ctrl *ctrl, u32 changes)
54 {
55 struct v4l2_event ev;
56 struct v4l2_subscribed_event *sev;
57
58 if (list_empty(&ctrl->ev_subs))
59 return;
60 fill_event(&ev, ctrl, changes);
61
62 list_for_each_entry(sev, &ctrl->ev_subs, node)
63 if (sev->fh != fh ||
64 (sev->flags & V4L2_EVENT_SUB_FL_ALLOW_FEEDBACK))
65 v4l2_event_queue_fh(sev->fh, &ev);
66 }
67
std_equal(const struct v4l2_ctrl * ctrl,u32 idx,union v4l2_ctrl_ptr ptr1,union v4l2_ctrl_ptr ptr2)68 static bool std_equal(const struct v4l2_ctrl *ctrl, u32 idx,
69 union v4l2_ctrl_ptr ptr1,
70 union v4l2_ctrl_ptr ptr2)
71 {
72 switch (ctrl->type) {
73 case V4L2_CTRL_TYPE_BUTTON:
74 return false;
75 case V4L2_CTRL_TYPE_STRING:
76 idx *= ctrl->elem_size;
77 /* strings are always 0-terminated */
78 return !strcmp(ptr1.p_char + idx, ptr2.p_char + idx);
79 case V4L2_CTRL_TYPE_INTEGER64:
80 return ptr1.p_s64[idx] == ptr2.p_s64[idx];
81 case V4L2_CTRL_TYPE_U8:
82 return ptr1.p_u8[idx] == ptr2.p_u8[idx];
83 case V4L2_CTRL_TYPE_U16:
84 return ptr1.p_u16[idx] == ptr2.p_u16[idx];
85 case V4L2_CTRL_TYPE_U32:
86 return ptr1.p_u32[idx] == ptr2.p_u32[idx];
87 default:
88 if (ctrl->is_int)
89 return ptr1.p_s32[idx] == ptr2.p_s32[idx];
90 idx *= ctrl->elem_size;
91 return !memcmp(ptr1.p_const + idx, ptr2.p_const + idx,
92 ctrl->elem_size);
93 }
94 }
95
96 /* Default intra MPEG-2 quantisation coefficients, from the specification. */
97 static const u8 mpeg2_intra_quant_matrix[64] = {
98 8, 16, 16, 19, 16, 19, 22, 22,
99 22, 22, 22, 22, 26, 24, 26, 27,
100 27, 27, 26, 26, 26, 26, 27, 27,
101 27, 29, 29, 29, 34, 34, 34, 29,
102 29, 29, 27, 27, 29, 29, 32, 32,
103 34, 34, 37, 38, 37, 35, 35, 34,
104 35, 38, 38, 40, 40, 40, 48, 48,
105 46, 46, 56, 56, 58, 69, 69, 83
106 };
107
std_init_compound(const struct v4l2_ctrl * ctrl,u32 idx,union v4l2_ctrl_ptr ptr)108 static void std_init_compound(const struct v4l2_ctrl *ctrl, u32 idx,
109 union v4l2_ctrl_ptr ptr)
110 {
111 struct v4l2_ctrl_mpeg2_sequence *p_mpeg2_sequence;
112 struct v4l2_ctrl_mpeg2_picture *p_mpeg2_picture;
113 struct v4l2_ctrl_mpeg2_quantisation *p_mpeg2_quant;
114 struct v4l2_ctrl_vp8_frame *p_vp8_frame;
115 struct v4l2_ctrl_fwht_params *p_fwht_params;
116 void *p = ptr.p + idx * ctrl->elem_size;
117
118 if (ctrl->p_def.p_const)
119 memcpy(p, ctrl->p_def.p_const, ctrl->elem_size);
120 else
121 memset(p, 0, ctrl->elem_size);
122
123 switch ((u32)ctrl->type) {
124 case V4L2_CTRL_TYPE_MPEG2_SEQUENCE:
125 p_mpeg2_sequence = p;
126
127 /* 4:2:0 */
128 p_mpeg2_sequence->chroma_format = 1;
129 break;
130 case V4L2_CTRL_TYPE_MPEG2_PICTURE:
131 p_mpeg2_picture = p;
132
133 /* interlaced top field */
134 p_mpeg2_picture->picture_structure = V4L2_MPEG2_PIC_TOP_FIELD;
135 p_mpeg2_picture->picture_coding_type =
136 V4L2_MPEG2_PIC_CODING_TYPE_I;
137 break;
138 case V4L2_CTRL_TYPE_MPEG2_QUANTISATION:
139 p_mpeg2_quant = p;
140
141 memcpy(p_mpeg2_quant->intra_quantiser_matrix,
142 mpeg2_intra_quant_matrix,
143 ARRAY_SIZE(mpeg2_intra_quant_matrix));
144 /*
145 * The default non-intra MPEG-2 quantisation
146 * coefficients are all 16, as per the specification.
147 */
148 memset(p_mpeg2_quant->non_intra_quantiser_matrix, 16,
149 sizeof(p_mpeg2_quant->non_intra_quantiser_matrix));
150 break;
151 case V4L2_CTRL_TYPE_VP8_FRAME:
152 p_vp8_frame = p;
153 p_vp8_frame->num_dct_parts = 1;
154 break;
155 case V4L2_CTRL_TYPE_FWHT_PARAMS:
156 p_fwht_params = p;
157 p_fwht_params->version = V4L2_FWHT_VERSION;
158 p_fwht_params->width = 1280;
159 p_fwht_params->height = 720;
160 p_fwht_params->flags = V4L2_FWHT_FL_PIXENC_YUV |
161 (2 << V4L2_FWHT_FL_COMPONENTS_NUM_OFFSET);
162 break;
163 }
164 }
165
std_init(const struct v4l2_ctrl * ctrl,u32 idx,union v4l2_ctrl_ptr ptr)166 static void std_init(const struct v4l2_ctrl *ctrl, u32 idx,
167 union v4l2_ctrl_ptr ptr)
168 {
169 switch (ctrl->type) {
170 case V4L2_CTRL_TYPE_STRING:
171 idx *= ctrl->elem_size;
172 memset(ptr.p_char + idx, ' ', ctrl->minimum);
173 ptr.p_char[idx + ctrl->minimum] = '\0';
174 break;
175 case V4L2_CTRL_TYPE_INTEGER64:
176 ptr.p_s64[idx] = ctrl->default_value;
177 break;
178 case V4L2_CTRL_TYPE_INTEGER:
179 case V4L2_CTRL_TYPE_INTEGER_MENU:
180 case V4L2_CTRL_TYPE_MENU:
181 case V4L2_CTRL_TYPE_BITMASK:
182 case V4L2_CTRL_TYPE_BOOLEAN:
183 ptr.p_s32[idx] = ctrl->default_value;
184 break;
185 case V4L2_CTRL_TYPE_BUTTON:
186 case V4L2_CTRL_TYPE_CTRL_CLASS:
187 ptr.p_s32[idx] = 0;
188 break;
189 case V4L2_CTRL_TYPE_U8:
190 ptr.p_u8[idx] = ctrl->default_value;
191 break;
192 case V4L2_CTRL_TYPE_U16:
193 ptr.p_u16[idx] = ctrl->default_value;
194 break;
195 case V4L2_CTRL_TYPE_U32:
196 ptr.p_u32[idx] = ctrl->default_value;
197 break;
198 default:
199 std_init_compound(ctrl, idx, ptr);
200 break;
201 }
202 }
203
std_log(const struct v4l2_ctrl * ctrl)204 static void std_log(const struct v4l2_ctrl *ctrl)
205 {
206 union v4l2_ctrl_ptr ptr = ctrl->p_cur;
207
208 if (ctrl->is_array) {
209 unsigned i;
210
211 for (i = 0; i < ctrl->nr_of_dims; i++)
212 pr_cont("[%u]", ctrl->dims[i]);
213 pr_cont(" ");
214 }
215
216 switch (ctrl->type) {
217 case V4L2_CTRL_TYPE_INTEGER:
218 pr_cont("%d", *ptr.p_s32);
219 break;
220 case V4L2_CTRL_TYPE_BOOLEAN:
221 pr_cont("%s", *ptr.p_s32 ? "true" : "false");
222 break;
223 case V4L2_CTRL_TYPE_MENU:
224 pr_cont("%s", ctrl->qmenu[*ptr.p_s32]);
225 break;
226 case V4L2_CTRL_TYPE_INTEGER_MENU:
227 pr_cont("%lld", ctrl->qmenu_int[*ptr.p_s32]);
228 break;
229 case V4L2_CTRL_TYPE_BITMASK:
230 pr_cont("0x%08x", *ptr.p_s32);
231 break;
232 case V4L2_CTRL_TYPE_INTEGER64:
233 pr_cont("%lld", *ptr.p_s64);
234 break;
235 case V4L2_CTRL_TYPE_STRING:
236 pr_cont("%s", ptr.p_char);
237 break;
238 case V4L2_CTRL_TYPE_U8:
239 pr_cont("%u", (unsigned)*ptr.p_u8);
240 break;
241 case V4L2_CTRL_TYPE_U16:
242 pr_cont("%u", (unsigned)*ptr.p_u16);
243 break;
244 case V4L2_CTRL_TYPE_U32:
245 pr_cont("%u", (unsigned)*ptr.p_u32);
246 break;
247 case V4L2_CTRL_TYPE_H264_SPS:
248 pr_cont("H264_SPS");
249 break;
250 case V4L2_CTRL_TYPE_H264_PPS:
251 pr_cont("H264_PPS");
252 break;
253 case V4L2_CTRL_TYPE_H264_SCALING_MATRIX:
254 pr_cont("H264_SCALING_MATRIX");
255 break;
256 case V4L2_CTRL_TYPE_H264_SLICE_PARAMS:
257 pr_cont("H264_SLICE_PARAMS");
258 break;
259 case V4L2_CTRL_TYPE_H264_DECODE_PARAMS:
260 pr_cont("H264_DECODE_PARAMS");
261 break;
262 case V4L2_CTRL_TYPE_H264_PRED_WEIGHTS:
263 pr_cont("H264_PRED_WEIGHTS");
264 break;
265 case V4L2_CTRL_TYPE_FWHT_PARAMS:
266 pr_cont("FWHT_PARAMS");
267 break;
268 case V4L2_CTRL_TYPE_VP8_FRAME:
269 pr_cont("VP8_FRAME");
270 break;
271 case V4L2_CTRL_TYPE_HDR10_CLL_INFO:
272 pr_cont("HDR10_CLL_INFO");
273 break;
274 case V4L2_CTRL_TYPE_HDR10_MASTERING_DISPLAY:
275 pr_cont("HDR10_MASTERING_DISPLAY");
276 break;
277 case V4L2_CTRL_TYPE_MPEG2_QUANTISATION:
278 pr_cont("MPEG2_QUANTISATION");
279 break;
280 case V4L2_CTRL_TYPE_MPEG2_SEQUENCE:
281 pr_cont("MPEG2_SEQUENCE");
282 break;
283 case V4L2_CTRL_TYPE_MPEG2_PICTURE:
284 pr_cont("MPEG2_PICTURE");
285 break;
286 default:
287 pr_cont("unknown type %d", ctrl->type);
288 break;
289 }
290 }
291
292 /*
293 * Round towards the closest legal value. Be careful when we are
294 * close to the maximum range of the control type to prevent
295 * wrap-arounds.
296 */
297 #define ROUND_TO_RANGE(val, offset_type, ctrl) \
298 ({ \
299 offset_type offset; \
300 if ((ctrl)->maximum >= 0 && \
301 val >= (ctrl)->maximum - (s32)((ctrl)->step / 2)) \
302 val = (ctrl)->maximum; \
303 else \
304 val += (s32)((ctrl)->step / 2); \
305 val = clamp_t(typeof(val), val, \
306 (ctrl)->minimum, (ctrl)->maximum); \
307 offset = (val) - (ctrl)->minimum; \
308 offset = (ctrl)->step * (offset / (u32)(ctrl)->step); \
309 val = (ctrl)->minimum + offset; \
310 0; \
311 })
312
313 /* Validate a new control */
314
315 #define zero_padding(s) \
316 memset(&(s).padding, 0, sizeof((s).padding))
317 #define zero_reserved(s) \
318 memset(&(s).reserved, 0, sizeof((s).reserved))
319
320 /*
321 * Compound controls validation requires setting unused fields/flags to zero
322 * in order to properly detect unchanged controls with std_equal's memcmp.
323 */
std_validate_compound(const struct v4l2_ctrl * ctrl,u32 idx,union v4l2_ctrl_ptr ptr)324 static int std_validate_compound(const struct v4l2_ctrl *ctrl, u32 idx,
325 union v4l2_ctrl_ptr ptr)
326 {
327 struct v4l2_ctrl_mpeg2_sequence *p_mpeg2_sequence;
328 struct v4l2_ctrl_mpeg2_picture *p_mpeg2_picture;
329 struct v4l2_ctrl_vp8_frame *p_vp8_frame;
330 struct v4l2_ctrl_fwht_params *p_fwht_params;
331 struct v4l2_ctrl_h264_sps *p_h264_sps;
332 struct v4l2_ctrl_h264_pps *p_h264_pps;
333 struct v4l2_ctrl_h264_pred_weights *p_h264_pred_weights;
334 struct v4l2_ctrl_h264_slice_params *p_h264_slice_params;
335 struct v4l2_ctrl_h264_decode_params *p_h264_dec_params;
336 struct v4l2_ctrl_hevc_sps *p_hevc_sps;
337 struct v4l2_ctrl_hevc_pps *p_hevc_pps;
338 struct v4l2_ctrl_hevc_slice_params *p_hevc_slice_params;
339 struct v4l2_ctrl_hdr10_mastering_display *p_hdr10_mastering;
340 struct v4l2_ctrl_hevc_decode_params *p_hevc_decode_params;
341 struct v4l2_area *area;
342 void *p = ptr.p + idx * ctrl->elem_size;
343 unsigned int i;
344
345 switch ((u32)ctrl->type) {
346 case V4L2_CTRL_TYPE_MPEG2_SEQUENCE:
347 p_mpeg2_sequence = p;
348
349 switch (p_mpeg2_sequence->chroma_format) {
350 case 1: /* 4:2:0 */
351 case 2: /* 4:2:2 */
352 case 3: /* 4:4:4 */
353 break;
354 default:
355 return -EINVAL;
356 }
357 break;
358
359 case V4L2_CTRL_TYPE_MPEG2_PICTURE:
360 p_mpeg2_picture = p;
361
362 switch (p_mpeg2_picture->intra_dc_precision) {
363 case 0: /* 8 bits */
364 case 1: /* 9 bits */
365 case 2: /* 10 bits */
366 case 3: /* 11 bits */
367 break;
368 default:
369 return -EINVAL;
370 }
371
372 switch (p_mpeg2_picture->picture_structure) {
373 case V4L2_MPEG2_PIC_TOP_FIELD:
374 case V4L2_MPEG2_PIC_BOTTOM_FIELD:
375 case V4L2_MPEG2_PIC_FRAME:
376 break;
377 default:
378 return -EINVAL;
379 }
380
381 switch (p_mpeg2_picture->picture_coding_type) {
382 case V4L2_MPEG2_PIC_CODING_TYPE_I:
383 case V4L2_MPEG2_PIC_CODING_TYPE_P:
384 case V4L2_MPEG2_PIC_CODING_TYPE_B:
385 break;
386 default:
387 return -EINVAL;
388 }
389 zero_reserved(*p_mpeg2_picture);
390 break;
391
392 case V4L2_CTRL_TYPE_MPEG2_QUANTISATION:
393 break;
394
395 case V4L2_CTRL_TYPE_FWHT_PARAMS:
396 p_fwht_params = p;
397 if (p_fwht_params->version < V4L2_FWHT_VERSION)
398 return -EINVAL;
399 if (!p_fwht_params->width || !p_fwht_params->height)
400 return -EINVAL;
401 break;
402
403 case V4L2_CTRL_TYPE_H264_SPS:
404 p_h264_sps = p;
405
406 /* Some syntax elements are only conditionally valid */
407 if (p_h264_sps->pic_order_cnt_type != 0) {
408 p_h264_sps->log2_max_pic_order_cnt_lsb_minus4 = 0;
409 } else if (p_h264_sps->pic_order_cnt_type != 1) {
410 p_h264_sps->num_ref_frames_in_pic_order_cnt_cycle = 0;
411 p_h264_sps->offset_for_non_ref_pic = 0;
412 p_h264_sps->offset_for_top_to_bottom_field = 0;
413 memset(&p_h264_sps->offset_for_ref_frame, 0,
414 sizeof(p_h264_sps->offset_for_ref_frame));
415 }
416
417 if (!V4L2_H264_SPS_HAS_CHROMA_FORMAT(p_h264_sps)) {
418 p_h264_sps->chroma_format_idc = 1;
419 p_h264_sps->bit_depth_luma_minus8 = 0;
420 p_h264_sps->bit_depth_chroma_minus8 = 0;
421
422 p_h264_sps->flags &=
423 ~V4L2_H264_SPS_FLAG_QPPRIME_Y_ZERO_TRANSFORM_BYPASS;
424
425 if (p_h264_sps->chroma_format_idc < 3)
426 p_h264_sps->flags &=
427 ~V4L2_H264_SPS_FLAG_SEPARATE_COLOUR_PLANE;
428 }
429
430 if (p_h264_sps->flags & V4L2_H264_SPS_FLAG_FRAME_MBS_ONLY)
431 p_h264_sps->flags &=
432 ~V4L2_H264_SPS_FLAG_MB_ADAPTIVE_FRAME_FIELD;
433
434 /*
435 * Chroma 4:2:2 format require at least High 4:2:2 profile.
436 *
437 * The H264 specification and well-known parser implementations
438 * use profile-idc values directly, as that is clearer and
439 * less ambiguous. We do the same here.
440 */
441 if (p_h264_sps->profile_idc < 122 &&
442 p_h264_sps->chroma_format_idc > 1)
443 return -EINVAL;
444 /* Chroma 4:4:4 format require at least High 4:2:2 profile */
445 if (p_h264_sps->profile_idc < 244 &&
446 p_h264_sps->chroma_format_idc > 2)
447 return -EINVAL;
448 if (p_h264_sps->chroma_format_idc > 3)
449 return -EINVAL;
450
451 if (p_h264_sps->bit_depth_luma_minus8 > 6)
452 return -EINVAL;
453 if (p_h264_sps->bit_depth_chroma_minus8 > 6)
454 return -EINVAL;
455 if (p_h264_sps->log2_max_frame_num_minus4 > 12)
456 return -EINVAL;
457 if (p_h264_sps->pic_order_cnt_type > 2)
458 return -EINVAL;
459 if (p_h264_sps->log2_max_pic_order_cnt_lsb_minus4 > 12)
460 return -EINVAL;
461 if (p_h264_sps->max_num_ref_frames > V4L2_H264_REF_LIST_LEN)
462 return -EINVAL;
463 break;
464
465 case V4L2_CTRL_TYPE_H264_PPS:
466 p_h264_pps = p;
467
468 if (p_h264_pps->num_slice_groups_minus1 > 7)
469 return -EINVAL;
470 if (p_h264_pps->num_ref_idx_l0_default_active_minus1 >
471 (V4L2_H264_REF_LIST_LEN - 1))
472 return -EINVAL;
473 if (p_h264_pps->num_ref_idx_l1_default_active_minus1 >
474 (V4L2_H264_REF_LIST_LEN - 1))
475 return -EINVAL;
476 if (p_h264_pps->weighted_bipred_idc > 2)
477 return -EINVAL;
478 /*
479 * pic_init_qp_minus26 shall be in the range of
480 * -(26 + QpBdOffset_y) to +25, inclusive,
481 * where QpBdOffset_y is 6 * bit_depth_luma_minus8
482 */
483 if (p_h264_pps->pic_init_qp_minus26 < -62 ||
484 p_h264_pps->pic_init_qp_minus26 > 25)
485 return -EINVAL;
486 if (p_h264_pps->pic_init_qs_minus26 < -26 ||
487 p_h264_pps->pic_init_qs_minus26 > 25)
488 return -EINVAL;
489 if (p_h264_pps->chroma_qp_index_offset < -12 ||
490 p_h264_pps->chroma_qp_index_offset > 12)
491 return -EINVAL;
492 if (p_h264_pps->second_chroma_qp_index_offset < -12 ||
493 p_h264_pps->second_chroma_qp_index_offset > 12)
494 return -EINVAL;
495 break;
496
497 case V4L2_CTRL_TYPE_H264_SCALING_MATRIX:
498 break;
499
500 case V4L2_CTRL_TYPE_H264_PRED_WEIGHTS:
501 p_h264_pred_weights = p;
502
503 if (p_h264_pred_weights->luma_log2_weight_denom > 7)
504 return -EINVAL;
505 if (p_h264_pred_weights->chroma_log2_weight_denom > 7)
506 return -EINVAL;
507 break;
508
509 case V4L2_CTRL_TYPE_H264_SLICE_PARAMS:
510 p_h264_slice_params = p;
511
512 if (p_h264_slice_params->slice_type != V4L2_H264_SLICE_TYPE_B)
513 p_h264_slice_params->flags &=
514 ~V4L2_H264_SLICE_FLAG_DIRECT_SPATIAL_MV_PRED;
515
516 if (p_h264_slice_params->colour_plane_id > 2)
517 return -EINVAL;
518 if (p_h264_slice_params->cabac_init_idc > 2)
519 return -EINVAL;
520 if (p_h264_slice_params->disable_deblocking_filter_idc > 2)
521 return -EINVAL;
522 if (p_h264_slice_params->slice_alpha_c0_offset_div2 < -6 ||
523 p_h264_slice_params->slice_alpha_c0_offset_div2 > 6)
524 return -EINVAL;
525 if (p_h264_slice_params->slice_beta_offset_div2 < -6 ||
526 p_h264_slice_params->slice_beta_offset_div2 > 6)
527 return -EINVAL;
528
529 if (p_h264_slice_params->slice_type == V4L2_H264_SLICE_TYPE_I ||
530 p_h264_slice_params->slice_type == V4L2_H264_SLICE_TYPE_SI)
531 p_h264_slice_params->num_ref_idx_l0_active_minus1 = 0;
532 if (p_h264_slice_params->slice_type != V4L2_H264_SLICE_TYPE_B)
533 p_h264_slice_params->num_ref_idx_l1_active_minus1 = 0;
534
535 if (p_h264_slice_params->num_ref_idx_l0_active_minus1 >
536 (V4L2_H264_REF_LIST_LEN - 1))
537 return -EINVAL;
538 if (p_h264_slice_params->num_ref_idx_l1_active_minus1 >
539 (V4L2_H264_REF_LIST_LEN - 1))
540 return -EINVAL;
541 zero_reserved(*p_h264_slice_params);
542 break;
543
544 case V4L2_CTRL_TYPE_H264_DECODE_PARAMS:
545 p_h264_dec_params = p;
546
547 if (p_h264_dec_params->nal_ref_idc > 3)
548 return -EINVAL;
549 for (i = 0; i < V4L2_H264_NUM_DPB_ENTRIES; i++) {
550 struct v4l2_h264_dpb_entry *dpb_entry =
551 &p_h264_dec_params->dpb[i];
552
553 zero_reserved(*dpb_entry);
554 }
555 zero_reserved(*p_h264_dec_params);
556 break;
557
558 case V4L2_CTRL_TYPE_VP8_FRAME:
559 p_vp8_frame = p;
560
561 switch (p_vp8_frame->num_dct_parts) {
562 case 1:
563 case 2:
564 case 4:
565 case 8:
566 break;
567 default:
568 return -EINVAL;
569 }
570 zero_padding(p_vp8_frame->segment);
571 zero_padding(p_vp8_frame->lf);
572 zero_padding(p_vp8_frame->quant);
573 zero_padding(p_vp8_frame->entropy);
574 zero_padding(p_vp8_frame->coder_state);
575 break;
576
577 case V4L2_CTRL_TYPE_HEVC_SPS:
578 p_hevc_sps = p;
579
580 if (!(p_hevc_sps->flags & V4L2_HEVC_SPS_FLAG_PCM_ENABLED)) {
581 p_hevc_sps->pcm_sample_bit_depth_luma_minus1 = 0;
582 p_hevc_sps->pcm_sample_bit_depth_chroma_minus1 = 0;
583 p_hevc_sps->log2_min_pcm_luma_coding_block_size_minus3 = 0;
584 p_hevc_sps->log2_diff_max_min_pcm_luma_coding_block_size = 0;
585 }
586
587 if (!(p_hevc_sps->flags &
588 V4L2_HEVC_SPS_FLAG_LONG_TERM_REF_PICS_PRESENT))
589 p_hevc_sps->num_long_term_ref_pics_sps = 0;
590 break;
591
592 case V4L2_CTRL_TYPE_HEVC_PPS:
593 p_hevc_pps = p;
594
595 if (!(p_hevc_pps->flags &
596 V4L2_HEVC_PPS_FLAG_CU_QP_DELTA_ENABLED))
597 p_hevc_pps->diff_cu_qp_delta_depth = 0;
598
599 if (!(p_hevc_pps->flags & V4L2_HEVC_PPS_FLAG_TILES_ENABLED)) {
600 p_hevc_pps->num_tile_columns_minus1 = 0;
601 p_hevc_pps->num_tile_rows_minus1 = 0;
602 memset(&p_hevc_pps->column_width_minus1, 0,
603 sizeof(p_hevc_pps->column_width_minus1));
604 memset(&p_hevc_pps->row_height_minus1, 0,
605 sizeof(p_hevc_pps->row_height_minus1));
606
607 p_hevc_pps->flags &=
608 ~V4L2_HEVC_PPS_FLAG_LOOP_FILTER_ACROSS_TILES_ENABLED;
609 }
610
611 if (p_hevc_pps->flags &
612 V4L2_HEVC_PPS_FLAG_PPS_DISABLE_DEBLOCKING_FILTER) {
613 p_hevc_pps->pps_beta_offset_div2 = 0;
614 p_hevc_pps->pps_tc_offset_div2 = 0;
615 }
616
617 zero_padding(*p_hevc_pps);
618 break;
619
620 case V4L2_CTRL_TYPE_HEVC_DECODE_PARAMS:
621 p_hevc_decode_params = p;
622
623 if (p_hevc_decode_params->num_active_dpb_entries >
624 V4L2_HEVC_DPB_ENTRIES_NUM_MAX)
625 return -EINVAL;
626
627 for (i = 0; i < p_hevc_decode_params->num_active_dpb_entries;
628 i++) {
629 struct v4l2_hevc_dpb_entry *dpb_entry =
630 &p_hevc_decode_params->dpb[i];
631
632 zero_padding(*dpb_entry);
633 }
634 break;
635
636 case V4L2_CTRL_TYPE_HEVC_SLICE_PARAMS:
637 p_hevc_slice_params = p;
638
639 zero_padding(p_hevc_slice_params->pred_weight_table);
640 zero_padding(*p_hevc_slice_params);
641 break;
642
643 case V4L2_CTRL_TYPE_HDR10_CLL_INFO:
644 break;
645
646 case V4L2_CTRL_TYPE_HDR10_MASTERING_DISPLAY:
647 p_hdr10_mastering = p;
648
649 for (i = 0; i < 3; ++i) {
650 if (p_hdr10_mastering->display_primaries_x[i] <
651 V4L2_HDR10_MASTERING_PRIMARIES_X_LOW ||
652 p_hdr10_mastering->display_primaries_x[i] >
653 V4L2_HDR10_MASTERING_PRIMARIES_X_HIGH ||
654 p_hdr10_mastering->display_primaries_y[i] <
655 V4L2_HDR10_MASTERING_PRIMARIES_Y_LOW ||
656 p_hdr10_mastering->display_primaries_y[i] >
657 V4L2_HDR10_MASTERING_PRIMARIES_Y_HIGH)
658 return -EINVAL;
659 }
660
661 if (p_hdr10_mastering->white_point_x <
662 V4L2_HDR10_MASTERING_WHITE_POINT_X_LOW ||
663 p_hdr10_mastering->white_point_x >
664 V4L2_HDR10_MASTERING_WHITE_POINT_X_HIGH ||
665 p_hdr10_mastering->white_point_y <
666 V4L2_HDR10_MASTERING_WHITE_POINT_Y_LOW ||
667 p_hdr10_mastering->white_point_y >
668 V4L2_HDR10_MASTERING_WHITE_POINT_Y_HIGH)
669 return -EINVAL;
670
671 if (p_hdr10_mastering->max_display_mastering_luminance <
672 V4L2_HDR10_MASTERING_MAX_LUMA_LOW ||
673 p_hdr10_mastering->max_display_mastering_luminance >
674 V4L2_HDR10_MASTERING_MAX_LUMA_HIGH ||
675 p_hdr10_mastering->min_display_mastering_luminance <
676 V4L2_HDR10_MASTERING_MIN_LUMA_LOW ||
677 p_hdr10_mastering->min_display_mastering_luminance >
678 V4L2_HDR10_MASTERING_MIN_LUMA_HIGH)
679 return -EINVAL;
680
681 /* The following restriction comes from ITU-T Rec. H.265 spec */
682 if (p_hdr10_mastering->max_display_mastering_luminance ==
683 V4L2_HDR10_MASTERING_MAX_LUMA_LOW &&
684 p_hdr10_mastering->min_display_mastering_luminance ==
685 V4L2_HDR10_MASTERING_MIN_LUMA_HIGH)
686 return -EINVAL;
687
688 break;
689
690 case V4L2_CTRL_TYPE_HEVC_SCALING_MATRIX:
691 break;
692
693 case V4L2_CTRL_TYPE_AREA:
694 area = p;
695 if (!area->width || !area->height)
696 return -EINVAL;
697 break;
698
699 default:
700 return -EINVAL;
701 }
702
703 return 0;
704 }
705
std_validate(const struct v4l2_ctrl * ctrl,u32 idx,union v4l2_ctrl_ptr ptr)706 static int std_validate(const struct v4l2_ctrl *ctrl, u32 idx,
707 union v4l2_ctrl_ptr ptr)
708 {
709 size_t len;
710 u64 offset;
711 s64 val;
712
713 switch ((u32)ctrl->type) {
714 case V4L2_CTRL_TYPE_INTEGER:
715 return ROUND_TO_RANGE(ptr.p_s32[idx], u32, ctrl);
716 case V4L2_CTRL_TYPE_INTEGER64:
717 /*
718 * We can't use the ROUND_TO_RANGE define here due to
719 * the u64 divide that needs special care.
720 */
721 val = ptr.p_s64[idx];
722 if (ctrl->maximum >= 0 && val >= ctrl->maximum - (s64)(ctrl->step / 2))
723 val = ctrl->maximum;
724 else
725 val += (s64)(ctrl->step / 2);
726 val = clamp_t(s64, val, ctrl->minimum, ctrl->maximum);
727 offset = val - ctrl->minimum;
728 do_div(offset, ctrl->step);
729 ptr.p_s64[idx] = ctrl->minimum + offset * ctrl->step;
730 return 0;
731 case V4L2_CTRL_TYPE_U8:
732 return ROUND_TO_RANGE(ptr.p_u8[idx], u8, ctrl);
733 case V4L2_CTRL_TYPE_U16:
734 return ROUND_TO_RANGE(ptr.p_u16[idx], u16, ctrl);
735 case V4L2_CTRL_TYPE_U32:
736 return ROUND_TO_RANGE(ptr.p_u32[idx], u32, ctrl);
737
738 case V4L2_CTRL_TYPE_BOOLEAN:
739 ptr.p_s32[idx] = !!ptr.p_s32[idx];
740 return 0;
741
742 case V4L2_CTRL_TYPE_MENU:
743 case V4L2_CTRL_TYPE_INTEGER_MENU:
744 if (ptr.p_s32[idx] < ctrl->minimum || ptr.p_s32[idx] > ctrl->maximum)
745 return -ERANGE;
746 if (ptr.p_s32[idx] < BITS_PER_LONG_LONG &&
747 (ctrl->menu_skip_mask & BIT_ULL(ptr.p_s32[idx])))
748 return -EINVAL;
749 if (ctrl->type == V4L2_CTRL_TYPE_MENU &&
750 ctrl->qmenu[ptr.p_s32[idx]][0] == '\0')
751 return -EINVAL;
752 return 0;
753
754 case V4L2_CTRL_TYPE_BITMASK:
755 ptr.p_s32[idx] &= ctrl->maximum;
756 return 0;
757
758 case V4L2_CTRL_TYPE_BUTTON:
759 case V4L2_CTRL_TYPE_CTRL_CLASS:
760 ptr.p_s32[idx] = 0;
761 return 0;
762
763 case V4L2_CTRL_TYPE_STRING:
764 idx *= ctrl->elem_size;
765 len = strlen(ptr.p_char + idx);
766 if (len < ctrl->minimum)
767 return -ERANGE;
768 if ((len - (u32)ctrl->minimum) % (u32)ctrl->step)
769 return -ERANGE;
770 return 0;
771
772 default:
773 return std_validate_compound(ctrl, idx, ptr);
774 }
775 }
776
777 static const struct v4l2_ctrl_type_ops std_type_ops = {
778 .equal = std_equal,
779 .init = std_init,
780 .log = std_log,
781 .validate = std_validate,
782 };
783
v4l2_ctrl_notify(struct v4l2_ctrl * ctrl,v4l2_ctrl_notify_fnc notify,void * priv)784 void v4l2_ctrl_notify(struct v4l2_ctrl *ctrl, v4l2_ctrl_notify_fnc notify, void *priv)
785 {
786 if (!ctrl)
787 return;
788 if (!notify) {
789 ctrl->call_notify = 0;
790 return;
791 }
792 if (WARN_ON(ctrl->handler->notify && ctrl->handler->notify != notify))
793 return;
794 ctrl->handler->notify = notify;
795 ctrl->handler->notify_priv = priv;
796 ctrl->call_notify = 1;
797 }
798 EXPORT_SYMBOL(v4l2_ctrl_notify);
799
800 /* Copy the one value to another. */
ptr_to_ptr(struct v4l2_ctrl * ctrl,union v4l2_ctrl_ptr from,union v4l2_ctrl_ptr to)801 static void ptr_to_ptr(struct v4l2_ctrl *ctrl,
802 union v4l2_ctrl_ptr from, union v4l2_ctrl_ptr to)
803 {
804 if (ctrl == NULL)
805 return;
806 memcpy(to.p, from.p_const, ctrl->elems * ctrl->elem_size);
807 }
808
809 /* Copy the new value to the current value. */
new_to_cur(struct v4l2_fh * fh,struct v4l2_ctrl * ctrl,u32 ch_flags)810 void new_to_cur(struct v4l2_fh *fh, struct v4l2_ctrl *ctrl, u32 ch_flags)
811 {
812 bool changed;
813
814 if (ctrl == NULL)
815 return;
816
817 /* has_changed is set by cluster_changed */
818 changed = ctrl->has_changed;
819 if (changed)
820 ptr_to_ptr(ctrl, ctrl->p_new, ctrl->p_cur);
821
822 if (ch_flags & V4L2_EVENT_CTRL_CH_FLAGS) {
823 /* Note: CH_FLAGS is only set for auto clusters. */
824 ctrl->flags &=
825 ~(V4L2_CTRL_FLAG_INACTIVE | V4L2_CTRL_FLAG_VOLATILE);
826 if (!is_cur_manual(ctrl->cluster[0])) {
827 ctrl->flags |= V4L2_CTRL_FLAG_INACTIVE;
828 if (ctrl->cluster[0]->has_volatiles)
829 ctrl->flags |= V4L2_CTRL_FLAG_VOLATILE;
830 }
831 fh = NULL;
832 }
833 if (changed || ch_flags) {
834 /* If a control was changed that was not one of the controls
835 modified by the application, then send the event to all. */
836 if (!ctrl->is_new)
837 fh = NULL;
838 send_event(fh, ctrl,
839 (changed ? V4L2_EVENT_CTRL_CH_VALUE : 0) | ch_flags);
840 if (ctrl->call_notify && changed && ctrl->handler->notify)
841 ctrl->handler->notify(ctrl, ctrl->handler->notify_priv);
842 }
843 }
844
845 /* Copy the current value to the new value */
cur_to_new(struct v4l2_ctrl * ctrl)846 void cur_to_new(struct v4l2_ctrl *ctrl)
847 {
848 if (ctrl == NULL)
849 return;
850 ptr_to_ptr(ctrl, ctrl->p_cur, ctrl->p_new);
851 }
852
853 /* Copy the new value to the request value */
new_to_req(struct v4l2_ctrl_ref * ref)854 void new_to_req(struct v4l2_ctrl_ref *ref)
855 {
856 if (!ref)
857 return;
858 ptr_to_ptr(ref->ctrl, ref->ctrl->p_new, ref->p_req);
859 ref->valid_p_req = true;
860 }
861
862 /* Copy the current value to the request value */
cur_to_req(struct v4l2_ctrl_ref * ref)863 void cur_to_req(struct v4l2_ctrl_ref *ref)
864 {
865 if (!ref)
866 return;
867 ptr_to_ptr(ref->ctrl, ref->ctrl->p_cur, ref->p_req);
868 ref->valid_p_req = true;
869 }
870
871 /* Copy the request value to the new value */
req_to_new(struct v4l2_ctrl_ref * ref)872 void req_to_new(struct v4l2_ctrl_ref *ref)
873 {
874 if (!ref)
875 return;
876 if (ref->valid_p_req)
877 ptr_to_ptr(ref->ctrl, ref->p_req, ref->ctrl->p_new);
878 else
879 ptr_to_ptr(ref->ctrl, ref->ctrl->p_cur, ref->ctrl->p_new);
880 }
881
882 /* Control range checking */
check_range(enum v4l2_ctrl_type type,s64 min,s64 max,u64 step,s64 def)883 int check_range(enum v4l2_ctrl_type type,
884 s64 min, s64 max, u64 step, s64 def)
885 {
886 switch (type) {
887 case V4L2_CTRL_TYPE_BOOLEAN:
888 if (step != 1 || max > 1 || min < 0)
889 return -ERANGE;
890 fallthrough;
891 case V4L2_CTRL_TYPE_U8:
892 case V4L2_CTRL_TYPE_U16:
893 case V4L2_CTRL_TYPE_U32:
894 case V4L2_CTRL_TYPE_INTEGER:
895 case V4L2_CTRL_TYPE_INTEGER64:
896 if (step == 0 || min > max || def < min || def > max)
897 return -ERANGE;
898 return 0;
899 case V4L2_CTRL_TYPE_BITMASK:
900 if (step || min || !max || (def & ~max))
901 return -ERANGE;
902 return 0;
903 case V4L2_CTRL_TYPE_MENU:
904 case V4L2_CTRL_TYPE_INTEGER_MENU:
905 if (min > max || def < min || def > max)
906 return -ERANGE;
907 /* Note: step == menu_skip_mask for menu controls.
908 So here we check if the default value is masked out. */
909 if (step && ((1 << def) & step))
910 return -EINVAL;
911 return 0;
912 case V4L2_CTRL_TYPE_STRING:
913 if (min > max || min < 0 || step < 1 || def)
914 return -ERANGE;
915 return 0;
916 default:
917 return 0;
918 }
919 }
920
921 /* Validate a new control */
validate_new(const struct v4l2_ctrl * ctrl,union v4l2_ctrl_ptr p_new)922 int validate_new(const struct v4l2_ctrl *ctrl, union v4l2_ctrl_ptr p_new)
923 {
924 unsigned idx;
925 int err = 0;
926
927 for (idx = 0; !err && idx < ctrl->elems; idx++)
928 err = ctrl->type_ops->validate(ctrl, idx, p_new);
929 return err;
930 }
931
932 /* Set the handler's error code if it wasn't set earlier already */
handler_set_err(struct v4l2_ctrl_handler * hdl,int err)933 static inline int handler_set_err(struct v4l2_ctrl_handler *hdl, int err)
934 {
935 if (hdl->error == 0)
936 hdl->error = err;
937 return err;
938 }
939
940 /* Initialize the handler */
v4l2_ctrl_handler_init_class(struct v4l2_ctrl_handler * hdl,unsigned nr_of_controls_hint,struct lock_class_key * key,const char * name)941 int v4l2_ctrl_handler_init_class(struct v4l2_ctrl_handler *hdl,
942 unsigned nr_of_controls_hint,
943 struct lock_class_key *key, const char *name)
944 {
945 mutex_init(&hdl->_lock);
946 hdl->lock = &hdl->_lock;
947 lockdep_set_class_and_name(hdl->lock, key, name);
948 INIT_LIST_HEAD(&hdl->ctrls);
949 INIT_LIST_HEAD(&hdl->ctrl_refs);
950 hdl->nr_of_buckets = 1 + nr_of_controls_hint / 8;
951 hdl->buckets = kvmalloc_array(hdl->nr_of_buckets,
952 sizeof(hdl->buckets[0]),
953 GFP_KERNEL | __GFP_ZERO);
954 hdl->error = hdl->buckets ? 0 : -ENOMEM;
955 v4l2_ctrl_handler_init_request(hdl);
956 return hdl->error;
957 }
958 EXPORT_SYMBOL(v4l2_ctrl_handler_init_class);
959
960 /* Free all controls and control refs */
v4l2_ctrl_handler_free(struct v4l2_ctrl_handler * hdl)961 void v4l2_ctrl_handler_free(struct v4l2_ctrl_handler *hdl)
962 {
963 struct v4l2_ctrl_ref *ref, *next_ref;
964 struct v4l2_ctrl *ctrl, *next_ctrl;
965 struct v4l2_subscribed_event *sev, *next_sev;
966
967 if (hdl == NULL || hdl->buckets == NULL)
968 return;
969
970 v4l2_ctrl_handler_free_request(hdl);
971
972 mutex_lock(hdl->lock);
973 /* Free all nodes */
974 list_for_each_entry_safe(ref, next_ref, &hdl->ctrl_refs, node) {
975 list_del(&ref->node);
976 kfree(ref);
977 }
978 /* Free all controls owned by the handler */
979 list_for_each_entry_safe(ctrl, next_ctrl, &hdl->ctrls, node) {
980 list_del(&ctrl->node);
981 list_for_each_entry_safe(sev, next_sev, &ctrl->ev_subs, node)
982 list_del(&sev->node);
983 kvfree(ctrl);
984 }
985 kvfree(hdl->buckets);
986 hdl->buckets = NULL;
987 hdl->cached = NULL;
988 hdl->error = 0;
989 mutex_unlock(hdl->lock);
990 mutex_destroy(&hdl->_lock);
991 }
992 EXPORT_SYMBOL(v4l2_ctrl_handler_free);
993
994 /* For backwards compatibility: V4L2_CID_PRIVATE_BASE should no longer
995 be used except in G_CTRL, S_CTRL, QUERYCTRL and QUERYMENU when dealing
996 with applications that do not use the NEXT_CTRL flag.
997
998 We just find the n-th private user control. It's O(N), but that should not
999 be an issue in this particular case. */
find_private_ref(struct v4l2_ctrl_handler * hdl,u32 id)1000 static struct v4l2_ctrl_ref *find_private_ref(
1001 struct v4l2_ctrl_handler *hdl, u32 id)
1002 {
1003 struct v4l2_ctrl_ref *ref;
1004
1005 id -= V4L2_CID_PRIVATE_BASE;
1006 list_for_each_entry(ref, &hdl->ctrl_refs, node) {
1007 /* Search for private user controls that are compatible with
1008 VIDIOC_G/S_CTRL. */
1009 if (V4L2_CTRL_ID2WHICH(ref->ctrl->id) == V4L2_CTRL_CLASS_USER &&
1010 V4L2_CTRL_DRIVER_PRIV(ref->ctrl->id)) {
1011 if (!ref->ctrl->is_int)
1012 continue;
1013 if (id == 0)
1014 return ref;
1015 id--;
1016 }
1017 }
1018 return NULL;
1019 }
1020
1021 /* Find a control with the given ID. */
find_ref(struct v4l2_ctrl_handler * hdl,u32 id)1022 struct v4l2_ctrl_ref *find_ref(struct v4l2_ctrl_handler *hdl, u32 id)
1023 {
1024 struct v4l2_ctrl_ref *ref;
1025 int bucket;
1026
1027 id &= V4L2_CTRL_ID_MASK;
1028
1029 /* Old-style private controls need special handling */
1030 if (id >= V4L2_CID_PRIVATE_BASE)
1031 return find_private_ref(hdl, id);
1032 bucket = id % hdl->nr_of_buckets;
1033
1034 /* Simple optimization: cache the last control found */
1035 if (hdl->cached && hdl->cached->ctrl->id == id)
1036 return hdl->cached;
1037
1038 /* Not in cache, search the hash */
1039 ref = hdl->buckets ? hdl->buckets[bucket] : NULL;
1040 while (ref && ref->ctrl->id != id)
1041 ref = ref->next;
1042
1043 if (ref)
1044 hdl->cached = ref; /* cache it! */
1045 return ref;
1046 }
1047
1048 /* Find a control with the given ID. Take the handler's lock first. */
find_ref_lock(struct v4l2_ctrl_handler * hdl,u32 id)1049 struct v4l2_ctrl_ref *find_ref_lock(struct v4l2_ctrl_handler *hdl, u32 id)
1050 {
1051 struct v4l2_ctrl_ref *ref = NULL;
1052
1053 if (hdl) {
1054 mutex_lock(hdl->lock);
1055 ref = find_ref(hdl, id);
1056 mutex_unlock(hdl->lock);
1057 }
1058 return ref;
1059 }
1060
1061 /* Find a control with the given ID. */
v4l2_ctrl_find(struct v4l2_ctrl_handler * hdl,u32 id)1062 struct v4l2_ctrl *v4l2_ctrl_find(struct v4l2_ctrl_handler *hdl, u32 id)
1063 {
1064 struct v4l2_ctrl_ref *ref = find_ref_lock(hdl, id);
1065
1066 return ref ? ref->ctrl : NULL;
1067 }
1068 EXPORT_SYMBOL(v4l2_ctrl_find);
1069
1070 /* Allocate a new v4l2_ctrl_ref and hook it into the handler. */
handler_new_ref(struct v4l2_ctrl_handler * hdl,struct v4l2_ctrl * ctrl,struct v4l2_ctrl_ref ** ctrl_ref,bool from_other_dev,bool allocate_req)1071 int handler_new_ref(struct v4l2_ctrl_handler *hdl,
1072 struct v4l2_ctrl *ctrl,
1073 struct v4l2_ctrl_ref **ctrl_ref,
1074 bool from_other_dev, bool allocate_req)
1075 {
1076 struct v4l2_ctrl_ref *ref;
1077 struct v4l2_ctrl_ref *new_ref;
1078 u32 id = ctrl->id;
1079 u32 class_ctrl = V4L2_CTRL_ID2WHICH(id) | 1;
1080 int bucket = id % hdl->nr_of_buckets; /* which bucket to use */
1081 unsigned int size_extra_req = 0;
1082
1083 if (ctrl_ref)
1084 *ctrl_ref = NULL;
1085
1086 /*
1087 * Automatically add the control class if it is not yet present and
1088 * the new control is not a compound control.
1089 */
1090 if (ctrl->type < V4L2_CTRL_COMPOUND_TYPES &&
1091 id != class_ctrl && find_ref_lock(hdl, class_ctrl) == NULL)
1092 if (!v4l2_ctrl_new_std(hdl, NULL, class_ctrl, 0, 0, 0, 0))
1093 return hdl->error;
1094
1095 if (hdl->error)
1096 return hdl->error;
1097
1098 if (allocate_req)
1099 size_extra_req = ctrl->elems * ctrl->elem_size;
1100 new_ref = kzalloc(sizeof(*new_ref) + size_extra_req, GFP_KERNEL);
1101 if (!new_ref)
1102 return handler_set_err(hdl, -ENOMEM);
1103 new_ref->ctrl = ctrl;
1104 new_ref->from_other_dev = from_other_dev;
1105 if (size_extra_req)
1106 new_ref->p_req.p = &new_ref[1];
1107
1108 INIT_LIST_HEAD(&new_ref->node);
1109
1110 mutex_lock(hdl->lock);
1111
1112 /* Add immediately at the end of the list if the list is empty, or if
1113 the last element in the list has a lower ID.
1114 This ensures that when elements are added in ascending order the
1115 insertion is an O(1) operation. */
1116 if (list_empty(&hdl->ctrl_refs) || id > node2id(hdl->ctrl_refs.prev)) {
1117 list_add_tail(&new_ref->node, &hdl->ctrl_refs);
1118 goto insert_in_hash;
1119 }
1120
1121 /* Find insert position in sorted list */
1122 list_for_each_entry(ref, &hdl->ctrl_refs, node) {
1123 if (ref->ctrl->id < id)
1124 continue;
1125 /* Don't add duplicates */
1126 if (ref->ctrl->id == id) {
1127 kfree(new_ref);
1128 goto unlock;
1129 }
1130 list_add(&new_ref->node, ref->node.prev);
1131 break;
1132 }
1133
1134 insert_in_hash:
1135 /* Insert the control node in the hash */
1136 new_ref->next = hdl->buckets[bucket];
1137 hdl->buckets[bucket] = new_ref;
1138 if (ctrl_ref)
1139 *ctrl_ref = new_ref;
1140 if (ctrl->handler == hdl) {
1141 /* By default each control starts in a cluster of its own.
1142 * new_ref->ctrl is basically a cluster array with one
1143 * element, so that's perfect to use as the cluster pointer.
1144 * But only do this for the handler that owns the control.
1145 */
1146 ctrl->cluster = &new_ref->ctrl;
1147 ctrl->ncontrols = 1;
1148 }
1149
1150 unlock:
1151 mutex_unlock(hdl->lock);
1152 return 0;
1153 }
1154
1155 /* Add a new control */
v4l2_ctrl_new(struct v4l2_ctrl_handler * hdl,const struct v4l2_ctrl_ops * ops,const struct v4l2_ctrl_type_ops * type_ops,u32 id,const char * name,enum v4l2_ctrl_type type,s64 min,s64 max,u64 step,s64 def,const u32 dims[V4L2_CTRL_MAX_DIMS],u32 elem_size,u32 flags,const char * const * qmenu,const s64 * qmenu_int,const union v4l2_ctrl_ptr p_def,void * priv)1156 static struct v4l2_ctrl *v4l2_ctrl_new(struct v4l2_ctrl_handler *hdl,
1157 const struct v4l2_ctrl_ops *ops,
1158 const struct v4l2_ctrl_type_ops *type_ops,
1159 u32 id, const char *name, enum v4l2_ctrl_type type,
1160 s64 min, s64 max, u64 step, s64 def,
1161 const u32 dims[V4L2_CTRL_MAX_DIMS], u32 elem_size,
1162 u32 flags, const char * const *qmenu,
1163 const s64 *qmenu_int, const union v4l2_ctrl_ptr p_def,
1164 void *priv)
1165 {
1166 struct v4l2_ctrl *ctrl;
1167 unsigned sz_extra;
1168 unsigned nr_of_dims = 0;
1169 unsigned elems = 1;
1170 bool is_array;
1171 unsigned tot_ctrl_size;
1172 unsigned idx;
1173 void *data;
1174 int err;
1175
1176 if (hdl->error)
1177 return NULL;
1178
1179 while (dims && dims[nr_of_dims]) {
1180 elems *= dims[nr_of_dims];
1181 nr_of_dims++;
1182 if (nr_of_dims == V4L2_CTRL_MAX_DIMS)
1183 break;
1184 }
1185 is_array = nr_of_dims > 0;
1186
1187 /* Prefill elem_size for all types handled by std_type_ops */
1188 switch ((u32)type) {
1189 case V4L2_CTRL_TYPE_INTEGER64:
1190 elem_size = sizeof(s64);
1191 break;
1192 case V4L2_CTRL_TYPE_STRING:
1193 elem_size = max + 1;
1194 break;
1195 case V4L2_CTRL_TYPE_U8:
1196 elem_size = sizeof(u8);
1197 break;
1198 case V4L2_CTRL_TYPE_U16:
1199 elem_size = sizeof(u16);
1200 break;
1201 case V4L2_CTRL_TYPE_U32:
1202 elem_size = sizeof(u32);
1203 break;
1204 case V4L2_CTRL_TYPE_MPEG2_SEQUENCE:
1205 elem_size = sizeof(struct v4l2_ctrl_mpeg2_sequence);
1206 break;
1207 case V4L2_CTRL_TYPE_MPEG2_PICTURE:
1208 elem_size = sizeof(struct v4l2_ctrl_mpeg2_picture);
1209 break;
1210 case V4L2_CTRL_TYPE_MPEG2_QUANTISATION:
1211 elem_size = sizeof(struct v4l2_ctrl_mpeg2_quantisation);
1212 break;
1213 case V4L2_CTRL_TYPE_FWHT_PARAMS:
1214 elem_size = sizeof(struct v4l2_ctrl_fwht_params);
1215 break;
1216 case V4L2_CTRL_TYPE_H264_SPS:
1217 elem_size = sizeof(struct v4l2_ctrl_h264_sps);
1218 break;
1219 case V4L2_CTRL_TYPE_H264_PPS:
1220 elem_size = sizeof(struct v4l2_ctrl_h264_pps);
1221 break;
1222 case V4L2_CTRL_TYPE_H264_SCALING_MATRIX:
1223 elem_size = sizeof(struct v4l2_ctrl_h264_scaling_matrix);
1224 break;
1225 case V4L2_CTRL_TYPE_H264_SLICE_PARAMS:
1226 elem_size = sizeof(struct v4l2_ctrl_h264_slice_params);
1227 break;
1228 case V4L2_CTRL_TYPE_H264_DECODE_PARAMS:
1229 elem_size = sizeof(struct v4l2_ctrl_h264_decode_params);
1230 break;
1231 case V4L2_CTRL_TYPE_H264_PRED_WEIGHTS:
1232 elem_size = sizeof(struct v4l2_ctrl_h264_pred_weights);
1233 break;
1234 case V4L2_CTRL_TYPE_VP8_FRAME:
1235 elem_size = sizeof(struct v4l2_ctrl_vp8_frame);
1236 break;
1237 case V4L2_CTRL_TYPE_HEVC_SPS:
1238 elem_size = sizeof(struct v4l2_ctrl_hevc_sps);
1239 break;
1240 case V4L2_CTRL_TYPE_HEVC_PPS:
1241 elem_size = sizeof(struct v4l2_ctrl_hevc_pps);
1242 break;
1243 case V4L2_CTRL_TYPE_HEVC_SLICE_PARAMS:
1244 elem_size = sizeof(struct v4l2_ctrl_hevc_slice_params);
1245 break;
1246 case V4L2_CTRL_TYPE_HEVC_SCALING_MATRIX:
1247 elem_size = sizeof(struct v4l2_ctrl_hevc_scaling_matrix);
1248 break;
1249 case V4L2_CTRL_TYPE_HEVC_DECODE_PARAMS:
1250 elem_size = sizeof(struct v4l2_ctrl_hevc_decode_params);
1251 break;
1252 case V4L2_CTRL_TYPE_HDR10_CLL_INFO:
1253 elem_size = sizeof(struct v4l2_ctrl_hdr10_cll_info);
1254 break;
1255 case V4L2_CTRL_TYPE_HDR10_MASTERING_DISPLAY:
1256 elem_size = sizeof(struct v4l2_ctrl_hdr10_mastering_display);
1257 break;
1258 case V4L2_CTRL_TYPE_AREA:
1259 elem_size = sizeof(struct v4l2_area);
1260 break;
1261 default:
1262 if (type < V4L2_CTRL_COMPOUND_TYPES)
1263 elem_size = sizeof(s32);
1264 break;
1265 }
1266 tot_ctrl_size = elem_size * elems;
1267
1268 /* Sanity checks */
1269 if (id == 0 || name == NULL || !elem_size ||
1270 id >= V4L2_CID_PRIVATE_BASE ||
1271 (type == V4L2_CTRL_TYPE_MENU && qmenu == NULL) ||
1272 (type == V4L2_CTRL_TYPE_INTEGER_MENU && qmenu_int == NULL)) {
1273 handler_set_err(hdl, -ERANGE);
1274 return NULL;
1275 }
1276 err = check_range(type, min, max, step, def);
1277 if (err) {
1278 handler_set_err(hdl, err);
1279 return NULL;
1280 }
1281 if (is_array &&
1282 (type == V4L2_CTRL_TYPE_BUTTON ||
1283 type == V4L2_CTRL_TYPE_CTRL_CLASS)) {
1284 handler_set_err(hdl, -EINVAL);
1285 return NULL;
1286 }
1287
1288 sz_extra = 0;
1289 if (type == V4L2_CTRL_TYPE_BUTTON)
1290 flags |= V4L2_CTRL_FLAG_WRITE_ONLY |
1291 V4L2_CTRL_FLAG_EXECUTE_ON_WRITE;
1292 else if (type == V4L2_CTRL_TYPE_CTRL_CLASS)
1293 flags |= V4L2_CTRL_FLAG_READ_ONLY;
1294 else if (type == V4L2_CTRL_TYPE_INTEGER64 ||
1295 type == V4L2_CTRL_TYPE_STRING ||
1296 type >= V4L2_CTRL_COMPOUND_TYPES ||
1297 is_array)
1298 sz_extra += 2 * tot_ctrl_size;
1299
1300 if (type >= V4L2_CTRL_COMPOUND_TYPES && p_def.p_const)
1301 sz_extra += elem_size;
1302
1303 ctrl = kvzalloc(sizeof(*ctrl) + sz_extra, GFP_KERNEL);
1304 if (ctrl == NULL) {
1305 handler_set_err(hdl, -ENOMEM);
1306 return NULL;
1307 }
1308
1309 INIT_LIST_HEAD(&ctrl->node);
1310 INIT_LIST_HEAD(&ctrl->ev_subs);
1311 ctrl->handler = hdl;
1312 ctrl->ops = ops;
1313 ctrl->type_ops = type_ops ? type_ops : &std_type_ops;
1314 ctrl->id = id;
1315 ctrl->name = name;
1316 ctrl->type = type;
1317 ctrl->flags = flags;
1318 ctrl->minimum = min;
1319 ctrl->maximum = max;
1320 ctrl->step = step;
1321 ctrl->default_value = def;
1322 ctrl->is_string = !is_array && type == V4L2_CTRL_TYPE_STRING;
1323 ctrl->is_ptr = is_array || type >= V4L2_CTRL_COMPOUND_TYPES || ctrl->is_string;
1324 ctrl->is_int = !ctrl->is_ptr && type != V4L2_CTRL_TYPE_INTEGER64;
1325 ctrl->is_array = is_array;
1326 ctrl->elems = elems;
1327 ctrl->nr_of_dims = nr_of_dims;
1328 if (nr_of_dims)
1329 memcpy(ctrl->dims, dims, nr_of_dims * sizeof(dims[0]));
1330 ctrl->elem_size = elem_size;
1331 if (type == V4L2_CTRL_TYPE_MENU)
1332 ctrl->qmenu = qmenu;
1333 else if (type == V4L2_CTRL_TYPE_INTEGER_MENU)
1334 ctrl->qmenu_int = qmenu_int;
1335 ctrl->priv = priv;
1336 ctrl->cur.val = ctrl->val = def;
1337 data = &ctrl[1];
1338
1339 if (!ctrl->is_int) {
1340 ctrl->p_new.p = data;
1341 ctrl->p_cur.p = data + tot_ctrl_size;
1342 } else {
1343 ctrl->p_new.p = &ctrl->val;
1344 ctrl->p_cur.p = &ctrl->cur.val;
1345 }
1346
1347 if (type >= V4L2_CTRL_COMPOUND_TYPES && p_def.p_const) {
1348 ctrl->p_def.p = ctrl->p_cur.p + tot_ctrl_size;
1349 memcpy(ctrl->p_def.p, p_def.p_const, elem_size);
1350 }
1351
1352 for (idx = 0; idx < elems; idx++) {
1353 ctrl->type_ops->init(ctrl, idx, ctrl->p_cur);
1354 ctrl->type_ops->init(ctrl, idx, ctrl->p_new);
1355 }
1356
1357 if (handler_new_ref(hdl, ctrl, NULL, false, false)) {
1358 kvfree(ctrl);
1359 return NULL;
1360 }
1361 mutex_lock(hdl->lock);
1362 list_add_tail(&ctrl->node, &hdl->ctrls);
1363 mutex_unlock(hdl->lock);
1364 return ctrl;
1365 }
1366
v4l2_ctrl_new_custom(struct v4l2_ctrl_handler * hdl,const struct v4l2_ctrl_config * cfg,void * priv)1367 struct v4l2_ctrl *v4l2_ctrl_new_custom(struct v4l2_ctrl_handler *hdl,
1368 const struct v4l2_ctrl_config *cfg, void *priv)
1369 {
1370 bool is_menu;
1371 struct v4l2_ctrl *ctrl;
1372 const char *name = cfg->name;
1373 const char * const *qmenu = cfg->qmenu;
1374 const s64 *qmenu_int = cfg->qmenu_int;
1375 enum v4l2_ctrl_type type = cfg->type;
1376 u32 flags = cfg->flags;
1377 s64 min = cfg->min;
1378 s64 max = cfg->max;
1379 u64 step = cfg->step;
1380 s64 def = cfg->def;
1381
1382 if (name == NULL)
1383 v4l2_ctrl_fill(cfg->id, &name, &type, &min, &max, &step,
1384 &def, &flags);
1385
1386 is_menu = (type == V4L2_CTRL_TYPE_MENU ||
1387 type == V4L2_CTRL_TYPE_INTEGER_MENU);
1388 if (is_menu)
1389 WARN_ON(step);
1390 else
1391 WARN_ON(cfg->menu_skip_mask);
1392 if (type == V4L2_CTRL_TYPE_MENU && !qmenu) {
1393 qmenu = v4l2_ctrl_get_menu(cfg->id);
1394 } else if (type == V4L2_CTRL_TYPE_INTEGER_MENU && !qmenu_int) {
1395 handler_set_err(hdl, -EINVAL);
1396 return NULL;
1397 }
1398
1399 ctrl = v4l2_ctrl_new(hdl, cfg->ops, cfg->type_ops, cfg->id, name,
1400 type, min, max,
1401 is_menu ? cfg->menu_skip_mask : step, def,
1402 cfg->dims, cfg->elem_size,
1403 flags, qmenu, qmenu_int, cfg->p_def, priv);
1404 if (ctrl)
1405 ctrl->is_private = cfg->is_private;
1406 return ctrl;
1407 }
1408 EXPORT_SYMBOL(v4l2_ctrl_new_custom);
1409
1410 /* Helper function for standard non-menu controls */
v4l2_ctrl_new_std(struct v4l2_ctrl_handler * hdl,const struct v4l2_ctrl_ops * ops,u32 id,s64 min,s64 max,u64 step,s64 def)1411 struct v4l2_ctrl *v4l2_ctrl_new_std(struct v4l2_ctrl_handler *hdl,
1412 const struct v4l2_ctrl_ops *ops,
1413 u32 id, s64 min, s64 max, u64 step, s64 def)
1414 {
1415 const char *name;
1416 enum v4l2_ctrl_type type;
1417 u32 flags;
1418
1419 v4l2_ctrl_fill(id, &name, &type, &min, &max, &step, &def, &flags);
1420 if (type == V4L2_CTRL_TYPE_MENU ||
1421 type == V4L2_CTRL_TYPE_INTEGER_MENU ||
1422 type >= V4L2_CTRL_COMPOUND_TYPES) {
1423 handler_set_err(hdl, -EINVAL);
1424 return NULL;
1425 }
1426 return v4l2_ctrl_new(hdl, ops, NULL, id, name, type,
1427 min, max, step, def, NULL, 0,
1428 flags, NULL, NULL, ptr_null, NULL);
1429 }
1430 EXPORT_SYMBOL(v4l2_ctrl_new_std);
1431
1432 /* Helper function for standard menu controls */
v4l2_ctrl_new_std_menu(struct v4l2_ctrl_handler * hdl,const struct v4l2_ctrl_ops * ops,u32 id,u8 _max,u64 mask,u8 _def)1433 struct v4l2_ctrl *v4l2_ctrl_new_std_menu(struct v4l2_ctrl_handler *hdl,
1434 const struct v4l2_ctrl_ops *ops,
1435 u32 id, u8 _max, u64 mask, u8 _def)
1436 {
1437 const char * const *qmenu = NULL;
1438 const s64 *qmenu_int = NULL;
1439 unsigned int qmenu_int_len = 0;
1440 const char *name;
1441 enum v4l2_ctrl_type type;
1442 s64 min;
1443 s64 max = _max;
1444 s64 def = _def;
1445 u64 step;
1446 u32 flags;
1447
1448 v4l2_ctrl_fill(id, &name, &type, &min, &max, &step, &def, &flags);
1449
1450 if (type == V4L2_CTRL_TYPE_MENU)
1451 qmenu = v4l2_ctrl_get_menu(id);
1452 else if (type == V4L2_CTRL_TYPE_INTEGER_MENU)
1453 qmenu_int = v4l2_ctrl_get_int_menu(id, &qmenu_int_len);
1454
1455 if ((!qmenu && !qmenu_int) || (qmenu_int && max > qmenu_int_len)) {
1456 handler_set_err(hdl, -EINVAL);
1457 return NULL;
1458 }
1459 return v4l2_ctrl_new(hdl, ops, NULL, id, name, type,
1460 0, max, mask, def, NULL, 0,
1461 flags, qmenu, qmenu_int, ptr_null, NULL);
1462 }
1463 EXPORT_SYMBOL(v4l2_ctrl_new_std_menu);
1464
1465 /* Helper function for standard menu controls with driver defined menu */
v4l2_ctrl_new_std_menu_items(struct v4l2_ctrl_handler * hdl,const struct v4l2_ctrl_ops * ops,u32 id,u8 _max,u64 mask,u8 _def,const char * const * qmenu)1466 struct v4l2_ctrl *v4l2_ctrl_new_std_menu_items(struct v4l2_ctrl_handler *hdl,
1467 const struct v4l2_ctrl_ops *ops, u32 id, u8 _max,
1468 u64 mask, u8 _def, const char * const *qmenu)
1469 {
1470 enum v4l2_ctrl_type type;
1471 const char *name;
1472 u32 flags;
1473 u64 step;
1474 s64 min;
1475 s64 max = _max;
1476 s64 def = _def;
1477
1478 /* v4l2_ctrl_new_std_menu_items() should only be called for
1479 * standard controls without a standard menu.
1480 */
1481 if (v4l2_ctrl_get_menu(id)) {
1482 handler_set_err(hdl, -EINVAL);
1483 return NULL;
1484 }
1485
1486 v4l2_ctrl_fill(id, &name, &type, &min, &max, &step, &def, &flags);
1487 if (type != V4L2_CTRL_TYPE_MENU || qmenu == NULL) {
1488 handler_set_err(hdl, -EINVAL);
1489 return NULL;
1490 }
1491 return v4l2_ctrl_new(hdl, ops, NULL, id, name, type,
1492 0, max, mask, def, NULL, 0,
1493 flags, qmenu, NULL, ptr_null, NULL);
1494
1495 }
1496 EXPORT_SYMBOL(v4l2_ctrl_new_std_menu_items);
1497
1498 /* Helper function for standard compound controls */
v4l2_ctrl_new_std_compound(struct v4l2_ctrl_handler * hdl,const struct v4l2_ctrl_ops * ops,u32 id,const union v4l2_ctrl_ptr p_def)1499 struct v4l2_ctrl *v4l2_ctrl_new_std_compound(struct v4l2_ctrl_handler *hdl,
1500 const struct v4l2_ctrl_ops *ops, u32 id,
1501 const union v4l2_ctrl_ptr p_def)
1502 {
1503 const char *name;
1504 enum v4l2_ctrl_type type;
1505 u32 flags;
1506 s64 min, max, step, def;
1507
1508 v4l2_ctrl_fill(id, &name, &type, &min, &max, &step, &def, &flags);
1509 if (type < V4L2_CTRL_COMPOUND_TYPES) {
1510 handler_set_err(hdl, -EINVAL);
1511 return NULL;
1512 }
1513 return v4l2_ctrl_new(hdl, ops, NULL, id, name, type,
1514 min, max, step, def, NULL, 0,
1515 flags, NULL, NULL, p_def, NULL);
1516 }
1517 EXPORT_SYMBOL(v4l2_ctrl_new_std_compound);
1518
1519 /* Helper function for standard integer menu controls */
v4l2_ctrl_new_int_menu(struct v4l2_ctrl_handler * hdl,const struct v4l2_ctrl_ops * ops,u32 id,u8 _max,u8 _def,const s64 * qmenu_int)1520 struct v4l2_ctrl *v4l2_ctrl_new_int_menu(struct v4l2_ctrl_handler *hdl,
1521 const struct v4l2_ctrl_ops *ops,
1522 u32 id, u8 _max, u8 _def, const s64 *qmenu_int)
1523 {
1524 const char *name;
1525 enum v4l2_ctrl_type type;
1526 s64 min;
1527 u64 step;
1528 s64 max = _max;
1529 s64 def = _def;
1530 u32 flags;
1531
1532 v4l2_ctrl_fill(id, &name, &type, &min, &max, &step, &def, &flags);
1533 if (type != V4L2_CTRL_TYPE_INTEGER_MENU) {
1534 handler_set_err(hdl, -EINVAL);
1535 return NULL;
1536 }
1537 return v4l2_ctrl_new(hdl, ops, NULL, id, name, type,
1538 0, max, 0, def, NULL, 0,
1539 flags, NULL, qmenu_int, ptr_null, NULL);
1540 }
1541 EXPORT_SYMBOL(v4l2_ctrl_new_int_menu);
1542
1543 /* Add the controls from another handler to our own. */
v4l2_ctrl_add_handler(struct v4l2_ctrl_handler * hdl,struct v4l2_ctrl_handler * add,bool (* filter)(const struct v4l2_ctrl * ctrl),bool from_other_dev)1544 int v4l2_ctrl_add_handler(struct v4l2_ctrl_handler *hdl,
1545 struct v4l2_ctrl_handler *add,
1546 bool (*filter)(const struct v4l2_ctrl *ctrl),
1547 bool from_other_dev)
1548 {
1549 struct v4l2_ctrl_ref *ref;
1550 int ret = 0;
1551
1552 /* Do nothing if either handler is NULL or if they are the same */
1553 if (!hdl || !add || hdl == add)
1554 return 0;
1555 if (hdl->error)
1556 return hdl->error;
1557 mutex_lock(add->lock);
1558 list_for_each_entry(ref, &add->ctrl_refs, node) {
1559 struct v4l2_ctrl *ctrl = ref->ctrl;
1560
1561 /* Skip handler-private controls. */
1562 if (ctrl->is_private)
1563 continue;
1564 /* And control classes */
1565 if (ctrl->type == V4L2_CTRL_TYPE_CTRL_CLASS)
1566 continue;
1567 /* Filter any unwanted controls */
1568 if (filter && !filter(ctrl))
1569 continue;
1570 ret = handler_new_ref(hdl, ctrl, NULL, from_other_dev, false);
1571 if (ret)
1572 break;
1573 }
1574 mutex_unlock(add->lock);
1575 return ret;
1576 }
1577 EXPORT_SYMBOL(v4l2_ctrl_add_handler);
1578
v4l2_ctrl_radio_filter(const struct v4l2_ctrl * ctrl)1579 bool v4l2_ctrl_radio_filter(const struct v4l2_ctrl *ctrl)
1580 {
1581 if (V4L2_CTRL_ID2WHICH(ctrl->id) == V4L2_CTRL_CLASS_FM_TX)
1582 return true;
1583 if (V4L2_CTRL_ID2WHICH(ctrl->id) == V4L2_CTRL_CLASS_FM_RX)
1584 return true;
1585 switch (ctrl->id) {
1586 case V4L2_CID_AUDIO_MUTE:
1587 case V4L2_CID_AUDIO_VOLUME:
1588 case V4L2_CID_AUDIO_BALANCE:
1589 case V4L2_CID_AUDIO_BASS:
1590 case V4L2_CID_AUDIO_TREBLE:
1591 case V4L2_CID_AUDIO_LOUDNESS:
1592 return true;
1593 default:
1594 break;
1595 }
1596 return false;
1597 }
1598 EXPORT_SYMBOL(v4l2_ctrl_radio_filter);
1599
1600 /* Cluster controls */
v4l2_ctrl_cluster(unsigned ncontrols,struct v4l2_ctrl ** controls)1601 void v4l2_ctrl_cluster(unsigned ncontrols, struct v4l2_ctrl **controls)
1602 {
1603 bool has_volatiles = false;
1604 int i;
1605
1606 /* The first control is the master control and it must not be NULL */
1607 if (WARN_ON(ncontrols == 0 || controls[0] == NULL))
1608 return;
1609
1610 for (i = 0; i < ncontrols; i++) {
1611 if (controls[i]) {
1612 controls[i]->cluster = controls;
1613 controls[i]->ncontrols = ncontrols;
1614 if (controls[i]->flags & V4L2_CTRL_FLAG_VOLATILE)
1615 has_volatiles = true;
1616 }
1617 }
1618 controls[0]->has_volatiles = has_volatiles;
1619 }
1620 EXPORT_SYMBOL(v4l2_ctrl_cluster);
1621
v4l2_ctrl_auto_cluster(unsigned ncontrols,struct v4l2_ctrl ** controls,u8 manual_val,bool set_volatile)1622 void v4l2_ctrl_auto_cluster(unsigned ncontrols, struct v4l2_ctrl **controls,
1623 u8 manual_val, bool set_volatile)
1624 {
1625 struct v4l2_ctrl *master = controls[0];
1626 u32 flag = 0;
1627 int i;
1628
1629 v4l2_ctrl_cluster(ncontrols, controls);
1630 WARN_ON(ncontrols <= 1);
1631 WARN_ON(manual_val < master->minimum || manual_val > master->maximum);
1632 WARN_ON(set_volatile && !has_op(master, g_volatile_ctrl));
1633 master->is_auto = true;
1634 master->has_volatiles = set_volatile;
1635 master->manual_mode_value = manual_val;
1636 master->flags |= V4L2_CTRL_FLAG_UPDATE;
1637
1638 if (!is_cur_manual(master))
1639 flag = V4L2_CTRL_FLAG_INACTIVE |
1640 (set_volatile ? V4L2_CTRL_FLAG_VOLATILE : 0);
1641
1642 for (i = 1; i < ncontrols; i++)
1643 if (controls[i])
1644 controls[i]->flags |= flag;
1645 }
1646 EXPORT_SYMBOL(v4l2_ctrl_auto_cluster);
1647
1648 /*
1649 * Obtain the current volatile values of an autocluster and mark them
1650 * as new.
1651 */
update_from_auto_cluster(struct v4l2_ctrl * master)1652 void update_from_auto_cluster(struct v4l2_ctrl *master)
1653 {
1654 int i;
1655
1656 for (i = 1; i < master->ncontrols; i++)
1657 cur_to_new(master->cluster[i]);
1658 if (!call_op(master, g_volatile_ctrl))
1659 for (i = 1; i < master->ncontrols; i++)
1660 if (master->cluster[i])
1661 master->cluster[i]->is_new = 1;
1662 }
1663
1664 /*
1665 * Return non-zero if one or more of the controls in the cluster has a new
1666 * value that differs from the current value.
1667 */
cluster_changed(struct v4l2_ctrl * master)1668 static int cluster_changed(struct v4l2_ctrl *master)
1669 {
1670 bool changed = false;
1671 unsigned int idx;
1672 int i;
1673
1674 for (i = 0; i < master->ncontrols; i++) {
1675 struct v4l2_ctrl *ctrl = master->cluster[i];
1676 bool ctrl_changed = false;
1677
1678 if (!ctrl)
1679 continue;
1680
1681 if (ctrl->flags & V4L2_CTRL_FLAG_EXECUTE_ON_WRITE) {
1682 changed = true;
1683 ctrl_changed = true;
1684 }
1685
1686 /*
1687 * Set has_changed to false to avoid generating
1688 * the event V4L2_EVENT_CTRL_CH_VALUE
1689 */
1690 if (ctrl->flags & V4L2_CTRL_FLAG_VOLATILE) {
1691 ctrl->has_changed = false;
1692 continue;
1693 }
1694
1695 for (idx = 0; !ctrl_changed && idx < ctrl->elems; idx++)
1696 ctrl_changed = !ctrl->type_ops->equal(ctrl, idx,
1697 ctrl->p_cur, ctrl->p_new);
1698 ctrl->has_changed = ctrl_changed;
1699 changed |= ctrl->has_changed;
1700 }
1701 return changed;
1702 }
1703
1704 /*
1705 * Core function that calls try/s_ctrl and ensures that the new value is
1706 * copied to the current value on a set.
1707 * Must be called with ctrl->handler->lock held.
1708 */
try_or_set_cluster(struct v4l2_fh * fh,struct v4l2_ctrl * master,bool set,u32 ch_flags)1709 int try_or_set_cluster(struct v4l2_fh *fh, struct v4l2_ctrl *master,
1710 bool set, u32 ch_flags)
1711 {
1712 bool update_flag;
1713 int ret;
1714 int i;
1715
1716 /*
1717 * Go through the cluster and either validate the new value or
1718 * (if no new value was set), copy the current value to the new
1719 * value, ensuring a consistent view for the control ops when
1720 * called.
1721 */
1722 for (i = 0; i < master->ncontrols; i++) {
1723 struct v4l2_ctrl *ctrl = master->cluster[i];
1724
1725 if (!ctrl)
1726 continue;
1727
1728 if (!ctrl->is_new) {
1729 cur_to_new(ctrl);
1730 continue;
1731 }
1732 /*
1733 * Check again: it may have changed since the
1734 * previous check in try_or_set_ext_ctrls().
1735 */
1736 if (set && (ctrl->flags & V4L2_CTRL_FLAG_GRABBED))
1737 return -EBUSY;
1738 }
1739
1740 ret = call_op(master, try_ctrl);
1741
1742 /* Don't set if there is no change */
1743 if (ret || !set || !cluster_changed(master))
1744 return ret;
1745 ret = call_op(master, s_ctrl);
1746 if (ret)
1747 return ret;
1748
1749 /* If OK, then make the new values permanent. */
1750 update_flag = is_cur_manual(master) != is_new_manual(master);
1751
1752 for (i = 0; i < master->ncontrols; i++) {
1753 /*
1754 * If we switch from auto to manual mode, and this cluster
1755 * contains volatile controls, then all non-master controls
1756 * have to be marked as changed. The 'new' value contains
1757 * the volatile value (obtained by update_from_auto_cluster),
1758 * which now has to become the current value.
1759 */
1760 if (i && update_flag && is_new_manual(master) &&
1761 master->has_volatiles && master->cluster[i])
1762 master->cluster[i]->has_changed = true;
1763
1764 new_to_cur(fh, master->cluster[i], ch_flags |
1765 ((update_flag && i > 0) ? V4L2_EVENT_CTRL_CH_FLAGS : 0));
1766 }
1767 return 0;
1768 }
1769
1770 /* Activate/deactivate a control. */
v4l2_ctrl_activate(struct v4l2_ctrl * ctrl,bool active)1771 void v4l2_ctrl_activate(struct v4l2_ctrl *ctrl, bool active)
1772 {
1773 /* invert since the actual flag is called 'inactive' */
1774 bool inactive = !active;
1775 bool old;
1776
1777 if (ctrl == NULL)
1778 return;
1779
1780 if (inactive)
1781 /* set V4L2_CTRL_FLAG_INACTIVE */
1782 old = test_and_set_bit(4, &ctrl->flags);
1783 else
1784 /* clear V4L2_CTRL_FLAG_INACTIVE */
1785 old = test_and_clear_bit(4, &ctrl->flags);
1786 if (old != inactive)
1787 send_event(NULL, ctrl, V4L2_EVENT_CTRL_CH_FLAGS);
1788 }
1789 EXPORT_SYMBOL(v4l2_ctrl_activate);
1790
__v4l2_ctrl_grab(struct v4l2_ctrl * ctrl,bool grabbed)1791 void __v4l2_ctrl_grab(struct v4l2_ctrl *ctrl, bool grabbed)
1792 {
1793 bool old;
1794
1795 if (ctrl == NULL)
1796 return;
1797
1798 lockdep_assert_held(ctrl->handler->lock);
1799
1800 if (grabbed)
1801 /* set V4L2_CTRL_FLAG_GRABBED */
1802 old = test_and_set_bit(1, &ctrl->flags);
1803 else
1804 /* clear V4L2_CTRL_FLAG_GRABBED */
1805 old = test_and_clear_bit(1, &ctrl->flags);
1806 if (old != grabbed)
1807 send_event(NULL, ctrl, V4L2_EVENT_CTRL_CH_FLAGS);
1808 }
1809 EXPORT_SYMBOL(__v4l2_ctrl_grab);
1810
1811 /* Call s_ctrl for all controls owned by the handler */
__v4l2_ctrl_handler_setup(struct v4l2_ctrl_handler * hdl)1812 int __v4l2_ctrl_handler_setup(struct v4l2_ctrl_handler *hdl)
1813 {
1814 struct v4l2_ctrl *ctrl;
1815 int ret = 0;
1816
1817 if (hdl == NULL)
1818 return 0;
1819
1820 lockdep_assert_held(hdl->lock);
1821
1822 list_for_each_entry(ctrl, &hdl->ctrls, node)
1823 ctrl->done = false;
1824
1825 list_for_each_entry(ctrl, &hdl->ctrls, node) {
1826 struct v4l2_ctrl *master = ctrl->cluster[0];
1827 int i;
1828
1829 /* Skip if this control was already handled by a cluster. */
1830 /* Skip button controls and read-only controls. */
1831 if (ctrl->done || ctrl->type == V4L2_CTRL_TYPE_BUTTON ||
1832 (ctrl->flags & V4L2_CTRL_FLAG_READ_ONLY))
1833 continue;
1834
1835 for (i = 0; i < master->ncontrols; i++) {
1836 if (master->cluster[i]) {
1837 cur_to_new(master->cluster[i]);
1838 master->cluster[i]->is_new = 1;
1839 master->cluster[i]->done = true;
1840 }
1841 }
1842 ret = call_op(master, s_ctrl);
1843 if (ret)
1844 break;
1845 }
1846
1847 return ret;
1848 }
1849 EXPORT_SYMBOL_GPL(__v4l2_ctrl_handler_setup);
1850
v4l2_ctrl_handler_setup(struct v4l2_ctrl_handler * hdl)1851 int v4l2_ctrl_handler_setup(struct v4l2_ctrl_handler *hdl)
1852 {
1853 int ret;
1854
1855 if (hdl == NULL)
1856 return 0;
1857
1858 mutex_lock(hdl->lock);
1859 ret = __v4l2_ctrl_handler_setup(hdl);
1860 mutex_unlock(hdl->lock);
1861
1862 return ret;
1863 }
1864 EXPORT_SYMBOL(v4l2_ctrl_handler_setup);
1865
1866 /* Log the control name and value */
log_ctrl(const struct v4l2_ctrl * ctrl,const char * prefix,const char * colon)1867 static void log_ctrl(const struct v4l2_ctrl *ctrl,
1868 const char *prefix, const char *colon)
1869 {
1870 if (ctrl->flags & (V4L2_CTRL_FLAG_DISABLED | V4L2_CTRL_FLAG_WRITE_ONLY))
1871 return;
1872 if (ctrl->type == V4L2_CTRL_TYPE_CTRL_CLASS)
1873 return;
1874
1875 pr_info("%s%s%s: ", prefix, colon, ctrl->name);
1876
1877 ctrl->type_ops->log(ctrl);
1878
1879 if (ctrl->flags & (V4L2_CTRL_FLAG_INACTIVE |
1880 V4L2_CTRL_FLAG_GRABBED |
1881 V4L2_CTRL_FLAG_VOLATILE)) {
1882 if (ctrl->flags & V4L2_CTRL_FLAG_INACTIVE)
1883 pr_cont(" inactive");
1884 if (ctrl->flags & V4L2_CTRL_FLAG_GRABBED)
1885 pr_cont(" grabbed");
1886 if (ctrl->flags & V4L2_CTRL_FLAG_VOLATILE)
1887 pr_cont(" volatile");
1888 }
1889 pr_cont("\n");
1890 }
1891
1892 /* Log all controls owned by the handler */
v4l2_ctrl_handler_log_status(struct v4l2_ctrl_handler * hdl,const char * prefix)1893 void v4l2_ctrl_handler_log_status(struct v4l2_ctrl_handler *hdl,
1894 const char *prefix)
1895 {
1896 struct v4l2_ctrl *ctrl;
1897 const char *colon = "";
1898 int len;
1899
1900 if (!hdl)
1901 return;
1902 if (!prefix)
1903 prefix = "";
1904 len = strlen(prefix);
1905 if (len && prefix[len - 1] != ' ')
1906 colon = ": ";
1907 mutex_lock(hdl->lock);
1908 list_for_each_entry(ctrl, &hdl->ctrls, node)
1909 if (!(ctrl->flags & V4L2_CTRL_FLAG_DISABLED))
1910 log_ctrl(ctrl, prefix, colon);
1911 mutex_unlock(hdl->lock);
1912 }
1913 EXPORT_SYMBOL(v4l2_ctrl_handler_log_status);
1914
v4l2_ctrl_new_fwnode_properties(struct v4l2_ctrl_handler * hdl,const struct v4l2_ctrl_ops * ctrl_ops,const struct v4l2_fwnode_device_properties * p)1915 int v4l2_ctrl_new_fwnode_properties(struct v4l2_ctrl_handler *hdl,
1916 const struct v4l2_ctrl_ops *ctrl_ops,
1917 const struct v4l2_fwnode_device_properties *p)
1918 {
1919 if (p->orientation != V4L2_FWNODE_PROPERTY_UNSET) {
1920 u32 orientation_ctrl;
1921
1922 switch (p->orientation) {
1923 case V4L2_FWNODE_ORIENTATION_FRONT:
1924 orientation_ctrl = V4L2_CAMERA_ORIENTATION_FRONT;
1925 break;
1926 case V4L2_FWNODE_ORIENTATION_BACK:
1927 orientation_ctrl = V4L2_CAMERA_ORIENTATION_BACK;
1928 break;
1929 case V4L2_FWNODE_ORIENTATION_EXTERNAL:
1930 orientation_ctrl = V4L2_CAMERA_ORIENTATION_EXTERNAL;
1931 break;
1932 default:
1933 return -EINVAL;
1934 }
1935 if (!v4l2_ctrl_new_std_menu(hdl, ctrl_ops,
1936 V4L2_CID_CAMERA_ORIENTATION,
1937 V4L2_CAMERA_ORIENTATION_EXTERNAL, 0,
1938 orientation_ctrl))
1939 return hdl->error;
1940 }
1941
1942 if (p->rotation != V4L2_FWNODE_PROPERTY_UNSET) {
1943 if (!v4l2_ctrl_new_std(hdl, ctrl_ops,
1944 V4L2_CID_CAMERA_SENSOR_ROTATION,
1945 p->rotation, p->rotation, 1,
1946 p->rotation))
1947 return hdl->error;
1948 }
1949
1950 return hdl->error;
1951 }
1952 EXPORT_SYMBOL(v4l2_ctrl_new_fwnode_properties);
1953