2 * vivid-core.h - core datastructures
4 * Copyright 2014 Cisco Systems, Inc. and/or its affiliates. All rights reserved.
6 * This program is free software; you may redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; version 2 of the License.
10 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
11 * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
12 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
13 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS
14 * BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN
15 * ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
16 * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
20 #ifndef _VIVID_CORE_H_
21 #define _VIVID_CORE_H_
24 #include <media/videobuf2-v4l2.h>
25 #include <media/v4l2-device.h>
26 #include <media/v4l2-dev.h>
27 #include <media/v4l2-ctrls.h>
28 #include "vivid-tpg.h"
29 #include "vivid-rds-gen.h"
30 #include "vivid-vbi-gen.h"
32 #define dprintk(dev, level, fmt, arg...) \
33 v4l2_dbg(level, vivid_debug, &dev->v4l2_dev, fmt, ## arg)
35 /* Maximum allowed frame rate
37 * vivid will allow setting timeperframe in [1/FPS_MAX - FPS_MAX/1] range.
39 * Ideally FPS_MAX should be infinity, i.e. practically UINT_MAX, but that
40 * might hit application errors when they manipulate these values.
42 * Besides, for tpf < 10ms image-generation logic should be changed, to avoid
43 * producing frames with equal content.
47 /* The maximum number of clip rectangles */
49 /* The maximum number of inputs */
51 /* The maximum number of outputs */
52 #define MAX_OUTPUTS 16
53 /* The maximum up or down scaling factor is 4 */
55 /* The maximum image width/height are set to 4K DMT */
56 #define MAX_WIDTH 4096
57 #define MAX_HEIGHT 2160
58 /* The minimum image width/height */
61 /* The data_offset of plane 0 for the multiplanar formats */
62 #define PLANE0_DATA_OFFSET 128
64 /* The supported TV frequency range in MHz */
65 #define MIN_TV_FREQ (44U * 16U)
66 #define MAX_TV_FREQ (958U * 16U)
68 /* The number of samples returned in every SDR buffer */
69 #define SDR_CAP_SAMPLES_PER_BUF 0x4000
71 /* used by the threads to know when to resync internal counters */
72 #define JIFFIES_PER_DAY (3600U * 24U * HZ)
73 #define JIFFIES_RESYNC (JIFFIES_PER_DAY * (0xf0000000U / JIFFIES_PER_DAY))
75 extern const struct v4l2_rect vivid_min_rect
;
76 extern const struct v4l2_rect vivid_max_rect
;
77 extern unsigned vivid_debug
;
80 u32 fourcc
; /* v4l2 format id */
83 u8 vdownsampling
[TPG_MAX_PLANES
];
87 u32 data_offset
[TPG_MAX_PLANES
];
88 u32 bit_depth
[TPG_MAX_PLANES
];
91 extern struct vivid_fmt vivid_formats
[];
93 /* buffer for one video frame */
95 /* common v4l buffer stuff -- must be first */
96 struct vb2_v4l2_buffer vb
;
97 struct list_head list
;
107 enum vivid_signal_mode
{
109 CURRENT_STD
= CURRENT_DV_TIMINGS
,
114 SELECTED_STD
= SELECTED_DV_TIMINGS
,
116 CYCLE_STD
= CYCLE_DV_TIMINGS
,
120 enum vivid_colorspace
{
132 #define VIVID_INVALID_SIGNAL(mode) \
133 ((mode) == NO_SIGNAL || (mode) == NO_LOCK || (mode) == OUT_OF_RANGE)
137 struct v4l2_device v4l2_dev
;
138 struct v4l2_ctrl_handler ctrl_hdl_user_gen
;
139 struct v4l2_ctrl_handler ctrl_hdl_user_vid
;
140 struct v4l2_ctrl_handler ctrl_hdl_user_aud
;
141 struct v4l2_ctrl_handler ctrl_hdl_streaming
;
142 struct v4l2_ctrl_handler ctrl_hdl_sdtv_cap
;
143 struct v4l2_ctrl_handler ctrl_hdl_loop_cap
;
144 struct video_device vid_cap_dev
;
145 struct v4l2_ctrl_handler ctrl_hdl_vid_cap
;
146 struct video_device vid_out_dev
;
147 struct v4l2_ctrl_handler ctrl_hdl_vid_out
;
148 struct video_device vbi_cap_dev
;
149 struct v4l2_ctrl_handler ctrl_hdl_vbi_cap
;
150 struct video_device vbi_out_dev
;
151 struct v4l2_ctrl_handler ctrl_hdl_vbi_out
;
152 struct video_device radio_rx_dev
;
153 struct v4l2_ctrl_handler ctrl_hdl_radio_rx
;
154 struct video_device radio_tx_dev
;
155 struct v4l2_ctrl_handler ctrl_hdl_radio_tx
;
156 struct video_device sdr_cap_dev
;
157 struct v4l2_ctrl_handler ctrl_hdl_sdr_cap
;
170 /* supported features */
173 u8 input_type
[MAX_INPUTS
];
174 u8 input_name_counter
[MAX_INPUTS
];
175 unsigned num_outputs
;
176 u8 output_type
[MAX_OUTPUTS
];
177 u8 output_name_counter
[MAX_OUTPUTS
];
178 bool has_audio_inputs
;
179 bool has_audio_outputs
;
183 bool has_raw_vbi_cap
;
184 bool has_sliced_vbi_cap
;
186 bool has_raw_vbi_out
;
187 bool has_sliced_vbi_out
;
196 struct v4l2_ctrl
*brightness
;
197 struct v4l2_ctrl
*contrast
;
198 struct v4l2_ctrl
*saturation
;
199 struct v4l2_ctrl
*hue
;
201 /* autogain/gain cluster */
202 struct v4l2_ctrl
*autogain
;
203 struct v4l2_ctrl
*gain
;
205 struct v4l2_ctrl
*volume
;
206 struct v4l2_ctrl
*mute
;
207 struct v4l2_ctrl
*alpha
;
208 struct v4l2_ctrl
*button
;
209 struct v4l2_ctrl
*boolean
;
210 struct v4l2_ctrl
*int32
;
211 struct v4l2_ctrl
*int64
;
212 struct v4l2_ctrl
*menu
;
213 struct v4l2_ctrl
*string
;
214 struct v4l2_ctrl
*bitmask
;
215 struct v4l2_ctrl
*int_menu
;
216 struct v4l2_ctrl
*test_pattern
;
217 struct v4l2_ctrl
*colorspace
;
218 struct v4l2_ctrl
*rgb_range_cap
;
219 struct v4l2_ctrl
*real_rgb_range_cap
;
221 /* std_signal_mode/standard cluster */
222 struct v4l2_ctrl
*ctrl_std_signal_mode
;
223 struct v4l2_ctrl
*ctrl_standard
;
226 /* dv_timings_signal_mode/timings cluster */
227 struct v4l2_ctrl
*ctrl_dv_timings_signal_mode
;
228 struct v4l2_ctrl
*ctrl_dv_timings
;
230 struct v4l2_ctrl
*ctrl_has_crop_cap
;
231 struct v4l2_ctrl
*ctrl_has_compose_cap
;
232 struct v4l2_ctrl
*ctrl_has_scaler_cap
;
233 struct v4l2_ctrl
*ctrl_has_crop_out
;
234 struct v4l2_ctrl
*ctrl_has_compose_out
;
235 struct v4l2_ctrl
*ctrl_has_scaler_out
;
236 struct v4l2_ctrl
*ctrl_tx_mode
;
237 struct v4l2_ctrl
*ctrl_tx_rgb_range
;
239 struct v4l2_ctrl
*radio_tx_rds_pi
;
240 struct v4l2_ctrl
*radio_tx_rds_pty
;
241 struct v4l2_ctrl
*radio_tx_rds_mono_stereo
;
242 struct v4l2_ctrl
*radio_tx_rds_art_head
;
243 struct v4l2_ctrl
*radio_tx_rds_compressed
;
244 struct v4l2_ctrl
*radio_tx_rds_dyn_pty
;
245 struct v4l2_ctrl
*radio_tx_rds_ta
;
246 struct v4l2_ctrl
*radio_tx_rds_tp
;
247 struct v4l2_ctrl
*radio_tx_rds_ms
;
248 struct v4l2_ctrl
*radio_tx_rds_psname
;
249 struct v4l2_ctrl
*radio_tx_rds_radiotext
;
251 struct v4l2_ctrl
*radio_rx_rds_pty
;
252 struct v4l2_ctrl
*radio_rx_rds_ta
;
253 struct v4l2_ctrl
*radio_rx_rds_tp
;
254 struct v4l2_ctrl
*radio_rx_rds_ms
;
255 struct v4l2_ctrl
*radio_rx_rds_psname
;
256 struct v4l2_ctrl
*radio_rx_rds_radiotext
;
258 unsigned input_brightness
[MAX_INPUTS
];
260 unsigned button_pressed
;
265 bool vbi_cap_interlaced
;
270 unsigned long video_pbase
;
272 u32 video_buffer_size
;
275 int display_byte_stride
;
278 struct fb_info fb_info
;
279 struct fb_var_screeninfo fb_defined
;
280 struct fb_fix_screeninfo fb_fix
;
282 /* Error injection */
283 bool queue_setup_error
;
284 bool buf_prepare_error
;
285 bool start_streaming_error
;
289 u64 time_wrap_offset
;
290 unsigned perc_dropped_buffers
;
291 enum vivid_signal_mode std_signal_mode
;
292 unsigned query_std_last
;
293 v4l2_std_id query_std
;
294 enum tpg_video_aspect std_aspect_ratio
;
296 enum vivid_signal_mode dv_timings_signal_mode
;
297 char **query_dv_timings_qmenu
;
298 unsigned query_dv_timings_size
;
299 unsigned query_dv_timings_last
;
300 unsigned query_dv_timings
;
301 enum tpg_video_aspect dv_timings_aspect_ratio
;
306 struct v4l2_dv_timings dv_timings_cap
;
308 struct vivid_vbi_gen_data vbi_gen
;
310 unsigned edid_blocks
;
311 unsigned edid_max_blocks
;
312 unsigned webcam_size_idx
;
313 unsigned webcam_ival_idx
;
316 unsigned tv_field_cap
;
317 unsigned tv_audio_input
;
319 /* Capture Overlay */
320 struct v4l2_framebuffer fb_cap
;
321 struct v4l2_fh
*overlay_cap_owner
;
323 int overlay_cap_top
, overlay_cap_left
;
324 enum v4l2_field overlay_cap_field
;
326 struct v4l2_clip clips_cap
[MAX_CLIPS
];
327 struct v4l2_clip try_clips_cap
[MAX_CLIPS
];
328 unsigned clipcount_cap
;
333 struct v4l2_dv_timings dv_timings_out
;
336 u32 quantization_out
;
339 unsigned bytesperline_out
[TPG_MAX_PLANES
];
340 unsigned tv_field_out
;
341 unsigned tv_audio_output
;
342 bool vbi_out_have_wss
;
344 bool vbi_out_have_cc
[2];
349 unsigned cur_scaled_line
;
353 bool overlay_out_enabled
;
354 int overlay_out_top
, overlay_out_left
;
356 struct v4l2_clip clips_out
[MAX_CLIPS
];
357 struct v4l2_clip try_clips_out
[MAX_CLIPS
];
358 unsigned clipcount_out
;
359 unsigned fbuf_out_flags
;
366 bool must_blank
[VIDEO_MAX_FRAME
];
368 const struct vivid_fmt
*fmt_cap
;
369 struct v4l2_fract timeperframe_vid_cap
;
370 enum v4l2_field field_cap
;
371 struct v4l2_rect src_rect
;
372 struct v4l2_rect fmt_cap_rect
;
373 struct v4l2_rect crop_cap
;
374 struct v4l2_rect compose_cap
;
375 struct v4l2_rect crop_bounds_cap
;
376 struct vb2_queue vb_vid_cap_q
;
377 struct list_head vid_cap_active
;
378 struct vb2_queue vb_vbi_cap_q
;
379 struct list_head vbi_cap_active
;
381 /* thread for generating video capture stream */
382 struct task_struct
*kthread_vid_cap
;
383 unsigned long jiffies_vid_cap
;
387 u32 vid_cap_seq_start
;
388 u32 vid_cap_seq_count
;
389 bool vid_cap_streaming
;
390 u32 vbi_cap_seq_start
;
391 u32 vbi_cap_seq_count
;
392 bool vbi_cap_streaming
;
393 bool stream_sliced_vbi_cap
;
396 const struct vivid_fmt
*fmt_out
;
397 struct v4l2_fract timeperframe_vid_out
;
398 enum v4l2_field field_out
;
399 struct v4l2_rect sink_rect
;
400 struct v4l2_rect fmt_out_rect
;
401 struct v4l2_rect crop_out
;
402 struct v4l2_rect compose_out
;
403 struct v4l2_rect compose_bounds_out
;
404 struct vb2_queue vb_vid_out_q
;
405 struct list_head vid_out_active
;
406 struct vb2_queue vb_vbi_out_q
;
407 struct list_head vbi_out_active
;
409 /* video loop precalculated rectangles */
412 * Intersection between what the output side composes and the capture side
413 * crops. I.e., what actually needs to be copied from the output buffer to
414 * the capture buffer.
416 struct v4l2_rect loop_vid_copy
;
417 /* The part of the output buffer that (after scaling) corresponds to loop_vid_copy. */
418 struct v4l2_rect loop_vid_out
;
419 /* The part of the capture buffer that (after scaling) corresponds to loop_vid_copy. */
420 struct v4l2_rect loop_vid_cap
;
422 * The intersection of the framebuffer, the overlay output window and
423 * loop_vid_copy. I.e., the part of the framebuffer that actually should be
424 * blended with the compose_out rectangle. This uses the framebuffer origin.
426 struct v4l2_rect loop_fb_copy
;
427 /* The same as loop_fb_copy but with compose_out origin. */
428 struct v4l2_rect loop_vid_overlay
;
430 * The part of the capture buffer that (after scaling) corresponds
431 * to loop_vid_overlay.
433 struct v4l2_rect loop_vid_overlay_cap
;
435 /* thread for generating video output stream */
436 struct task_struct
*kthread_vid_out
;
437 unsigned long jiffies_vid_out
;
441 u32 vid_out_seq_start
;
442 u32 vid_out_seq_count
;
443 bool vid_out_streaming
;
444 u32 vbi_out_seq_start
;
445 u32 vbi_out_seq_count
;
446 bool vbi_out_streaming
;
447 bool stream_sliced_vbi_out
;
450 struct vb2_queue vb_sdr_cap_q
;
451 struct list_head sdr_cap_active
;
452 u32 sdr_pixelformat
; /* v4l2 format id */
453 unsigned sdr_buffersize
;
454 unsigned sdr_adc_freq
;
455 unsigned sdr_fm_freq
;
456 unsigned sdr_fm_deviation
;
457 int sdr_fixp_src_phase
;
458 int sdr_fixp_mod_phase
;
460 bool tstamp_src_is_soe
;
462 bool has_compose_cap
;
465 bool has_compose_out
;
468 /* thread for generating SDR stream */
469 struct task_struct
*kthread_sdr_cap
;
470 unsigned long jiffies_sdr_cap
;
471 u32 sdr_cap_seq_offset
;
472 u32 sdr_cap_seq_count
;
473 bool sdr_cap_seq_resync
;
476 struct vivid_rds_gen rds_gen
;
479 unsigned radio_rx_freq
;
480 unsigned radio_rx_audmode
;
481 int radio_rx_sig_qual
;
482 unsigned radio_rx_hw_seek_mode
;
483 bool radio_rx_hw_seek_prog_lim
;
484 bool radio_rx_rds_controls
;
485 bool radio_rx_rds_enabled
;
486 unsigned radio_rx_rds_use_alternates
;
487 unsigned radio_rx_rds_last_block
;
488 struct v4l2_fh
*radio_rx_rds_owner
;
490 /* Radio transmitter */
491 unsigned radio_tx_freq
;
492 unsigned radio_tx_subchans
;
493 bool radio_tx_rds_controls
;
494 unsigned radio_tx_rds_last_block
;
495 struct v4l2_fh
*radio_tx_rds_owner
;
497 /* Shared between radio receiver and transmitter */
499 struct timespec radio_rds_init_ts
;
502 static inline bool vivid_is_webcam(const struct vivid_dev
*dev
)
504 return dev
->input_type
[dev
->input
] == WEBCAM
;
507 static inline bool vivid_is_tv_cap(const struct vivid_dev
*dev
)
509 return dev
->input_type
[dev
->input
] == TV
;
512 static inline bool vivid_is_svid_cap(const struct vivid_dev
*dev
)
514 return dev
->input_type
[dev
->input
] == SVID
;
517 static inline bool vivid_is_hdmi_cap(const struct vivid_dev
*dev
)
519 return dev
->input_type
[dev
->input
] == HDMI
;
522 static inline bool vivid_is_sdtv_cap(const struct vivid_dev
*dev
)
524 return vivid_is_tv_cap(dev
) || vivid_is_svid_cap(dev
);
527 static inline bool vivid_is_svid_out(const struct vivid_dev
*dev
)
529 return dev
->output_type
[dev
->output
] == SVID
;
532 static inline bool vivid_is_hdmi_out(const struct vivid_dev
*dev
)
534 return dev
->output_type
[dev
->output
] == HDMI
;