00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023 #ifndef AVCODEC_VC1_H
00024 #define AVCODEC_VC1_H
00025
00026 #include "avcodec.h"
00027 #include "mpegvideo.h"
00028 #include "intrax8.h"
00029
00032 enum VC1Code{
00033 VC1_CODE_RES0 = 0x00000100,
00034 VC1_CODE_ENDOFSEQ = 0x0000010A,
00035 VC1_CODE_SLICE,
00036 VC1_CODE_FIELD,
00037 VC1_CODE_FRAME,
00038 VC1_CODE_ENTRYPOINT,
00039 VC1_CODE_SEQHDR,
00040 };
00042
00043 #define IS_MARKER(x) (((x) & ~0xFF) == VC1_CODE_RES0)
00044
00047 enum Profile {
00048 PROFILE_SIMPLE,
00049 PROFILE_MAIN,
00050 PROFILE_COMPLEX,
00051 PROFILE_ADVANCED
00052 };
00054
00057 enum QuantMode {
00058 QUANT_FRAME_IMPLICIT,
00059 QUANT_FRAME_EXPLICIT,
00060 QUANT_NON_UNIFORM,
00061 QUANT_UNIFORM
00062 };
00064
00067 enum DQProfile {
00068 DQPROFILE_FOUR_EDGES,
00069 DQPROFILE_DOUBLE_EDGES,
00070 DQPROFILE_SINGLE_EDGE,
00071 DQPROFILE_ALL_MBS
00072 };
00074
00078 enum DQSingleEdge {
00079 DQSINGLE_BEDGE_LEFT,
00080 DQSINGLE_BEDGE_TOP,
00081 DQSINGLE_BEDGE_RIGHT,
00082 DQSINGLE_BEDGE_BOTTOM
00083 };
00085
00088 enum DQDoubleEdge {
00089 DQDOUBLE_BEDGE_TOPLEFT,
00090 DQDOUBLE_BEDGE_TOPRIGHT,
00091 DQDOUBLE_BEDGE_BOTTOMRIGHT,
00092 DQDOUBLE_BEDGE_BOTTOMLEFT
00093 };
00095
00098 enum MVModes {
00099 MV_PMODE_1MV_HPEL_BILIN,
00100 MV_PMODE_1MV,
00101 MV_PMODE_1MV_HPEL,
00102 MV_PMODE_MIXED_MV,
00103 MV_PMODE_INTENSITY_COMP
00104 };
00106
00109 enum BMVTypes {
00110 BMV_TYPE_BACKWARD,
00111 BMV_TYPE_FORWARD,
00112 BMV_TYPE_INTERPOLATED
00113 };
00115
00118 enum TransformTypes {
00119 TT_8X8,
00120 TT_8X4_BOTTOM,
00121 TT_8X4_TOP,
00122 TT_8X4,
00123 TT_4X8_RIGHT,
00124 TT_4X8_LEFT,
00125 TT_4X8,
00126 TT_4X4
00127 };
00129
00130 enum CodingSet {
00131 CS_HIGH_MOT_INTRA = 0,
00132 CS_HIGH_MOT_INTER,
00133 CS_LOW_MOT_INTRA,
00134 CS_LOW_MOT_INTER,
00135 CS_MID_RATE_INTRA,
00136 CS_MID_RATE_INTER,
00137 CS_HIGH_RATE_INTRA,
00138 CS_HIGH_RATE_INTER
00139 };
00140
00143 enum COTypes {
00144 CONDOVER_NONE = 0,
00145 CONDOVER_ALL,
00146 CONDOVER_SELECT
00147 };
00149
00150
00155 typedef struct VC1Context{
00156 MpegEncContext s;
00157 IntraX8Context x8;
00158
00159 int bits;
00160
00163 int res_sprite;
00164 int res_y411;
00165 int res_x8;
00166 int multires;
00167 int res_fasttx;
00168 int res_transtab;
00169 int rangered;
00170
00171 int res_rtm_flag;
00172 int reserved;
00173
00174
00177 int level;
00178 int chromaformat;
00179 int postprocflag;
00180 int broadcast;
00181 int interlace;
00182 int tfcntrflag;
00183 int panscanflag;
00184 int refdist_flag;
00185 int extended_dmv;
00186 int color_prim;
00187 int transfer_char;
00188 int matrix_coef;
00189 int hrd_param_flag;
00190
00191 int psf;
00192
00193
00198 int profile;
00199 int frmrtq_postproc;
00200 int bitrtq_postproc;
00201 int fastuvmc;
00202 int extended_mv;
00203 int dquant;
00204 int vstransform;
00205 int overlap;
00206 int quantizer_mode;
00207 int finterpflag;
00208
00209
00212 uint8_t mv_mode;
00213 uint8_t mv_mode2;
00214 int k_x;
00215 int k_y;
00216 int range_x, range_y;
00217 uint8_t pq, altpq;
00218 const uint8_t* zz_8x4;
00219 const uint8_t* zz_4x8;
00220
00222 uint8_t dquantfrm;
00223 uint8_t dqprofile;
00224 uint8_t dqsbedge;
00225 uint8_t dqbilevel;
00227
00231 int c_ac_table_index;
00232 int y_ac_table_index;
00233
00234 int ttfrm;
00235 uint8_t ttmbf;
00236 uint8_t ttblk4x4;
00237 int codingset;
00238 int codingset2;
00239 int pqindex;
00240 int a_avail, c_avail;
00241 uint8_t *mb_type_base, *mb_type[3];
00242
00243
00246 uint8_t lumscale;
00247 uint8_t lumshift;
00249 int16_t bfraction;
00250 uint8_t halfpq;
00251 uint8_t respic;
00252 int buffer_fullness;
00253
00259 uint8_t mvrange;
00260 uint8_t pquantizer;
00261 VLC *cbpcy_vlc;
00262 int tt_index;
00263 uint8_t* mv_type_mb_plane;
00264 uint8_t* direct_mb_plane;
00265 int mv_type_is_raw;
00266 int dmb_is_raw;
00267 int skip_is_raw;
00268 uint8_t luty[256], lutuv[256];
00269 int use_ic;
00270 int rnd;
00271
00274 uint8_t rangeredfrm;
00275 uint8_t interpfrm;
00277
00280 uint8_t fcm;
00281 uint8_t numpanscanwin;
00282 uint8_t tfcntr;
00283 uint8_t rptfrm, tff, rff;
00284 uint16_t topleftx;
00285 uint16_t toplefty;
00286 uint16_t bottomrightx;
00287 uint16_t bottomrighty;
00288 uint8_t uvsamp;
00289 uint8_t postproc;
00290 int hrd_num_leaky_buckets;
00291 uint8_t bit_rate_exponent;
00292 uint8_t buffer_size_exponent;
00293 uint8_t* acpred_plane;
00294 int acpred_is_raw;
00295 uint8_t* over_flags_plane;
00296 int overflg_is_raw;
00297 uint8_t condover;
00298 uint16_t *hrd_rate, *hrd_buffer;
00299 uint8_t *hrd_fullness;
00300 uint8_t range_mapy_flag;
00301 uint8_t range_mapuv_flag;
00302 uint8_t range_mapy;
00303 uint8_t range_mapuv;
00305
00306 int p_frame_skipped;
00307 int bi_type;
00308 int x8_type;
00309
00310 uint32_t *cbp_base, *cbp;
00311 uint8_t bfraction_lut_index;
00312 uint8_t broken_link;
00313 uint8_t closed_entry;
00314
00315 int parse_only;
00316
00317 int warn_interlaced;
00318 } VC1Context;
00319
00323 static av_always_inline const uint8_t* find_next_marker(const uint8_t *src, const uint8_t *end)
00324 {
00325 uint32_t mrk = 0xFFFFFFFF;
00326
00327 if(end-src < 4) return end;
00328 while(src < end){
00329 mrk = (mrk << 8) | *src++;
00330 if(IS_MARKER(mrk))
00331 return src-4;
00332 }
00333 return end;
00334 }
00335
00336 static av_always_inline int vc1_unescape_buffer(const uint8_t *src, int size, uint8_t *dst)
00337 {
00338 int dsize = 0, i;
00339
00340 if(size < 4){
00341 for(dsize = 0; dsize < size; dsize++) *dst++ = *src++;
00342 return size;
00343 }
00344 for(i = 0; i < size; i++, src++) {
00345 if(src[0] == 3 && i >= 2 && !src[-1] && !src[-2] && i < size-1 && src[1] < 4) {
00346 dst[dsize++] = src[1];
00347 src++;
00348 i++;
00349 } else
00350 dst[dsize++] = *src;
00351 }
00352 return dsize;
00353 }
00354
00362 int vc1_decode_sequence_header(AVCodecContext *avctx, VC1Context *v, GetBitContext *gb);
00363
00364 int vc1_decode_entry_point(AVCodecContext *avctx, VC1Context *v, GetBitContext *gb);
00365
00366 int vc1_parse_frame_header (VC1Context *v, GetBitContext *gb);
00367 int vc1_parse_frame_header_adv(VC1Context *v, GetBitContext *gb);
00368
00369 #endif