1 /* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */
2 #ifndef __MSM_VIDC_UTILS_H__
3 #define __MSM_VIDC_UTILS_H__
4
5 #include <linux/types.h>
6
7 #define MSM_VIDC_EXTRADATA_NONE 0x00000000
8 struct msm_vidc_extradata_header {
9 __u32 size;
10 __u32 version; /** Keeping binary compatibility */
11 __u32 port_index; /* with firmware and OpenMAX IL **/
12 __u32 type; /* msm_vidc_extradata_type */
13 __u32 data_size;
14 __u32 data[1];
15 };
16
17 /* msm_vidc_interlace_type */
18 #define MSM_VIDC_INTERLACE_FRAME_PROGRESSIVE 0x01
19 #define MSM_VIDC_INTERLACE_INTERLEAVE_FRAME_TOPFIELDFIRST 0x02
20 #define MSM_VIDC_INTERLACE_INTERLEAVE_FRAME_BOTTOMFIELDFIRST 0x04
21 #define MSM_VIDC_INTERLACE_FRAME_TOPFIELDFIRST 0x08
22 #define MSM_VIDC_INTERLACE_FRAME_BOTTOMFIELDFIRST 0x10
23 #define MSM_VIDC_INTERLACE_FRAME_MBAFF 0x20
24 /* Color formats */
25 #define MSM_VIDC_HAL_INTERLACE_COLOR_FORMAT_NV12 0x2
26 #define MSM_VIDC_HAL_INTERLACE_COLOR_FORMAT_NV12_UBWC 0x8002
27 #define MSM_VIDC_EXTRADATA_INTERLACE_VIDEO 0x00000002
28 struct msm_vidc_interlace_payload {
29 __u32 format; /* Interlace format */
30 __u32 color_format;
31 };
32
33 #define MSM_VIDC_EXTRADATA_FRAME_RATE 0x00000007
34 struct msm_vidc_framerate_payload {
35 __u32 frame_rate; /*In Q16 format */
36 };
37
38 #define MSM_VIDC_EXTRADATA_TIMESTAMP 0x00000005
39 struct msm_vidc_ts_payload {
40 __u32 timestamp_lo;
41 __u32 timestamp_hi;
42 };
43
44 #define MSM_VIDC_EXTRADATA_NUM_CONCEALED_MB 0x7F100001
45 struct msm_vidc_concealmb_payload {
46 __u32 num_mbs;
47 };
48
49
50 #define MSM_VIDC_FRAME_RECONSTRUCTION_INCORRECT 0x0
51 #define MSM_VIDC_FRAME_RECONSTRUCTION_CORRECT 0x01
52 #define MSM_VIDC_FRAME_RECONSTRUCTION_APPROXIMATELY_CORRECT 0x02
53 #define MSM_VIDC_EXTRADATA_RECOVERY_POINT_SEI 0x00000009
54 struct msm_vidc_recoverysei_payload {
55 __u32 flags;
56 };
57
58 #define MSM_VIDC_EXTRADATA_ASPECT_RATIO 0x7F100003
59 struct msm_vidc_aspect_ratio_payload {
60 __u32 size;
61 __u32 version;
62 __u32 port_index;
63 __u32 aspect_width;
64 __u32 aspect_height;
65 };
66
67 struct msm_vidc_misr_info {
68 __u32 misr_set;
69 __u32 misr_dpb_luma[8];
70 __u32 misr_dpb_chroma[8];
71 __u32 misr_opb_luma[8];
72 __u32 misr_opb_chroma[8];
73 };
74 #define MSM_VIDC_EXTRADATA_OUTPUT_CROP 0x0700000F
75 struct msm_vidc_output_crop_payload {
76 __u32 size;
77 __u32 version;
78 __u32 port_index;
79 __u32 left;
80 __u32 top;
81 __u32 display_width;
82 __u32 display_height;
83 __u32 width;
84 __u32 height;
85 __u32 frame_num;
86 __u32 bit_depth_y;
87 __u32 bit_depth_c;
88 struct msm_vidc_misr_info misr_info[2];
89 };
90
91 #define MSM_VIDC_EXTRADATA_INDEX 0x7F100002
92 struct msm_vidc_extradata_index {
93 __u32 type;
94 union {
95 struct msm_vidc_aspect_ratio_payload aspect_ratio;
96 };
97 };
98
99 #define MSM_VIDC_EXTRADATA_PANSCAN_WINDOW 0x00000008
100 struct msm_vidc_panscan_window {
101 __u32 panscan_height_offset;
102 __u32 panscan_width_offset;
103 __u32 panscan_window_width;
104 __u32 panscan_window_height;
105 };
106 struct msm_vidc_panscan_window_payload {
107 __u32 num_panscan_windows;
108 struct msm_vidc_panscan_window wnd[1];
109 };
110
111
112 #define MSM_VIDC_USERDATA_TYPE_FRAME 0x1
113 #define MSM_VIDC_USERDATA_TYPE_TOP_FIELD 0x2
114 #define MSM_VIDC_USERDATA_TYPE_BOTTOM_FIELD 0x3
115 #define MSM_VIDC_EXTRADATA_STREAM_USERDATA 0x0000000E
116 struct msm_vidc_stream_userdata_payload {
117 __u32 type;
118 __u32 data[1];
119 };
120
121 #define MSM_VIDC_EXTRADATA_FRAME_QP 0x0000000F
122 struct msm_vidc_frame_qp_payload {
123 __u32 frame_qp;
124 __u32 qp_sum;
125 __u32 skip_qp_sum;
126 __u32 skip_num_blocks;
127 __u32 total_num_blocks;
128 };
129
130 #define MSM_VIDC_EXTRADATA_FRAME_BITS_INFO 0x00000010
131 struct msm_vidc_frame_bits_info_payload {
132 __u32 frame_bits;
133 __u32 header_bits;
134 };
135
136 #define MSM_VIDC_EXTRADATA_S3D_FRAME_PACKING 0x00000006
137 struct msm_vidc_s3d_frame_packing_payload {
138 __u32 fpa_id;
139 __u32 cancel_flag;
140 __u32 fpa_type;
141 __u32 quin_cunx_flag;
142 __u32 content_interprtation_type;
143 __u32 spatial_flipping_flag;
144 __u32 frame0_flipped_flag;
145 __u32 field_views_flag;
146 __u32 current_frame_is_frame0_flag;
147 __u32 frame0_self_contained_flag;
148 __u32 frame1_self_contained_flag;
149 __u32 frame0_graid_pos_x;
150 __u32 frame0_graid_pos_y;
151 __u32 frame1_graid_pos_x;
152 __u32 frame1_graid_pos_y;
153 __u32 fpa_reserved_byte;
154 __u32 fpa_repetition_period;
155 __u32 fpa_extension_flag;
156 };
157
158 struct msm_vidc_roi_qp_payload {
159 __s32 upper_qp_offset;
160 __s32 lower_qp_offset;
161 __u32 b_roi_info;
162 __u32 mbi_info_size;
163 __u32 data[1];
164 };
165
166 #define MSM_VIDC_EXTRADATA_ROI_QP 0x00000013
167 struct msm_vidc_roi_deltaqp_payload {
168 __u32 b_roi_info; /*Enable/Disable*/
169 __u32 mbi_info_size; /*Size of QP data*/
170 __u32 data[1];
171 };
172
173 #define MSM_VIDC_EXTRADATA_MASTERING_DISPLAY_COLOUR_SEI 0x00000015
174 struct msm_vidc_mastering_display_colour_sei_payload {
175 __u32 nDisplayPrimariesX[3];
176 __u32 nDisplayPrimariesY[3];
177 __u32 nWhitePointX;
178 __u32 nWhitePointY;
179 __u32 nMaxDisplayMasteringLuminance;
180 __u32 nMinDisplayMasteringLuminance;
181 };
182
183 #define MSM_VIDC_EXTRADATA_CONTENT_LIGHT_LEVEL_SEI 0x00000016
184 struct msm_vidc_content_light_level_sei_payload {
185 __u32 nMaxContentLight;
186 __u32 nMaxPicAverageLight;
187 };
188
189 #define MSM_VIDC_EXTRADATA_HDR10PLUS_METADATA 0x0000001A
190 struct msm_vidc_hdr10plus_metadata_payload {
191 __u32 size;
192 __u32 data[1];
193 };
194
195 #define MSM_VIDC_EXTRADATA_CVP_METADATA 0x0000001B
196 struct msm_vidc_enc_cvp_metadata_payload {
197 __u32 data[256];
198 };
199
200 /* video_format */
201 #define MSM_VIDC_COMPONENT 0
202 #define MSM_VIDC_PAL 1
203 #define MSM_VIDC_NTSC 2
204 #define MSM_VIDC_SECAM 3
205 #define MSM_VIDC_MAC 4
206 #define MSM_VIDC_UNSPECIFIED_FORMAT 5
207 #define MSM_VIDC_RESERVED_1_FORMAT 6
208 #define MSM_VIDC_RESERVED_2_FORMAT 7
209
210 /* See colour_primaries of ISO/IEC 14496 for significance */
211 /* color_primaries values */
212 #define MSM_VIDC_RESERVED_1 0
213 #define MSM_VIDC_BT709_5 1
214 #define MSM_VIDC_UNSPECIFIED 2
215 #define MSM_VIDC_RESERVED_2 3
216 #define MSM_VIDC_BT470_6_M 4
217 #define MSM_VIDC_BT601_6_625 5
218 #define MSM_VIDC_BT470_6_BG MSM_VIDC_BT601_6_625
219 #define MSM_VIDC_BT601_6_525 6
220 #define MSM_VIDC_SMPTE_240M 7
221 #define MSM_VIDC_GENERIC_FILM 8
222 #define MSM_VIDC_BT2020 9
223
224 /* matrix_coeffs values */
225 #define MSM_VIDC_MATRIX_RGB 0
226 #define MSM_VIDC_MATRIX_BT_709_5 1
227 #define MSM_VIDC_MATRIX_UNSPECIFIED 2
228 #define MSM_VIDC_MATRIX_RESERVED 3
229 #define MSM_VIDC_MATRIX_FCC_47 4
230 #define MSM_VIDC_MATRIX_601_6_625 5
231 #define MSM_VIDC_MATRIX_BT470_BG MSM_VIDC_MATRIX_601_6_625
232 #define MSM_VIDC_MATRIX_601_6_525 6
233 #define MSM_VIDC_MATRIX_SMPTE_170M MSM_VIDC_MATRIX_601_6_525
234 #define MSM_VIDC_MATRIX_SMPTE_240M 7
235 #define MSM_VIDC_MATRIX_Y_CG_CO 8
236 #define MSM_VIDC_MATRIX_BT_2020 9
237 #define MSM_VIDC_MATRIX_BT_2020_CONST 10
238
239 /* transfer_char values */
240 #define MSM_VIDC_TRANSFER_RESERVED_1 0
241 #define MSM_VIDC_TRANSFER_BT709_5 1
242 #define MSM_VIDC_TRANSFER_UNSPECIFIED 2
243 #define MSM_VIDC_TRANSFER_RESERVED_2 3
244 #define MSM_VIDC_TRANSFER_BT_470_6_M 4
245 #define MSM_VIDC_TRANSFER_BT_470_6_BG 5
246 #define MSM_VIDC_TRANSFER_601_6_625 6
247 #define MSM_VIDC_TRANSFER_601_6_525 MSM_VIDC_TRANSFER_601_6_625
248 #define MSM_VIDC_TRANSFER_SMPTE_240M 7
249 #define MSM_VIDC_TRANSFER_LINEAR 8
250 #define MSM_VIDC_TRANSFER_LOG_100_1 9
251 #define MSM_VIDC_TRANSFER_LOG_100_SQRT10_1 10
252 #define MSM_VIDC_TRANSFER_IEC_61966 11
253 #define MSM_VIDC_TRANSFER_BT_1361 12
254 #define MSM_VIDC_TRANSFER_SRGB 13
255 #define MSM_VIDC_TRANSFER_BT_2020_10 14
256 #define MSM_VIDC_TRANSFER_BT_2020_12 15
257 #define MSM_VIDC_TRANSFER_SMPTE_ST2084 16
258 #define MSM_VIDC_TRANSFER_SMPTE_ST428_1 17
259 #define MSM_VIDC_TRANSFER_HLG 18
260
261 #define MSM_VIDC_EXTRADATA_VUI_DISPLAY_INFO 0x7F100006
262 struct msm_vidc_vui_display_info_payload {
263 __u32 video_signal_present_flag;
264 __u32 video_format;
265 __u32 bit_depth_y;
266 __u32 bit_depth_c;
267 __u32 video_full_range_flag;
268 __u32 color_description_present_flag;
269 __u32 color_primaries;
270 __u32 transfer_char;
271 __u32 matrix_coeffs;
272 __u32 chroma_location_info_present_flag;
273 __u32 chroma_format_idc;
274 __u32 separate_color_plane_flag;
275 __u32 chroma_sample_loc_type_top_field;
276 __u32 chroma_sample_loc_type_bottom_field;
277 };
278
279 #define MSM_VIDC_EXTRADATA_HDR_HIST 0x7F100008
280 struct msm_vidc_extradata_hdr_hist_payload {
281 __u32 value_count[1024];
282 };
283
284 #define MSM_VIDC_EXTRADATA_MPEG2_SEQDISP 0x0000000D
285 struct msm_vidc_mpeg2_seqdisp_payload {
286 __u32 video_format;
287 __u32 color_descp;
288 __u32 color_primaries;
289 __u32 transfer_char;
290 __u32 matrix_coeffs;
291 __u32 disp_width;
292 __u32 disp_height;
293 };
294
295 /* VPx color_space values */
296 #define MSM_VIDC_CS_UNKNOWN 0
297 #define MSM_VIDC_CS_BT_601 1
298 #define MSM_VIDC_CS_BT_709 2
299 #define MSM_VIDC_CS_SMPTE_170 3
300 #define MSM_VIDC_CS_SMPTE_240 4
301 #define MSM_VIDC_CS_BT_2020 5
302 #define MSM_VIDC_CS_RESERVED 6
303 #define MSM_VIDC_CS_RGB 7
304 #define MSM_VIDC_EXTRADATA_VPX_COLORSPACE_INFO 0x00000014
305 struct msm_vidc_vpx_colorspace_payload {
306 __u32 color_space;
307 __u32 yuv_range_flag;
308 __u32 sumsampling_x;
309 __u32 sumsampling_y;
310 };
311
312 #define MSM_VIDC_EXTRADATA_METADATA_LTRINFO 0x7F100004
313 /* Don't use the #define below. It is to bypass checkpatch */
314 #define LTRINFO MSM_VIDC_EXTRADATA_METADATA_LTRINFO
315 struct msm_vidc_metadata_ltr_payload {
316 __u32 ltr_use_mark;
317 };
318
319 /* ptr[2]: event_notify: pixel_depth */
320 #define MSM_VIDC_BIT_DEPTH_8 0
321 #define MSM_VIDC_BIT_DEPTH_10 1
322 #define MSM_VIDC_BIT_DEPTH_UNSUPPORTED 0XFFFFFFFF
323
324 /* ptr[3]: event_notify: pic_struct */
325 #define MSM_VIDC_PIC_STRUCT_MAYBE_INTERLACED 0x0
326 #define MSM_VIDC_PIC_STRUCT_PROGRESSIVE 0x1
327
328 /*default when layer ID isn't specified*/
329 #define MSM_VIDC_ALL_LAYER_ID 0xFF
330
VENUS_EXTRADATA_SIZE(int width,int height)331 static __inline__ unsigned int VENUS_EXTRADATA_SIZE(int width, int height)
332 {
333 (void)height;
334 (void)width;
335
336 /*
337 * In the future, calculate the size based on the w/h but just
338 * hardcode it for now since 16K satisfies all current usecases.
339 */
340 return 16 * 1024;
341 }
342
343 /* V4L2_CID_MPEG_VIDC_VENC_HDR_INFO payload index */
344 enum msm_vidc_hdr_info_types {
345 MSM_VIDC_RGB_PRIMARY_00,
346 MSM_VIDC_RGB_PRIMARY_01,
347 MSM_VIDC_RGB_PRIMARY_10,
348 MSM_VIDC_RGB_PRIMARY_11,
349 MSM_VIDC_RGB_PRIMARY_20,
350 MSM_VIDC_RGB_PRIMARY_21,
351 MSM_VIDC_WHITEPOINT_X,
352 MSM_VIDC_WHITEPOINT_Y,
353 MSM_VIDC_MAX_DISP_LUM,
354 MSM_VIDC_MIN_DISP_LUM,
355 MSM_VIDC_RGB_MAX_CLL,
356 MSM_VIDC_RGB_MAX_FLL,
357 };
358
359 enum msm_vidc_plane_reserved_field_types {
360 MSM_VIDC_BUFFER_FD,
361 MSM_VIDC_DATA_OFFSET,
362 MSM_VIDC_COMP_RATIO,
363 MSM_VIDC_INPUT_TAG_1,
364 MSM_VIDC_INPUT_TAG_2,
365 };
366
367 enum msm_vidc_cb_event_types {
368 MSM_VIDC_HEIGHT,
369 MSM_VIDC_WIDTH,
370 MSM_VIDC_BIT_DEPTH,
371 MSM_VIDC_PIC_STRUCT,
372 MSM_VIDC_COLOR_SPACE,
373 MSM_VIDC_FW_MIN_COUNT,
374 };
375 #endif
376