xref: /OK3568_Linux_fs/kernel/include/media/drv-intf/cx2341x.h (revision 4882a59341e53eb6f0b4789bf948001014eff981)
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