1*4882a593Smuzhiyun /* SPDX-License-Identifier: GPL-2.0-or-later */ 2*4882a593Smuzhiyun /* 3*4882a593Smuzhiyun cx23415/6/8 header containing common defines. 4*4882a593Smuzhiyun 5*4882a593Smuzhiyun */ 6*4882a593Smuzhiyun 7*4882a593Smuzhiyun #ifndef CX2341X_H 8*4882a593Smuzhiyun #define CX2341X_H 9*4882a593Smuzhiyun 10*4882a593Smuzhiyun #include <media/v4l2-ctrls.h> 11*4882a593Smuzhiyun 12*4882a593Smuzhiyun enum cx2341x_port { 13*4882a593Smuzhiyun CX2341X_PORT_MEMORY = 0, 14*4882a593Smuzhiyun CX2341X_PORT_STREAMING = 1, 15*4882a593Smuzhiyun CX2341X_PORT_SERIAL = 2 16*4882a593Smuzhiyun }; 17*4882a593Smuzhiyun 18*4882a593Smuzhiyun enum cx2341x_cap { 19*4882a593Smuzhiyun CX2341X_CAP_HAS_SLICED_VBI = 1 << 0, 20*4882a593Smuzhiyun CX2341X_CAP_HAS_TS = 1 << 1, 21*4882a593Smuzhiyun CX2341X_CAP_HAS_AC3 = 1 << 2, 22*4882a593Smuzhiyun }; 23*4882a593Smuzhiyun 24*4882a593Smuzhiyun struct cx2341x_mpeg_params { 25*4882a593Smuzhiyun /* misc */ 26*4882a593Smuzhiyun u32 capabilities; 27*4882a593Smuzhiyun enum cx2341x_port port; 28*4882a593Smuzhiyun u16 width; 29*4882a593Smuzhiyun u16 height; 30*4882a593Smuzhiyun u16 is_50hz; 31*4882a593Smuzhiyun 32*4882a593Smuzhiyun /* stream */ 33*4882a593Smuzhiyun enum v4l2_mpeg_stream_type stream_type; 34*4882a593Smuzhiyun enum v4l2_mpeg_stream_vbi_fmt stream_vbi_fmt; 35*4882a593Smuzhiyun u16 stream_insert_nav_packets; 36*4882a593Smuzhiyun 37*4882a593Smuzhiyun /* audio */ 38*4882a593Smuzhiyun enum v4l2_mpeg_audio_sampling_freq audio_sampling_freq; 39*4882a593Smuzhiyun enum v4l2_mpeg_audio_encoding audio_encoding; 40*4882a593Smuzhiyun enum v4l2_mpeg_audio_l2_bitrate audio_l2_bitrate; 41*4882a593Smuzhiyun enum v4l2_mpeg_audio_ac3_bitrate audio_ac3_bitrate; 42*4882a593Smuzhiyun enum v4l2_mpeg_audio_mode audio_mode; 43*4882a593Smuzhiyun enum v4l2_mpeg_audio_mode_extension audio_mode_extension; 44*4882a593Smuzhiyun enum v4l2_mpeg_audio_emphasis audio_emphasis; 45*4882a593Smuzhiyun enum v4l2_mpeg_audio_crc audio_crc; 46*4882a593Smuzhiyun u32 audio_properties; 47*4882a593Smuzhiyun u16 audio_mute; 48*4882a593Smuzhiyun 49*4882a593Smuzhiyun /* video */ 50*4882a593Smuzhiyun enum v4l2_mpeg_video_encoding video_encoding; 51*4882a593Smuzhiyun enum v4l2_mpeg_video_aspect video_aspect; 52*4882a593Smuzhiyun u16 video_b_frames; 53*4882a593Smuzhiyun u16 video_gop_size; 54*4882a593Smuzhiyun u16 video_gop_closure; 55*4882a593Smuzhiyun enum v4l2_mpeg_video_bitrate_mode video_bitrate_mode; 56*4882a593Smuzhiyun u32 video_bitrate; 57*4882a593Smuzhiyun u32 video_bitrate_peak; 58*4882a593Smuzhiyun u16 video_temporal_decimation; 59*4882a593Smuzhiyun u16 video_mute; 60*4882a593Smuzhiyun u32 video_mute_yuv; 61*4882a593Smuzhiyun 62*4882a593Smuzhiyun /* encoding filters */ 63*4882a593Smuzhiyun enum v4l2_mpeg_cx2341x_video_spatial_filter_mode video_spatial_filter_mode; 64*4882a593Smuzhiyun u16 video_spatial_filter; 65*4882a593Smuzhiyun enum v4l2_mpeg_cx2341x_video_luma_spatial_filter_type video_luma_spatial_filter_type; 66*4882a593Smuzhiyun enum v4l2_mpeg_cx2341x_video_chroma_spatial_filter_type video_chroma_spatial_filter_type; 67*4882a593Smuzhiyun enum v4l2_mpeg_cx2341x_video_temporal_filter_mode video_temporal_filter_mode; 68*4882a593Smuzhiyun u16 video_temporal_filter; 69*4882a593Smuzhiyun enum v4l2_mpeg_cx2341x_video_median_filter_type video_median_filter_type; 70*4882a593Smuzhiyun u16 video_luma_median_filter_top; 71*4882a593Smuzhiyun u16 video_luma_median_filter_bottom; 72*4882a593Smuzhiyun u16 video_chroma_median_filter_top; 73*4882a593Smuzhiyun u16 video_chroma_median_filter_bottom; 74*4882a593Smuzhiyun }; 75*4882a593Smuzhiyun 76*4882a593Smuzhiyun #define CX2341X_MBOX_MAX_DATA 16 77*4882a593Smuzhiyun 78*4882a593Smuzhiyun extern const u32 cx2341x_mpeg_ctrls[]; 79*4882a593Smuzhiyun typedef int (*cx2341x_mbox_func)(void *priv, u32 cmd, int in, int out, 80*4882a593Smuzhiyun u32 data[CX2341X_MBOX_MAX_DATA]); 81*4882a593Smuzhiyun int cx2341x_update(void *priv, cx2341x_mbox_func func, 82*4882a593Smuzhiyun const struct cx2341x_mpeg_params *old, 83*4882a593Smuzhiyun const struct cx2341x_mpeg_params *new); 84*4882a593Smuzhiyun int cx2341x_ctrl_query(const struct cx2341x_mpeg_params *params, 85*4882a593Smuzhiyun struct v4l2_queryctrl *qctrl); 86*4882a593Smuzhiyun const char * const *cx2341x_ctrl_get_menu(const struct cx2341x_mpeg_params *p, u32 id); 87*4882a593Smuzhiyun int cx2341x_ext_ctrls(struct cx2341x_mpeg_params *params, int busy, 88*4882a593Smuzhiyun struct v4l2_ext_controls *ctrls, unsigned int cmd); 89*4882a593Smuzhiyun void cx2341x_fill_defaults(struct cx2341x_mpeg_params *p); 90*4882a593Smuzhiyun void cx2341x_log_status(const struct cx2341x_mpeg_params *p, const char *prefix); 91*4882a593Smuzhiyun 92*4882a593Smuzhiyun struct cx2341x_handler; 93*4882a593Smuzhiyun 94*4882a593Smuzhiyun struct cx2341x_handler_ops { 95*4882a593Smuzhiyun /* needed for the video clock freq */ 96*4882a593Smuzhiyun int (*s_audio_sampling_freq)(struct cx2341x_handler *hdl, u32 val); 97*4882a593Smuzhiyun /* needed for dualwatch */ 98*4882a593Smuzhiyun int (*s_audio_mode)(struct cx2341x_handler *hdl, u32 val); 99*4882a593Smuzhiyun /* needed for setting up the video resolution */ 100*4882a593Smuzhiyun int (*s_video_encoding)(struct cx2341x_handler *hdl, u32 val); 101*4882a593Smuzhiyun /* needed for setting up the sliced vbi insertion data structures */ 102*4882a593Smuzhiyun int (*s_stream_vbi_fmt)(struct cx2341x_handler *hdl, u32 val); 103*4882a593Smuzhiyun }; 104*4882a593Smuzhiyun 105*4882a593Smuzhiyun struct cx2341x_handler { 106*4882a593Smuzhiyun u32 capabilities; 107*4882a593Smuzhiyun enum cx2341x_port port; 108*4882a593Smuzhiyun u16 width; 109*4882a593Smuzhiyun u16 height; 110*4882a593Smuzhiyun u16 is_50hz; 111*4882a593Smuzhiyun u32 audio_properties; 112*4882a593Smuzhiyun 113*4882a593Smuzhiyun struct v4l2_ctrl_handler hdl; 114*4882a593Smuzhiyun void *priv; 115*4882a593Smuzhiyun cx2341x_mbox_func func; 116*4882a593Smuzhiyun const struct cx2341x_handler_ops *ops; 117*4882a593Smuzhiyun 118*4882a593Smuzhiyun struct v4l2_ctrl *stream_vbi_fmt; 119*4882a593Smuzhiyun 120*4882a593Smuzhiyun struct { 121*4882a593Smuzhiyun /* audio cluster */ 122*4882a593Smuzhiyun struct v4l2_ctrl *audio_sampling_freq; 123*4882a593Smuzhiyun struct v4l2_ctrl *audio_encoding; 124*4882a593Smuzhiyun struct v4l2_ctrl *audio_l2_bitrate; 125*4882a593Smuzhiyun struct v4l2_ctrl *audio_mode; 126*4882a593Smuzhiyun struct v4l2_ctrl *audio_mode_extension; 127*4882a593Smuzhiyun struct v4l2_ctrl *audio_emphasis; 128*4882a593Smuzhiyun struct v4l2_ctrl *audio_crc; 129*4882a593Smuzhiyun struct v4l2_ctrl *audio_ac3_bitrate; 130*4882a593Smuzhiyun }; 131*4882a593Smuzhiyun 132*4882a593Smuzhiyun struct { 133*4882a593Smuzhiyun /* video gop cluster */ 134*4882a593Smuzhiyun struct v4l2_ctrl *video_b_frames; 135*4882a593Smuzhiyun struct v4l2_ctrl *video_gop_size; 136*4882a593Smuzhiyun }; 137*4882a593Smuzhiyun 138*4882a593Smuzhiyun struct { 139*4882a593Smuzhiyun /* stream type cluster */ 140*4882a593Smuzhiyun struct v4l2_ctrl *stream_type; 141*4882a593Smuzhiyun struct v4l2_ctrl *video_encoding; 142*4882a593Smuzhiyun struct v4l2_ctrl *video_bitrate_mode; 143*4882a593Smuzhiyun struct v4l2_ctrl *video_bitrate; 144*4882a593Smuzhiyun struct v4l2_ctrl *video_bitrate_peak; 145*4882a593Smuzhiyun }; 146*4882a593Smuzhiyun 147*4882a593Smuzhiyun struct { 148*4882a593Smuzhiyun /* video mute cluster */ 149*4882a593Smuzhiyun struct v4l2_ctrl *video_mute; 150*4882a593Smuzhiyun struct v4l2_ctrl *video_mute_yuv; 151*4882a593Smuzhiyun }; 152*4882a593Smuzhiyun 153*4882a593Smuzhiyun struct { 154*4882a593Smuzhiyun /* video filter mode cluster */ 155*4882a593Smuzhiyun struct v4l2_ctrl *video_spatial_filter_mode; 156*4882a593Smuzhiyun struct v4l2_ctrl *video_temporal_filter_mode; 157*4882a593Smuzhiyun struct v4l2_ctrl *video_median_filter_type; 158*4882a593Smuzhiyun }; 159*4882a593Smuzhiyun 160*4882a593Smuzhiyun struct { 161*4882a593Smuzhiyun /* video filter type cluster */ 162*4882a593Smuzhiyun struct v4l2_ctrl *video_luma_spatial_filter_type; 163*4882a593Smuzhiyun struct v4l2_ctrl *video_chroma_spatial_filter_type; 164*4882a593Smuzhiyun }; 165*4882a593Smuzhiyun 166*4882a593Smuzhiyun struct { 167*4882a593Smuzhiyun /* video filter cluster */ 168*4882a593Smuzhiyun struct v4l2_ctrl *video_spatial_filter; 169*4882a593Smuzhiyun struct v4l2_ctrl *video_temporal_filter; 170*4882a593Smuzhiyun }; 171*4882a593Smuzhiyun 172*4882a593Smuzhiyun struct { 173*4882a593Smuzhiyun /* video median cluster */ 174*4882a593Smuzhiyun struct v4l2_ctrl *video_luma_median_filter_top; 175*4882a593Smuzhiyun struct v4l2_ctrl *video_luma_median_filter_bottom; 176*4882a593Smuzhiyun struct v4l2_ctrl *video_chroma_median_filter_top; 177*4882a593Smuzhiyun struct v4l2_ctrl *video_chroma_median_filter_bottom; 178*4882a593Smuzhiyun }; 179*4882a593Smuzhiyun }; 180*4882a593Smuzhiyun 181*4882a593Smuzhiyun int cx2341x_handler_init(struct cx2341x_handler *cxhdl, 182*4882a593Smuzhiyun unsigned nr_of_controls_hint); 183*4882a593Smuzhiyun void cx2341x_handler_set_50hz(struct cx2341x_handler *cxhdl, int is_50hz); 184*4882a593Smuzhiyun int cx2341x_handler_setup(struct cx2341x_handler *cxhdl); 185*4882a593Smuzhiyun void cx2341x_handler_set_busy(struct cx2341x_handler *cxhdl, int busy); 186*4882a593Smuzhiyun 187*4882a593Smuzhiyun /* Firmware names */ 188*4882a593Smuzhiyun #define CX2341X_FIRM_ENC_FILENAME "v4l-cx2341x-enc.fw" 189*4882a593Smuzhiyun /* Decoder firmware for the cx23415 only */ 190*4882a593Smuzhiyun #define CX2341X_FIRM_DEC_FILENAME "v4l-cx2341x-dec.fw" 191*4882a593Smuzhiyun 192*4882a593Smuzhiyun /* Firmware API commands */ 193*4882a593Smuzhiyun 194*4882a593Smuzhiyun /* MPEG decoder API, specific to the cx23415 */ 195*4882a593Smuzhiyun #define CX2341X_DEC_PING_FW 0x00 196*4882a593Smuzhiyun #define CX2341X_DEC_START_PLAYBACK 0x01 197*4882a593Smuzhiyun #define CX2341X_DEC_STOP_PLAYBACK 0x02 198*4882a593Smuzhiyun #define CX2341X_DEC_SET_PLAYBACK_SPEED 0x03 199*4882a593Smuzhiyun #define CX2341X_DEC_STEP_VIDEO 0x05 200*4882a593Smuzhiyun #define CX2341X_DEC_SET_DMA_BLOCK_SIZE 0x08 201*4882a593Smuzhiyun #define CX2341X_DEC_GET_XFER_INFO 0x09 202*4882a593Smuzhiyun #define CX2341X_DEC_GET_DMA_STATUS 0x0a 203*4882a593Smuzhiyun #define CX2341X_DEC_SCHED_DMA_FROM_HOST 0x0b 204*4882a593Smuzhiyun #define CX2341X_DEC_PAUSE_PLAYBACK 0x0d 205*4882a593Smuzhiyun #define CX2341X_DEC_HALT_FW 0x0e 206*4882a593Smuzhiyun #define CX2341X_DEC_SET_STANDARD 0x10 207*4882a593Smuzhiyun #define CX2341X_DEC_GET_VERSION 0x11 208*4882a593Smuzhiyun #define CX2341X_DEC_SET_STREAM_INPUT 0x14 209*4882a593Smuzhiyun #define CX2341X_DEC_GET_TIMING_INFO 0x15 210*4882a593Smuzhiyun #define CX2341X_DEC_SET_AUDIO_MODE 0x16 211*4882a593Smuzhiyun #define CX2341X_DEC_SET_EVENT_NOTIFICATION 0x17 212*4882a593Smuzhiyun #define CX2341X_DEC_SET_DISPLAY_BUFFERS 0x18 213*4882a593Smuzhiyun #define CX2341X_DEC_EXTRACT_VBI 0x19 214*4882a593Smuzhiyun #define CX2341X_DEC_SET_DECODER_SOURCE 0x1a 215*4882a593Smuzhiyun #define CX2341X_DEC_SET_PREBUFFERING 0x1e 216*4882a593Smuzhiyun 217*4882a593Smuzhiyun /* MPEG encoder API */ 218*4882a593Smuzhiyun #define CX2341X_ENC_PING_FW 0x80 219*4882a593Smuzhiyun #define CX2341X_ENC_START_CAPTURE 0x81 220*4882a593Smuzhiyun #define CX2341X_ENC_STOP_CAPTURE 0x82 221*4882a593Smuzhiyun #define CX2341X_ENC_SET_AUDIO_ID 0x89 222*4882a593Smuzhiyun #define CX2341X_ENC_SET_VIDEO_ID 0x8b 223*4882a593Smuzhiyun #define CX2341X_ENC_SET_PCR_ID 0x8d 224*4882a593Smuzhiyun #define CX2341X_ENC_SET_FRAME_RATE 0x8f 225*4882a593Smuzhiyun #define CX2341X_ENC_SET_FRAME_SIZE 0x91 226*4882a593Smuzhiyun #define CX2341X_ENC_SET_BIT_RATE 0x95 227*4882a593Smuzhiyun #define CX2341X_ENC_SET_GOP_PROPERTIES 0x97 228*4882a593Smuzhiyun #define CX2341X_ENC_SET_ASPECT_RATIO 0x99 229*4882a593Smuzhiyun #define CX2341X_ENC_SET_DNR_FILTER_MODE 0x9b 230*4882a593Smuzhiyun #define CX2341X_ENC_SET_DNR_FILTER_PROPS 0x9d 231*4882a593Smuzhiyun #define CX2341X_ENC_SET_CORING_LEVELS 0x9f 232*4882a593Smuzhiyun #define CX2341X_ENC_SET_SPATIAL_FILTER_TYPE 0xa1 233*4882a593Smuzhiyun #define CX2341X_ENC_SET_VBI_LINE 0xb7 234*4882a593Smuzhiyun #define CX2341X_ENC_SET_STREAM_TYPE 0xb9 235*4882a593Smuzhiyun #define CX2341X_ENC_SET_OUTPUT_PORT 0xbb 236*4882a593Smuzhiyun #define CX2341X_ENC_SET_AUDIO_PROPERTIES 0xbd 237*4882a593Smuzhiyun #define CX2341X_ENC_HALT_FW 0xc3 238*4882a593Smuzhiyun #define CX2341X_ENC_GET_VERSION 0xc4 239*4882a593Smuzhiyun #define CX2341X_ENC_SET_GOP_CLOSURE 0xc5 240*4882a593Smuzhiyun #define CX2341X_ENC_GET_SEQ_END 0xc6 241*4882a593Smuzhiyun #define CX2341X_ENC_SET_PGM_INDEX_INFO 0xc7 242*4882a593Smuzhiyun #define CX2341X_ENC_SET_VBI_CONFIG 0xc8 243*4882a593Smuzhiyun #define CX2341X_ENC_SET_DMA_BLOCK_SIZE 0xc9 244*4882a593Smuzhiyun #define CX2341X_ENC_GET_PREV_DMA_INFO_MB_10 0xca 245*4882a593Smuzhiyun #define CX2341X_ENC_GET_PREV_DMA_INFO_MB_9 0xcb 246*4882a593Smuzhiyun #define CX2341X_ENC_SCHED_DMA_TO_HOST 0xcc 247*4882a593Smuzhiyun #define CX2341X_ENC_INITIALIZE_INPUT 0xcd 248*4882a593Smuzhiyun #define CX2341X_ENC_SET_FRAME_DROP_RATE 0xd0 249*4882a593Smuzhiyun #define CX2341X_ENC_PAUSE_ENCODER 0xd2 250*4882a593Smuzhiyun #define CX2341X_ENC_REFRESH_INPUT 0xd3 251*4882a593Smuzhiyun #define CX2341X_ENC_SET_COPYRIGHT 0xd4 252*4882a593Smuzhiyun #define CX2341X_ENC_SET_EVENT_NOTIFICATION 0xd5 253*4882a593Smuzhiyun #define CX2341X_ENC_SET_NUM_VSYNC_LINES 0xd6 254*4882a593Smuzhiyun #define CX2341X_ENC_SET_PLACEHOLDER 0xd7 255*4882a593Smuzhiyun #define CX2341X_ENC_MUTE_VIDEO 0xd9 256*4882a593Smuzhiyun #define CX2341X_ENC_MUTE_AUDIO 0xda 257*4882a593Smuzhiyun #define CX2341X_ENC_SET_VERT_CROP_LINE 0xdb 258*4882a593Smuzhiyun #define CX2341X_ENC_MISC 0xdc 259*4882a593Smuzhiyun 260*4882a593Smuzhiyun /* OSD API, specific to the cx23415 */ 261*4882a593Smuzhiyun #define CX2341X_OSD_GET_FRAMEBUFFER 0x41 262*4882a593Smuzhiyun #define CX2341X_OSD_GET_PIXEL_FORMAT 0x42 263*4882a593Smuzhiyun #define CX2341X_OSD_SET_PIXEL_FORMAT 0x43 264*4882a593Smuzhiyun #define CX2341X_OSD_GET_STATE 0x44 265*4882a593Smuzhiyun #define CX2341X_OSD_SET_STATE 0x45 266*4882a593Smuzhiyun #define CX2341X_OSD_GET_OSD_COORDS 0x46 267*4882a593Smuzhiyun #define CX2341X_OSD_SET_OSD_COORDS 0x47 268*4882a593Smuzhiyun #define CX2341X_OSD_GET_SCREEN_COORDS 0x48 269*4882a593Smuzhiyun #define CX2341X_OSD_SET_SCREEN_COORDS 0x49 270*4882a593Smuzhiyun #define CX2341X_OSD_GET_GLOBAL_ALPHA 0x4a 271*4882a593Smuzhiyun #define CX2341X_OSD_SET_GLOBAL_ALPHA 0x4b 272*4882a593Smuzhiyun #define CX2341X_OSD_SET_BLEND_COORDS 0x4c 273*4882a593Smuzhiyun #define CX2341X_OSD_GET_FLICKER_STATE 0x4f 274*4882a593Smuzhiyun #define CX2341X_OSD_SET_FLICKER_STATE 0x50 275*4882a593Smuzhiyun #define CX2341X_OSD_BLT_COPY 0x52 276*4882a593Smuzhiyun #define CX2341X_OSD_BLT_FILL 0x53 277*4882a593Smuzhiyun #define CX2341X_OSD_BLT_TEXT 0x54 278*4882a593Smuzhiyun #define CX2341X_OSD_SET_FRAMEBUFFER_WINDOW 0x56 279*4882a593Smuzhiyun #define CX2341X_OSD_SET_CHROMA_KEY 0x60 280*4882a593Smuzhiyun #define CX2341X_OSD_GET_ALPHA_CONTENT_INDEX 0x61 281*4882a593Smuzhiyun #define CX2341X_OSD_SET_ALPHA_CONTENT_INDEX 0x62 282*4882a593Smuzhiyun 283*4882a593Smuzhiyun #endif /* CX2341X_H */ 284