28 |
* ToDo ? : when BFRAMES is defined, the API_VERSION should not |
* ToDo ? : when BFRAMES is defined, the API_VERSION should not |
29 |
* be the same (3.0 ?) |
* be the same (3.0 ?) |
30 |
* |
* |
31 |
* $Id: xvid.h,v 1.15 2002-07-19 11:15:21 albeu Exp $ |
* $Id: xvid.h,v 1.17.2.24 2003-01-14 10:30:39 chl Exp $ |
32 |
* |
* |
33 |
*****************************************************************************/ |
*****************************************************************************/ |
34 |
|
|
37 |
#define _XVID_H_ |
#define _XVID_H_ |
38 |
|
|
39 |
#ifdef __cplusplus |
#ifdef __cplusplus |
40 |
* $Id: xvid.h,v 1.15 2002-07-19 11:15:21 albeu Exp $ |
extern "C" { |
41 |
#endif |
#endif |
42 |
|
|
43 |
/***************************************************************************** |
/***************************************************************************** |
46 |
|
|
47 |
/* API Version : 2.1 */ |
/* API Version : 2.1 */ |
48 |
#define API_VERSION ((2 << 16) | (1)) |
#define API_VERSION ((2 << 16) | (1)) |
49 |
|
#define XVID_API_UNSTABLE |
50 |
|
|
51 |
|
/* Bitstream Version |
52 |
|
* this will be writen into the bitstream to allow easy detection of xvid |
53 |
|
* encoder bugs in the decoder, without this it might not possible to |
54 |
|
* automatically distinquish between a file which has been encoded with an |
55 |
|
* old & buggy XVID from a file which has been encoded with a bugfree version |
56 |
|
* see the infamous interlacing bug ... |
57 |
|
* |
58 |
|
* this MUST be increased if an encoder bug is fixed, increasing it too often |
59 |
|
* doesnt hurt but not increasing it could cause difficulty for decoders in the |
60 |
|
* future |
61 |
|
*/ |
62 |
|
#define XVID_BS_VERSION "0008" |
63 |
|
|
64 |
|
|
65 |
/* Error codes */ |
/* Error codes */ |
70 |
|
|
71 |
|
|
72 |
/* Colorspaces */ |
/* Colorspaces */ |
73 |
#define XVID_CSP_RGB24 0 |
#define XVID_CSP_RGB24 0 /* [b|g|r] */ |
74 |
#define XVID_CSP_YV12 1 |
#define XVID_CSP_YV12 1 |
75 |
#define XVID_CSP_YUY2 2 |
#define XVID_CSP_YUY2 2 |
76 |
#define XVID_CSP_UYVY 3 |
#define XVID_CSP_UYVY 3 |
80 |
#define XVID_CSP_USER 12 |
#define XVID_CSP_USER 12 |
81 |
#define XVID_CSP_EXTERN 1004 // per slice rendering |
#define XVID_CSP_EXTERN 1004 // per slice rendering |
82 |
#define XVID_CSP_YVYU 1002 |
#define XVID_CSP_YVYU 1002 |
83 |
#define XVID_CSP_RGB32 1000 |
#define XVID_CSP_RGB32 1000 /* [b|g|r|a] */ |
84 |
|
#define XVID_CSP_ABGR 1006 /* [a|b|g|r] */ |
85 |
|
#define XVID_CSP_RGBA 1005 /* [r|g|b|a] */ |
86 |
|
|
87 |
|
|
88 |
|
|
89 |
#define XVID_CSP_NULL 9999 |
#define XVID_CSP_NULL 9999 |
90 |
|
|
91 |
#define XVID_CSP_VFLIP 0x80000000 // flip mask |
#define XVID_CSP_VFLIP 0x80000000 // flip mask |
96 |
****************************************************************************/ |
****************************************************************************/ |
97 |
|
|
98 |
/* CPU flags for XVID_INIT_PARAM.cpu_flags */ |
/* CPU flags for XVID_INIT_PARAM.cpu_flags */ |
99 |
|
#define XVID_CPU_FORCE 0x80000000 |
100 |
|
#define XVID_CPU_CHKONLY 0x40000000 /* check cpu only; dont init globals */ |
101 |
|
|
102 |
#define XVID_CPU_MMX 0x00000001 |
#define XVID_CPU_ASM 0x00000080 /* native assembly */ |
103 |
#define XVID_CPU_MMXEXT 0x00000002 |
/* ARCH_X86 */ |
104 |
#define XVID_CPU_SSE 0x00000004 |
#define XVID_CPU_MMX 0x00000001 /* mmx: pentiumMMX,k6 */ |
105 |
#define XVID_CPU_SSE2 0x00000008 |
#define XVID_CPU_MMXEXT 0x00000002 /* mmxx-ext: pentium2,athlon */ |
106 |
#define XVID_CPU_3DNOW 0x00000010 |
#define XVID_CPU_SSE 0x00000004 /* sse: pentium3,athlonXP */ |
107 |
#define XVID_CPU_3DNOWEXT 0x00000020 |
#define XVID_CPU_SSE2 0x00000008 /* sse2: pentium4,athlon64 */ |
108 |
|
#define XVID_CPU_3DNOW 0x00000010 /* 3dnow: k6-2 */ |
109 |
#define XVID_CPU_TSC 0x00000040 |
#define XVID_CPU_3DNOWEXT 0x00000020 /* 3dnow-ext: athlon */ |
110 |
|
#define XVID_CPU_TSC 0x00000040 /* timestamp counter */ |
111 |
#define XVID_CPU_IA64 0x00000080 |
/* ARCH_IA64 */ |
112 |
|
#define XVID_CPU_IA64 XVID_CPU_ASM /* defined for backward compatibility */ |
113 |
|
/* ARCH_PPC */ |
114 |
|
#define XVID_CPU_ALTIVEC 0x00000001 /* altivec */ |
115 |
|
|
|
#define XVID_CPU_CHKONLY 0x40000000 /* check cpu only; dont init globals */ |
|
|
#define XVID_CPU_FORCE 0x80000000 |
|
116 |
|
|
117 |
|
typedef struct |
118 |
|
{ |
119 |
|
int colorspace; |
120 |
|
void * y; |
121 |
|
void * u; |
122 |
|
void * v; |
123 |
|
int y_stride; |
124 |
|
int uv_stride; |
125 |
|
} XVID_IMAGE; /* from yv12 */ |
126 |
|
|
127 |
|
#define XVID_INIT_INIT 0 |
128 |
|
#define XVID_INIT_CONVERT 1 |
129 |
|
#define XVID_INIT_TEST 2 |
130 |
|
|
131 |
/***************************************************************************** |
/***************************************************************************** |
132 |
* Initialization structures |
* Initialization structures |
140 |
} |
} |
141 |
XVID_INIT_PARAM; |
XVID_INIT_PARAM; |
142 |
|
|
143 |
|
typedef struct |
144 |
|
{ |
145 |
|
XVID_IMAGE input; |
146 |
|
XVID_IMAGE output; |
147 |
|
int width; |
148 |
|
int height; |
149 |
|
int interlacing; |
150 |
|
} XVID_INIT_CONVERTINFO; |
151 |
|
|
152 |
/***************************************************************************** |
/***************************************************************************** |
153 |
* Initialization entry point |
* Initialization entry point |
154 |
****************************************************************************/ |
****************************************************************************/ |
164 |
****************************************************************************/ |
****************************************************************************/ |
165 |
|
|
166 |
/* Flags for XVID_DEC_FRAME.general */ |
/* Flags for XVID_DEC_FRAME.general */ |
167 |
|
#define XVID_DEC_LOWDELAY 0x00000001 /* decode lowdelay mode (ie. video-for-windows) */ |
168 |
|
#define XVID_DEC_DEBLOCKY 0x00000002 /* luma deblocking */ |
169 |
|
#define XVID_DEC_DEBLOCKUV 0x00000008 /* chroma deblocking */ |
170 |
|
#define XVID_DEC_DISCONTINUITY 0x00000004 /* indicates break in stream; instructs |
171 |
|
decoder to ignore any previous reference frames */ |
172 |
#define XVID_QUICK_DECODE 0x00000010 |
#define XVID_QUICK_DECODE 0x00000010 |
173 |
|
|
174 |
/***************************************************************************** |
/***************************************************************************** |
184 |
XVID_DEC_PARAM; |
XVID_DEC_PARAM; |
185 |
|
|
186 |
|
|
187 |
|
#define XVID_DEC_VOP 0 |
188 |
|
#define XVID_DEC_VOL 1 |
189 |
|
#define XVID_DEC_NOTHING 2 /* nothing was decoded */ |
190 |
|
|
191 |
|
typedef struct |
192 |
|
{ |
193 |
|
int notify; /* [out] output 'mode' */ |
194 |
|
union |
195 |
|
{ |
196 |
|
struct /* XVID_DEC_VOP */ |
197 |
|
{ |
198 |
|
int time_base; /* [out] time base */ |
199 |
|
int time_increment; /* [out] time increment */ |
200 |
|
} vop; |
201 |
|
struct /* XVID_DEC_VOL */ |
202 |
|
{ |
203 |
|
int general; /* [out] flags: eg. frames are interlaced */ |
204 |
|
int width; /* [out] width */ |
205 |
|
int height; /* [out] height */ |
206 |
|
int aspect_ratio; /* [out] aspect ratio */ |
207 |
|
int par_width; /* [out] aspect ratio width */ |
208 |
|
int par_height; /* [out] aspect ratio height */ |
209 |
|
} vol; |
210 |
|
} data; |
211 |
|
} XVID_DEC_STATS; |
212 |
|
|
213 |
|
|
214 |
typedef struct |
typedef struct |
215 |
{ |
{ |
216 |
int general; |
int general; |
255 |
#define XVID_GLOBAL_PACKED 0x00000001 /* packed bitstream */ |
#define XVID_GLOBAL_PACKED 0x00000001 /* packed bitstream */ |
256 |
#define XVID_GLOBAL_DX50BVOP 0x00000002 /* dx50 bvop compatibility */ |
#define XVID_GLOBAL_DX50BVOP 0x00000002 /* dx50 bvop compatibility */ |
257 |
#define XVID_GLOBAL_DEBUG 0x00000004 /* print debug info on each frame */ |
#define XVID_GLOBAL_DEBUG 0x00000004 /* print debug info on each frame */ |
258 |
|
#define XVID_GLOBAL_REDUCED 0x04000000 /* reduced resolution vop enable */ |
259 |
|
|
260 |
/* Flags for XVID_ENC_FRAME.general */ |
/* Flags for XVID_ENC_FRAME.general */ |
261 |
#define XVID_VALID_FLAGS 0x80000000 |
#define XVID_VALID_FLAGS 0x80000000 |
264 |
#define XVID_H263QUANT 0x00000010 |
#define XVID_H263QUANT 0x00000010 |
265 |
#define XVID_MPEGQUANT 0x00000020 |
#define XVID_MPEGQUANT 0x00000020 |
266 |
#define XVID_HALFPEL 0x00000040 /* use halfpel interpolation */ |
#define XVID_HALFPEL 0x00000040 /* use halfpel interpolation */ |
267 |
|
#define XVID_QUARTERPEL 0x02000000 |
268 |
#define XVID_ADAPTIVEQUANT 0x00000080 |
#define XVID_ADAPTIVEQUANT 0x00000080 |
269 |
#define XVID_LUMIMASKING 0x00000100 |
#define XVID_LUMIMASKING 0x00000100 |
270 |
#define XVID_LATEINTRA 0x00000200 |
#define XVID_LATEINTRA 0x00000200 |
284 |
#define XVID_ME_PMVFAST 0x00080000 |
#define XVID_ME_PMVFAST 0x00080000 |
285 |
#define XVID_ME_EPZS 0x00100000 |
#define XVID_ME_EPZS 0x00100000 |
286 |
|
|
|
|
|
287 |
#define XVID_GREYSCALE 0x01000000 /* enable greyscale only mode (even for */ |
#define XVID_GREYSCALE 0x01000000 /* enable greyscale only mode (even for */ |
288 |
#define XVID_GRAYSCALE 0x01000000 /* color input material chroma is ignored) */ |
#define XVID_GRAYSCALE 0x01000000 /* color input material chroma is ignored) */ |
289 |
|
|
290 |
|
#define XVID_GMC 0x10000000 |
291 |
|
#define XVID_GMC_TRANSLATIONAL 0x20000000 |
292 |
|
|
293 |
|
#define XVID_REDUCED 0x04000000 /* reduced resolution vop */ |
294 |
|
|
295 |
/* Flags for XVID_ENC_FRAME.motion */ |
/* Flags for XVID_ENC_FRAME.motion */ |
296 |
#define PMV_ADVANCEDDIAMOND8 0x00004000 |
#define PMV_ADVANCEDDIAMOND8 0x00004000 |
297 |
#define PMV_ADVANCEDDIAMOND16 0x00008000 |
#define PMV_ADVANCEDDIAMOND16 0x00008000 |
298 |
#define PMV_EARLYSTOP16 0x00080000 |
|
299 |
#define PMV_QUICKSTOP16 0x00100000 /* like early, but without any more refinement */ |
#define PMV_HALFPELDIAMOND16 0x00010000 |
300 |
|
#define PMV_HALFPELREFINE16 0x00020000 |
301 |
|
#define PMV_QUARTERPELREFINE16 0x00040000 |
302 |
|
#define PMV_EXTSEARCH16 0x00080000 /* extend PMV by more searches */ |
303 |
|
|
304 |
|
#define PMV_CHROMA16 0x00100000 /* also use chroma for MB-ME */ |
305 |
#define PMV_UNRESTRICTED16 0x00200000 /* unrestricted ME, not implemented */ |
#define PMV_UNRESTRICTED16 0x00200000 /* unrestricted ME, not implemented */ |
306 |
#define PMV_OVERLAPPING16 0x00400000 /* overlapping ME, not implemented */ |
#define PMV_OVERLAPPING16 0x00400000 /* overlapping ME, not implemented */ |
307 |
#define PMV_USESQUARES16 0x00800000 |
#define PMV_USESQUARES16 0x00800000 /* use squares instead of diamonds as search pattern */ |
308 |
|
|
309 |
#define PMV_HALFPELDIAMOND8 0x01000000 |
#define PMV_HALFPELDIAMOND8 0x01000000 |
310 |
#define PMV_HALFPELREFINE8 0x02000000 |
#define PMV_HALFPELREFINE8 0x02000000 |
311 |
#define PMV_EXTSEARCH8 0x04000000 /* extend PMV by more searches */ |
#define PMV_QUARTERPELREFINE8 0x04000000 |
312 |
#define PMV_EARLYSTOP8 0x08000000 |
#define PMV_EXTSEARCH8 0x08000000 /* extend PMV by more searches */ |
313 |
#define PMV_QUICKSTOP8 0x10000000 /* like early, but without any more refinement */ |
|
314 |
|
#define PMV_CHROMA8 0x10000000 /* also use chroma for B-ME */ |
315 |
#define PMV_UNRESTRICTED8 0x20000000 /* unrestricted ME, not implemented */ |
#define PMV_UNRESTRICTED8 0x20000000 /* unrestricted ME, not implemented */ |
316 |
#define PMV_OVERLAPPING8 0x40000000 /* overlapping ME, not implemented */ |
#define PMV_OVERLAPPING8 0x40000000 /* overlapping ME, not implemented */ |
317 |
#define PMV_USESQUARES8 0x80000000 |
#define PMV_USESQUARES8 0x80000000 |
318 |
|
|
319 |
|
|
320 |
|
/* note: old and deprecated */ |
321 |
|
|
322 |
|
/* only for compatability with old encoders */ |
323 |
|
|
324 |
|
#define PMV_EARLYSTOP16 0x00 |
325 |
|
#define PMV_EARLYSTOP8 0x00 |
326 |
|
#define PMV_QUICKSTOP16 0x00 |
327 |
|
#define PMV_QUICKSTOP8 0x00 |
328 |
|
|
329 |
|
#define XVID_ME_COLOUR 0x00 /* this has been converted to PMV_COLOUR[16/8] */ |
330 |
|
|
331 |
|
|
332 |
/***************************************************************************** |
/***************************************************************************** |
333 |
* Encoder structures |
* Encoder structures |
334 |
****************************************************************************/ |
****************************************************************************/ |
347 |
#ifdef _SMP |
#ifdef _SMP |
348 |
int num_threads; /* number of threads */ |
int num_threads; /* number of threads */ |
349 |
#endif |
#endif |
|
#ifdef BFRAMES |
|
350 |
int global; /* global/debug options */ |
int global; /* global/debug options */ |
351 |
int max_bframes; /* max sequential bframes (0=disable bframes) */ |
int max_bframes; /* max sequential bframes (0=disable bframes) */ |
352 |
int bquant_ratio; /* bframe quantizer multipier (percentage). |
int bquant_ratio; /* bframe quantizer multipier (percentage). |
354 |
* eg. 200 = x2 multiplier |
* eg. 200 = x2 multiplier |
355 |
* quant = ((past_quant + future_quant) * bquant_ratio)/200 |
* quant = ((past_quant + future_quant) * bquant_ratio)/200 |
356 |
*/ |
*/ |
357 |
|
int bquant_offset; /* bquant += bquant_offset */ |
358 |
int frame_drop_ratio; /* frame dropping: 0=drop none... 100=drop all */ |
int frame_drop_ratio; /* frame dropping: 0=drop none... 100=drop all */ |
|
#endif |
|
359 |
void *handle; /* [out] encoder instance handle */ |
void *handle; /* [out] encoder instance handle */ |
360 |
} |
} |
361 |
XVID_ENC_PARAM; |
XVID_ENC_PARAM; |
363 |
typedef struct |
typedef struct |
364 |
{ |
{ |
365 |
int x; |
int x; |
366 |
|
int y; |
367 |
} |
} |
368 |
VECTOR; |
VECTOR; |
369 |
|
|
400 |
int length; /* [out] bitstream length (bytes) */ |
int length; /* [out] bitstream length (bytes) */ |
401 |
|
|
402 |
void *image; /* [in] image ptr */ |
void *image; /* [in] image ptr */ |
403 |
|
int stride; |
404 |
int colorspace; /* [in] source colorspace */ |
int colorspace; /* [in] source colorspace */ |
405 |
|
|
406 |
unsigned char *quant_intra_matrix; // [in] custom intra qmatrix */ |
unsigned char *quant_intra_matrix; // [in] custom intra qmatrix */ |
411 |
*/ |
*/ |
412 |
HINTINFO hint; /* [in/out] mv hint information */ |
HINTINFO hint; /* [in/out] mv hint information */ |
413 |
|
|
|
#ifdef BFRAMES |
|
414 |
int bquant; /* [in] bframe quantizer */ |
int bquant; /* [in] bframe quantizer */ |
|
#endif |
|
415 |
|
|
416 |
} |
} |
417 |
XVID_ENC_FRAME; |
XVID_ENC_FRAME; |
422 |
int quant; /* [out] frame quantizer */ |
int quant; /* [out] frame quantizer */ |
423 |
int hlength; /* [out] header length (bytes) */ |
int hlength; /* [out] header length (bytes) */ |
424 |
int kblks, mblks, ublks; /* [out] */ |
int kblks, mblks, ublks; /* [out] */ |
|
|
|
425 |
} |
} |
426 |
XVID_ENC_STATS; |
XVID_ENC_STATS; |
427 |
|
|