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 <linux/workqueue.h>
25 #include <media/cec.h>
26 #include <media/videobuf2-v4l2.h>
27 #include <media/v4l2-device.h>
28 #include <media/v4l2-dev.h>
29 #include <media/v4l2-ctrls.h>
30 #include <media/v4l2-tpg.h>
31 #include "vivid-rds-gen.h"
32 #include "vivid-vbi-gen.h"
34 #define dprintk(dev, level, fmt, arg...) \
35 v4l2_dbg(level, vivid_debug, &dev->v4l2_dev, fmt, ## arg)
37 /* Maximum allowed frame rate
39 * vivid will allow setting timeperframe in [1/FPS_MAX - FPS_MAX/1] range.
41 * Ideally FPS_MAX should be infinity, i.e. practically UINT_MAX, but that
42 * might hit application errors when they manipulate these values.
44 * Besides, for tpf < 10ms image-generation logic should be changed, to avoid
45 * producing frames with equal content.
49 /* The maximum number of clip rectangles */
51 /* The maximum number of inputs */
53 /* The maximum number of outputs */
54 #define MAX_OUTPUTS 16
55 /* The maximum up or down scaling factor is 4 */
57 /* The maximum image width/height are set to 4K DMT */
58 #define MAX_WIDTH 4096
59 #define MAX_HEIGHT 2160
60 /* The minimum image width/height */
63 /* The data_offset of plane 0 for the multiplanar formats */
64 #define PLANE0_DATA_OFFSET 128
66 /* The supported TV frequency range in MHz */
67 #define MIN_TV_FREQ (44U * 16U)
68 #define MAX_TV_FREQ (958U * 16U)
70 /* The number of samples returned in every SDR buffer */
71 #define SDR_CAP_SAMPLES_PER_BUF 0x4000
73 /* used by the threads to know when to resync internal counters */
74 #define JIFFIES_PER_DAY (3600U * 24U * HZ)
75 #define JIFFIES_RESYNC (JIFFIES_PER_DAY * (0xf0000000U / JIFFIES_PER_DAY))
77 extern const struct v4l2_rect vivid_min_rect
;
78 extern const struct v4l2_rect vivid_max_rect
;
79 extern unsigned vivid_debug
;
82 u32 fourcc
; /* v4l2 format id */
85 u8 vdownsampling
[TPG_MAX_PLANES
];
89 u32 data_offset
[TPG_MAX_PLANES
];
90 u32 bit_depth
[TPG_MAX_PLANES
];
93 extern struct vivid_fmt vivid_formats
[];
95 /* buffer for one video frame */
97 /* common v4l buffer stuff -- must be first */
98 struct vb2_v4l2_buffer vb
;
99 struct list_head list
;
109 enum vivid_signal_mode
{
111 CURRENT_STD
= CURRENT_DV_TIMINGS
,
116 SELECTED_STD
= SELECTED_DV_TIMINGS
,
118 CYCLE_STD
= CYCLE_DV_TIMINGS
,
122 enum vivid_colorspace
{
134 #define VIVID_INVALID_SIGNAL(mode) \
135 ((mode) == NO_SIGNAL || (mode) == NO_LOCK || (mode) == OUT_OF_RANGE)
137 struct vivid_cec_work
{
138 struct list_head list
;
139 struct delayed_work work
;
140 struct cec_adapter
*adap
;
141 struct vivid_dev
*dev
;
143 unsigned int timeout_ms
;
150 struct v4l2_device v4l2_dev
;
151 struct v4l2_ctrl_handler ctrl_hdl_user_gen
;
152 struct v4l2_ctrl_handler ctrl_hdl_user_vid
;
153 struct v4l2_ctrl_handler ctrl_hdl_user_aud
;
154 struct v4l2_ctrl_handler ctrl_hdl_streaming
;
155 struct v4l2_ctrl_handler ctrl_hdl_sdtv_cap
;
156 struct v4l2_ctrl_handler ctrl_hdl_loop_cap
;
157 struct video_device vid_cap_dev
;
158 struct v4l2_ctrl_handler ctrl_hdl_vid_cap
;
159 struct video_device vid_out_dev
;
160 struct v4l2_ctrl_handler ctrl_hdl_vid_out
;
161 struct video_device vbi_cap_dev
;
162 struct v4l2_ctrl_handler ctrl_hdl_vbi_cap
;
163 struct video_device vbi_out_dev
;
164 struct v4l2_ctrl_handler ctrl_hdl_vbi_out
;
165 struct video_device radio_rx_dev
;
166 struct v4l2_ctrl_handler ctrl_hdl_radio_rx
;
167 struct video_device radio_tx_dev
;
168 struct v4l2_ctrl_handler ctrl_hdl_radio_tx
;
169 struct video_device sdr_cap_dev
;
170 struct v4l2_ctrl_handler ctrl_hdl_sdr_cap
;
183 /* supported features */
186 u8 input_type
[MAX_INPUTS
];
187 u8 input_name_counter
[MAX_INPUTS
];
188 unsigned num_outputs
;
189 u8 output_type
[MAX_OUTPUTS
];
190 u8 output_name_counter
[MAX_OUTPUTS
];
191 bool has_audio_inputs
;
192 bool has_audio_outputs
;
196 bool has_raw_vbi_cap
;
197 bool has_sliced_vbi_cap
;
199 bool has_raw_vbi_out
;
200 bool has_sliced_vbi_out
;
209 struct v4l2_ctrl
*brightness
;
210 struct v4l2_ctrl
*contrast
;
211 struct v4l2_ctrl
*saturation
;
212 struct v4l2_ctrl
*hue
;
214 /* autogain/gain cluster */
215 struct v4l2_ctrl
*autogain
;
216 struct v4l2_ctrl
*gain
;
218 struct v4l2_ctrl
*volume
;
219 struct v4l2_ctrl
*mute
;
220 struct v4l2_ctrl
*alpha
;
221 struct v4l2_ctrl
*button
;
222 struct v4l2_ctrl
*boolean
;
223 struct v4l2_ctrl
*int32
;
224 struct v4l2_ctrl
*int64
;
225 struct v4l2_ctrl
*menu
;
226 struct v4l2_ctrl
*string
;
227 struct v4l2_ctrl
*bitmask
;
228 struct v4l2_ctrl
*int_menu
;
229 struct v4l2_ctrl
*test_pattern
;
230 struct v4l2_ctrl
*colorspace
;
231 struct v4l2_ctrl
*rgb_range_cap
;
232 struct v4l2_ctrl
*real_rgb_range_cap
;
234 /* std_signal_mode/standard cluster */
235 struct v4l2_ctrl
*ctrl_std_signal_mode
;
236 struct v4l2_ctrl
*ctrl_standard
;
239 /* dv_timings_signal_mode/timings cluster */
240 struct v4l2_ctrl
*ctrl_dv_timings_signal_mode
;
241 struct v4l2_ctrl
*ctrl_dv_timings
;
243 struct v4l2_ctrl
*ctrl_has_crop_cap
;
244 struct v4l2_ctrl
*ctrl_has_compose_cap
;
245 struct v4l2_ctrl
*ctrl_has_scaler_cap
;
246 struct v4l2_ctrl
*ctrl_has_crop_out
;
247 struct v4l2_ctrl
*ctrl_has_compose_out
;
248 struct v4l2_ctrl
*ctrl_has_scaler_out
;
249 struct v4l2_ctrl
*ctrl_tx_mode
;
250 struct v4l2_ctrl
*ctrl_tx_rgb_range
;
252 struct v4l2_ctrl
*radio_tx_rds_pi
;
253 struct v4l2_ctrl
*radio_tx_rds_pty
;
254 struct v4l2_ctrl
*radio_tx_rds_mono_stereo
;
255 struct v4l2_ctrl
*radio_tx_rds_art_head
;
256 struct v4l2_ctrl
*radio_tx_rds_compressed
;
257 struct v4l2_ctrl
*radio_tx_rds_dyn_pty
;
258 struct v4l2_ctrl
*radio_tx_rds_ta
;
259 struct v4l2_ctrl
*radio_tx_rds_tp
;
260 struct v4l2_ctrl
*radio_tx_rds_ms
;
261 struct v4l2_ctrl
*radio_tx_rds_psname
;
262 struct v4l2_ctrl
*radio_tx_rds_radiotext
;
264 struct v4l2_ctrl
*radio_rx_rds_pty
;
265 struct v4l2_ctrl
*radio_rx_rds_ta
;
266 struct v4l2_ctrl
*radio_rx_rds_tp
;
267 struct v4l2_ctrl
*radio_rx_rds_ms
;
268 struct v4l2_ctrl
*radio_rx_rds_psname
;
269 struct v4l2_ctrl
*radio_rx_rds_radiotext
;
271 unsigned input_brightness
[MAX_INPUTS
];
273 unsigned button_pressed
;
278 bool vbi_cap_interlaced
;
283 unsigned long video_pbase
;
285 u32 video_buffer_size
;
288 int display_byte_stride
;
291 struct fb_info fb_info
;
292 struct fb_var_screeninfo fb_defined
;
293 struct fb_fix_screeninfo fb_fix
;
295 /* Error injection */
296 bool queue_setup_error
;
297 bool buf_prepare_error
;
298 bool start_streaming_error
;
302 u64 time_wrap_offset
;
303 unsigned perc_dropped_buffers
;
304 enum vivid_signal_mode std_signal_mode
;
305 unsigned query_std_last
;
306 v4l2_std_id query_std
;
307 enum tpg_video_aspect std_aspect_ratio
;
309 enum vivid_signal_mode dv_timings_signal_mode
;
310 char **query_dv_timings_qmenu
;
311 unsigned query_dv_timings_size
;
312 unsigned query_dv_timings_last
;
313 unsigned query_dv_timings
;
314 enum tpg_video_aspect dv_timings_aspect_ratio
;
319 struct v4l2_dv_timings dv_timings_cap
;
321 struct vivid_vbi_gen_data vbi_gen
;
323 unsigned edid_blocks
;
324 unsigned edid_max_blocks
;
325 unsigned webcam_size_idx
;
326 unsigned webcam_ival_idx
;
329 unsigned tv_field_cap
;
330 unsigned tv_audio_input
;
332 /* Capture Overlay */
333 struct v4l2_framebuffer fb_cap
;
334 struct v4l2_fh
*overlay_cap_owner
;
336 int overlay_cap_top
, overlay_cap_left
;
337 enum v4l2_field overlay_cap_field
;
339 struct v4l2_clip clips_cap
[MAX_CLIPS
];
340 struct v4l2_clip try_clips_cap
[MAX_CLIPS
];
341 unsigned clipcount_cap
;
346 struct v4l2_dv_timings dv_timings_out
;
349 u32 quantization_out
;
352 unsigned bytesperline_out
[TPG_MAX_PLANES
];
353 unsigned tv_field_out
;
354 unsigned tv_audio_output
;
355 bool vbi_out_have_wss
;
357 bool vbi_out_have_cc
[2];
362 unsigned cur_scaled_line
;
366 bool overlay_out_enabled
;
367 int overlay_out_top
, overlay_out_left
;
369 struct v4l2_clip clips_out
[MAX_CLIPS
];
370 struct v4l2_clip try_clips_out
[MAX_CLIPS
];
371 unsigned clipcount_out
;
372 unsigned fbuf_out_flags
;
379 bool must_blank
[VIDEO_MAX_FRAME
];
381 const struct vivid_fmt
*fmt_cap
;
382 struct v4l2_fract timeperframe_vid_cap
;
383 enum v4l2_field field_cap
;
384 struct v4l2_rect src_rect
;
385 struct v4l2_rect fmt_cap_rect
;
386 struct v4l2_rect crop_cap
;
387 struct v4l2_rect compose_cap
;
388 struct v4l2_rect crop_bounds_cap
;
389 struct vb2_queue vb_vid_cap_q
;
390 struct list_head vid_cap_active
;
391 struct vb2_queue vb_vbi_cap_q
;
392 struct list_head vbi_cap_active
;
394 /* thread for generating video capture stream */
395 struct task_struct
*kthread_vid_cap
;
396 unsigned long jiffies_vid_cap
;
400 u32 vid_cap_seq_start
;
401 u32 vid_cap_seq_count
;
402 bool vid_cap_streaming
;
403 u32 vbi_cap_seq_start
;
404 u32 vbi_cap_seq_count
;
405 bool vbi_cap_streaming
;
406 bool stream_sliced_vbi_cap
;
409 const struct vivid_fmt
*fmt_out
;
410 struct v4l2_fract timeperframe_vid_out
;
411 enum v4l2_field field_out
;
412 struct v4l2_rect sink_rect
;
413 struct v4l2_rect fmt_out_rect
;
414 struct v4l2_rect crop_out
;
415 struct v4l2_rect compose_out
;
416 struct v4l2_rect compose_bounds_out
;
417 struct vb2_queue vb_vid_out_q
;
418 struct list_head vid_out_active
;
419 struct vb2_queue vb_vbi_out_q
;
420 struct list_head vbi_out_active
;
422 /* video loop precalculated rectangles */
425 * Intersection between what the output side composes and the capture side
426 * crops. I.e., what actually needs to be copied from the output buffer to
427 * the capture buffer.
429 struct v4l2_rect loop_vid_copy
;
430 /* The part of the output buffer that (after scaling) corresponds to loop_vid_copy. */
431 struct v4l2_rect loop_vid_out
;
432 /* The part of the capture buffer that (after scaling) corresponds to loop_vid_copy. */
433 struct v4l2_rect loop_vid_cap
;
435 * The intersection of the framebuffer, the overlay output window and
436 * loop_vid_copy. I.e., the part of the framebuffer that actually should be
437 * blended with the compose_out rectangle. This uses the framebuffer origin.
439 struct v4l2_rect loop_fb_copy
;
440 /* The same as loop_fb_copy but with compose_out origin. */
441 struct v4l2_rect loop_vid_overlay
;
443 * The part of the capture buffer that (after scaling) corresponds
444 * to loop_vid_overlay.
446 struct v4l2_rect loop_vid_overlay_cap
;
448 /* thread for generating video output stream */
449 struct task_struct
*kthread_vid_out
;
450 unsigned long jiffies_vid_out
;
454 u32 vid_out_seq_start
;
455 u32 vid_out_seq_count
;
456 bool vid_out_streaming
;
457 u32 vbi_out_seq_start
;
458 u32 vbi_out_seq_count
;
459 bool vbi_out_streaming
;
460 bool stream_sliced_vbi_out
;
463 struct vb2_queue vb_sdr_cap_q
;
464 struct list_head sdr_cap_active
;
465 u32 sdr_pixelformat
; /* v4l2 format id */
466 unsigned sdr_buffersize
;
467 unsigned sdr_adc_freq
;
468 unsigned sdr_fm_freq
;
469 unsigned sdr_fm_deviation
;
470 int sdr_fixp_src_phase
;
471 int sdr_fixp_mod_phase
;
473 bool tstamp_src_is_soe
;
475 bool has_compose_cap
;
478 bool has_compose_out
;
481 /* thread for generating SDR stream */
482 struct task_struct
*kthread_sdr_cap
;
483 unsigned long jiffies_sdr_cap
;
484 u32 sdr_cap_seq_offset
;
485 u32 sdr_cap_seq_count
;
486 bool sdr_cap_seq_resync
;
489 struct vivid_rds_gen rds_gen
;
492 unsigned radio_rx_freq
;
493 unsigned radio_rx_audmode
;
494 int radio_rx_sig_qual
;
495 unsigned radio_rx_hw_seek_mode
;
496 bool radio_rx_hw_seek_prog_lim
;
497 bool radio_rx_rds_controls
;
498 bool radio_rx_rds_enabled
;
499 unsigned radio_rx_rds_use_alternates
;
500 unsigned radio_rx_rds_last_block
;
501 struct v4l2_fh
*radio_rx_rds_owner
;
503 /* Radio transmitter */
504 unsigned radio_tx_freq
;
505 unsigned radio_tx_subchans
;
506 bool radio_tx_rds_controls
;
507 unsigned radio_tx_rds_last_block
;
508 struct v4l2_fh
*radio_tx_rds_owner
;
510 /* Shared between radio receiver and transmitter */
512 struct timespec radio_rds_init_ts
;
515 struct cec_adapter
*cec_rx_adap
;
516 struct cec_adapter
*cec_tx_adap
[MAX_OUTPUTS
];
517 struct workqueue_struct
*cec_workqueue
;
518 spinlock_t cec_slock
;
519 struct list_head cec_work_list
;
520 unsigned int cec_xfer_time_jiffies
;
521 unsigned long cec_xfer_start_jiffies
;
522 u8 cec_output2bus_map
[MAX_OUTPUTS
];
526 unsigned long osd_jiffies
;
529 static inline bool vivid_is_webcam(const struct vivid_dev
*dev
)
531 return dev
->input_type
[dev
->input
] == WEBCAM
;
534 static inline bool vivid_is_tv_cap(const struct vivid_dev
*dev
)
536 return dev
->input_type
[dev
->input
] == TV
;
539 static inline bool vivid_is_svid_cap(const struct vivid_dev
*dev
)
541 return dev
->input_type
[dev
->input
] == SVID
;
544 static inline bool vivid_is_hdmi_cap(const struct vivid_dev
*dev
)
546 return dev
->input_type
[dev
->input
] == HDMI
;
549 static inline bool vivid_is_sdtv_cap(const struct vivid_dev
*dev
)
551 return vivid_is_tv_cap(dev
) || vivid_is_svid_cap(dev
);
554 static inline bool vivid_is_svid_out(const struct vivid_dev
*dev
)
556 return dev
->output_type
[dev
->output
] == SVID
;
559 static inline bool vivid_is_hdmi_out(const struct vivid_dev
*dev
)
561 return dev
->output_type
[dev
->output
] == HDMI
;