2 * MPEG1 codec / MPEG2 decoder
3 * Copyright (c) 2000,2001 Fabrice Bellard.
4 * Copyright (c) 2002-2004 Michael Niedermayer <michaelni@gmx.at>
6 * This library is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU Lesser General Public
8 * License as published by the Free Software Foundation; either
9 * version 2 of the License, or (at your option) any later version.
11 * This library is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 * Lesser General Public License for more details.
16 * You should have received a copy of the GNU Lesser General Public
17 * License along with this library; if not, write to the Free Software
18 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
29 #include "mpegvideo.h"
31 #include "mpeg12data.h"
38 #define SEQ_END_CODE 0x000001b7
39 #define SEQ_START_CODE 0x000001b3
40 #define GOP_START_CODE 0x000001b8
41 #define PICTURE_START_CODE 0x00000100
42 #define SLICE_MIN_START_CODE 0x00000101
43 #define SLICE_MAX_START_CODE 0x000001af
44 #define EXT_START_CODE 0x000001b5
45 #define USER_START_CODE 0x000001b2
49 #define MBINCR_VLC_BITS 9
50 #define MB_PAT_VLC_BITS 9
51 #define MB_PTYPE_VLC_BITS 6
52 #define MB_BTYPE_VLC_BITS 6
53 #define TEX_VLC_BITS 9
55 #ifdef CONFIG_ENCODERS
56 static void mpeg1_encode_block(MpegEncContext *s,
59 static void mpeg1_encode_motion(MpegEncContext *s, int val, int f_or_b_code); // RAL: f_code parameter added
60 #endif //CONFIG_ENCODERS
61 static inline int mpeg1_decode_block_inter(MpegEncContext *s,
64 static inline int mpeg1_decode_block_intra(MpegEncContext *s,
67 static inline int mpeg2_decode_block_non_intra(MpegEncContext *s,
70 static inline int mpeg2_decode_block_intra(MpegEncContext *s,
73 static int mpeg_decode_motion(MpegEncContext *s, int fcode, int pred);
74 static void exchange_uv(MpegEncContext *s);
77 extern int XVMC_field_start(MpegEncContext *s, AVCodecContext *avctx);
78 extern int XVMC_field_end(MpegEncContext *s);
79 extern void XVMC_pack_pblocks(MpegEncContext *s,int cbp);
80 extern void XVMC_init_block(MpegEncContext *s);//set s->block
83 #ifdef CONFIG_ENCODERS
84 static uint8_t (*mv_penalty)[MAX_MV*2+1]= NULL;
85 static uint8_t fcode_tab[MAX_MV*2+1];
87 static uint32_t uni_mpeg1_ac_vlc_bits[64*64*2];
88 static uint8_t uni_mpeg1_ac_vlc_len [64*64*2];
90 /* simple include everything table for dc, first byte is bits number next 3 are code*/
91 static uint32_t mpeg1_lum_dc_uni[512];
92 static uint32_t mpeg1_chr_dc_uni[512];
94 static uint8_t mpeg1_index_run[2][64];
95 static int8_t mpeg1_max_level[2][64];
96 #endif //CONFIG_ENCODERS
98 static void init_2d_vlc_rl(RLTable *rl)
102 init_vlc(&rl->vlc, TEX_VLC_BITS, rl->n + 2,
103 &rl->table_vlc[0][1], 4, 2,
104 &rl->table_vlc[0][0], 4, 2);
107 rl->rl_vlc[0]= av_malloc(rl->vlc.table_size*sizeof(RL_VLC_ELEM));
108 for(i=0; i<rl->vlc.table_size; i++){
109 int code= rl->vlc.table[i][0];
110 int len = rl->vlc.table[i][1];
113 if(len==0){ // illegal code
116 }else if(len<0){ //more bits needed
120 if(code==rl->n){ //esc
123 }else if(code==rl->n+1){ //eob
127 run= rl->table_run [code] + 1;
128 level= rl->table_level[code];
131 rl->rl_vlc[0][i].len= len;
132 rl->rl_vlc[0][i].level= level;
133 rl->rl_vlc[0][i].run= run;
137 #ifdef CONFIG_ENCODERS
138 static void init_uni_ac_vlc(RLTable *rl, uint32_t *uni_ac_vlc_bits, uint8_t *uni_ac_vlc_len){
141 for(i=0; i<128; i++){
144 for(run=0; run<64; run++){
147 int alevel= ABS(level);
148 int sign= (level>>31)&1;
150 if (alevel > rl->max_level[0][run])
153 code= rl->index_run[0][run] + alevel - 1;
155 if (code < 111 /* rl->n */) {
156 /* store the vlc & sign at once */
157 len= mpeg1_vlc[code][1]+1;
158 bits= (mpeg1_vlc[code][0]<<1) + sign;
160 len= mpeg1_vlc[111/*rl->n*/][1]+6;
161 bits= mpeg1_vlc[111/*rl->n*/][0]<<6;
171 bits|= 0x8001 + level + 255;
173 bits|= level & 0xffff;
178 uni_ac_vlc_bits[UNI_AC_ENC_INDEX(run, i)]= bits;
179 uni_ac_vlc_len [UNI_AC_ENC_INDEX(run, i)]= len;
185 static int find_frame_rate_index(MpegEncContext *s){
187 int64_t dmin= INT64_MAX;
191 if(s->avctx->strict_std_compliance >= 0 && i>=9) break;
193 d = ABS(MPEG1_FRAME_RATE_BASE*(int64_t)s->avctx->frame_rate - frame_rate_tab[i]*(int64_t)s->avctx->frame_rate_base);
196 s->frame_rate_index= i;
205 static int encode_init(AVCodecContext *avctx)
207 MpegEncContext *s = avctx->priv_data;
209 if(MPV_encode_init(avctx) < 0)
212 if(find_frame_rate_index(s) < 0){
213 if(s->strict_std_compliance >=0){
214 av_log(avctx, AV_LOG_ERROR, "MPEG1/2 doesnt support %d/%d fps\n", avctx->frame_rate, avctx->frame_rate_base);
217 av_log(avctx, AV_LOG_INFO, "MPEG1/2 doesnt support %d/%d fps, there may be AV sync issues\n", avctx->frame_rate, avctx->frame_rate_base);
224 static void put_header(MpegEncContext *s, int header)
226 align_put_bits(&s->pb);
227 put_bits(&s->pb, 16, header>>16);
228 put_bits(&s->pb, 16, header&0xFFFF);
231 /* put sequence header if needed */
232 static void mpeg1_encode_sequence_header(MpegEncContext *s)
234 unsigned int vbv_buffer_size;
238 float best_aspect_error= 1E10;
239 float aspect_ratio= av_q2d(s->avctx->sample_aspect_ratio);
240 int constraint_parameter_flag;
242 if(aspect_ratio==0.0) aspect_ratio= 1.0; //pixel aspect 1:1 (VGA)
244 if (s->current_picture.key_frame) {
245 /* mpeg1 header repeated every gop */
246 put_header(s, SEQ_START_CODE);
248 put_bits(&s->pb, 12, s->width);
249 put_bits(&s->pb, 12, s->height);
252 float error= aspect_ratio;
253 if(s->codec_id == CODEC_ID_MPEG1VIDEO || i <=1)
254 error-= 1.0/mpeg1_aspect[i];
256 error-= av_q2d(mpeg2_aspect[i])*s->height/s->width;
260 if(error < best_aspect_error){
261 best_aspect_error= error;
262 s->aspect_ratio_info= i;
266 put_bits(&s->pb, 4, s->aspect_ratio_info);
267 put_bits(&s->pb, 4, s->frame_rate_index);
269 if(s->avctx->rc_max_rate){
270 v = (s->avctx->rc_max_rate + 399) / 400;
271 if (v > 0x3ffff && s->codec_id == CODEC_ID_MPEG1VIDEO)
277 if(s->avctx->rc_buffer_size)
278 vbv_buffer_size = s->avctx->rc_buffer_size;
280 /* VBV calculation: Scaled so that a VCD has the proper VBV size of 40 kilobytes */
281 vbv_buffer_size = (( 20 * s->bit_rate) / (1151929 / 2)) * 8 * 1024;
282 vbv_buffer_size= (vbv_buffer_size + 16383) / 16384;
284 put_bits(&s->pb, 18, v & 0x3FFFF);
285 put_bits(&s->pb, 1, 1); /* marker */
286 put_bits(&s->pb, 10, vbv_buffer_size & 0x3FF);
288 constraint_parameter_flag=
289 s->width <= 768 && s->height <= 576 &&
290 s->mb_width * s->mb_height <= 396 &&
291 s->mb_width * s->mb_height * frame_rate_tab[s->frame_rate_index] <= MPEG1_FRAME_RATE_BASE*396*25 &&
292 frame_rate_tab[s->frame_rate_index] <= MPEG1_FRAME_RATE_BASE*30 &&
293 vbv_buffer_size <= 20 &&
295 s->codec_id == CODEC_ID_MPEG1VIDEO;
297 put_bits(&s->pb, 1, constraint_parameter_flag);
299 ff_write_quant_matrix(&s->pb, s->avctx->intra_matrix);
300 ff_write_quant_matrix(&s->pb, s->avctx->inter_matrix);
302 if(s->codec_id == CODEC_ID_MPEG2VIDEO){
303 put_header(s, EXT_START_CODE);
304 put_bits(&s->pb, 4, 1); //seq ext
305 put_bits(&s->pb, 1, 0); //esc
306 put_bits(&s->pb, 3, 4); //profile
307 put_bits(&s->pb, 4, 8); //level
308 put_bits(&s->pb, 1, s->progressive_sequence);
309 put_bits(&s->pb, 2, 1); //chroma format 4:2:0
310 put_bits(&s->pb, 2, 0); //horizontal size ext
311 put_bits(&s->pb, 2, 0); //vertical size ext
312 put_bits(&s->pb, 12, v>>18); //bitrate ext
313 put_bits(&s->pb, 1, 1); //marker
314 put_bits(&s->pb, 8, vbv_buffer_size >>10); //vbv buffer ext
315 put_bits(&s->pb, 1, s->low_delay);
316 put_bits(&s->pb, 2, 0); // frame_rate_ext_n
317 put_bits(&s->pb, 5, 0); // frame_rate_ext_d
320 put_header(s, GOP_START_CODE);
321 put_bits(&s->pb, 1, 0); /* do drop frame */
322 /* time code : we must convert from the real frame rate to a
323 fake mpeg frame rate in case of low frame rate */
324 fps = (frame_rate_tab[s->frame_rate_index] + MPEG1_FRAME_RATE_BASE/2)/ MPEG1_FRAME_RATE_BASE;
325 time_code = s->current_picture_ptr->coded_picture_number;
327 s->gop_picture_number = time_code;
328 put_bits(&s->pb, 5, (uint32_t)((time_code / (fps * 3600)) % 24));
329 put_bits(&s->pb, 6, (uint32_t)((time_code / (fps * 60)) % 60));
330 put_bits(&s->pb, 1, 1);
331 put_bits(&s->pb, 6, (uint32_t)((time_code / fps) % 60));
332 put_bits(&s->pb, 6, (uint32_t)((time_code % fps)));
333 put_bits(&s->pb, 1, !!(s->flags & CODEC_FLAG_CLOSED_GOP));
334 put_bits(&s->pb, 1, 0); /* broken link */
338 static inline void encode_mb_skip_run(MpegEncContext *s, int run){
340 put_bits(&s->pb, 11, 0x008);
343 put_bits(&s->pb, mbAddrIncrTable[run][1],
344 mbAddrIncrTable[run][0]);
346 #endif //CONFIG_ENCODERS
348 static void common_init(MpegEncContext *s)
351 s->c_dc_scale_table= ff_mpeg1_dc_scale_table;
354 void ff_mpeg1_clean_buffers(MpegEncContext *s){
355 s->last_dc[0] = 1 << (7 + s->intra_dc_precision);
356 s->last_dc[1] = s->last_dc[0];
357 s->last_dc[2] = s->last_dc[0];
358 memset(s->last_mv, 0, sizeof(s->last_mv));
361 #ifdef CONFIG_ENCODERS
363 void ff_mpeg1_encode_slice_header(MpegEncContext *s){
364 put_header(s, SLICE_MIN_START_CODE + s->mb_y);
365 put_bits(&s->pb, 5, s->qscale); /* quantizer scale */
366 put_bits(&s->pb, 1, 0); /* slice extra information */
369 void mpeg1_encode_picture_header(MpegEncContext *s, int picture_number)
371 mpeg1_encode_sequence_header(s);
373 /* mpeg1 picture header */
374 put_header(s, PICTURE_START_CODE);
375 /* temporal reference */
377 // RAL: s->picture_number instead of s->fake_picture_number
378 put_bits(&s->pb, 10, (s->picture_number -
379 s->gop_picture_number) & 0x3ff);
380 put_bits(&s->pb, 3, s->pict_type);
382 s->vbv_delay_ptr= s->pb.buf + get_bit_count(&s->pb)/8;
383 put_bits(&s->pb, 16, 0xFFFF); /* vbv_delay */
385 // RAL: Forward f_code also needed for B frames
386 if (s->pict_type == P_TYPE || s->pict_type == B_TYPE) {
387 put_bits(&s->pb, 1, 0); /* half pel coordinates */
388 if(s->codec_id == CODEC_ID_MPEG1VIDEO)
389 put_bits(&s->pb, 3, s->f_code); /* forward_f_code */
391 put_bits(&s->pb, 3, 7); /* forward_f_code */
394 // RAL: Backward f_code necessary for B frames
395 if (s->pict_type == B_TYPE) {
396 put_bits(&s->pb, 1, 0); /* half pel coordinates */
397 if(s->codec_id == CODEC_ID_MPEG1VIDEO)
398 put_bits(&s->pb, 3, s->b_code); /* backward_f_code */
400 put_bits(&s->pb, 3, 7); /* backward_f_code */
403 put_bits(&s->pb, 1, 0); /* extra bit picture */
405 s->frame_pred_frame_dct = 1;
406 if(s->codec_id == CODEC_ID_MPEG2VIDEO){
407 put_header(s, EXT_START_CODE);
408 put_bits(&s->pb, 4, 8); //pic ext
409 if (s->pict_type == P_TYPE || s->pict_type == B_TYPE) {
410 put_bits(&s->pb, 4, s->f_code);
411 put_bits(&s->pb, 4, s->f_code);
413 put_bits(&s->pb, 8, 255);
415 if (s->pict_type == B_TYPE) {
416 put_bits(&s->pb, 4, s->b_code);
417 put_bits(&s->pb, 4, s->b_code);
419 put_bits(&s->pb, 8, 255);
421 put_bits(&s->pb, 2, s->intra_dc_precision);
422 put_bits(&s->pb, 2, s->picture_structure= PICT_FRAME);
423 if (s->progressive_sequence) {
424 put_bits(&s->pb, 1, 0); /* no repeat */
426 put_bits(&s->pb, 1, s->current_picture_ptr->top_field_first);
428 /* XXX: optimize the generation of this flag with entropy
430 s->frame_pred_frame_dct = s->progressive_sequence;
432 put_bits(&s->pb, 1, s->frame_pred_frame_dct);
433 put_bits(&s->pb, 1, s->concealment_motion_vectors);
434 put_bits(&s->pb, 1, s->q_scale_type);
435 put_bits(&s->pb, 1, s->intra_vlc_format);
436 put_bits(&s->pb, 1, s->alternate_scan);
437 put_bits(&s->pb, 1, s->repeat_first_field);
438 put_bits(&s->pb, 1, s->chroma_420_type=1);
439 s->progressive_frame = s->progressive_sequence;
440 put_bits(&s->pb, 1, s->progressive_frame);
441 put_bits(&s->pb, 1, 0); //composite_display_flag
443 if(s->flags & CODEC_FLAG_SVCD_SCAN_OFFSET){
446 put_header(s, USER_START_CODE);
447 for(i=0; i<sizeof(svcd_scan_offset_placeholder); i++){
448 put_bits(&s->pb, 8, svcd_scan_offset_placeholder[i]);
453 ff_mpeg1_encode_slice_header(s);
456 static inline void put_mb_modes(MpegEncContext *s, int n, int bits,
457 int has_mv, int field_motion)
459 put_bits(&s->pb, n, bits);
460 if (!s->frame_pred_frame_dct) {
462 put_bits(&s->pb, 2, 2 - field_motion); /* motion_type: frame/field */
463 put_bits(&s->pb, 1, s->interlaced_dct);
467 void mpeg1_encode_mb(MpegEncContext *s,
468 DCTELEM block[6][64],
469 int motion_x, int motion_y)
472 const int mb_x = s->mb_x;
473 const int mb_y = s->mb_y;
474 const int first_mb= mb_x == s->resync_mb_x && mb_y == s->resync_mb_y;
479 if (s->block_last_index[i] >= 0)
483 if (cbp == 0 && !first_mb && (mb_x != s->mb_width - 1 || (mb_y != s->mb_height - 1 && s->codec_id == CODEC_ID_MPEG1VIDEO)) &&
484 ((s->pict_type == P_TYPE && s->mv_type == MV_TYPE_16X16 && (motion_x | motion_y) == 0) ||
485 (s->pict_type == B_TYPE && s->mv_dir == s->last_mv_dir && (((s->mv_dir & MV_DIR_FORWARD) ? ((s->mv[0][0][0] - s->last_mv[0][0][0])|(s->mv[0][0][1] - s->last_mv[0][0][1])) : 0) |
486 ((s->mv_dir & MV_DIR_BACKWARD) ? ((s->mv[1][0][0] - s->last_mv[1][0][0])|(s->mv[1][0][1] - s->last_mv[1][0][1])) : 0)) == 0))) {
488 s->qscale -= s->dquant;
492 if(s->pict_type == P_TYPE){
493 s->last_mv[0][1][0]= s->last_mv[0][0][0]=
494 s->last_mv[0][1][1]= s->last_mv[0][0][1]= 0;
498 assert(s->mb_skip_run == 0);
499 encode_mb_skip_run(s, s->mb_x);
501 encode_mb_skip_run(s, s->mb_skip_run);
504 if (s->pict_type == I_TYPE) {
505 if(s->dquant && cbp){
506 put_mb_modes(s, 2, 1, 0, 0); /* macroblock_type : macroblock_quant = 1 */
507 put_bits(&s->pb, 5, s->qscale);
509 put_mb_modes(s, 1, 1, 0, 0); /* macroblock_type : macroblock_quant = 0 */
510 s->qscale -= s->dquant;
512 s->misc_bits+= get_bits_diff(s);
514 } else if (s->mb_intra) {
515 if(s->dquant && cbp){
516 put_mb_modes(s, 6, 0x01, 0, 0);
517 put_bits(&s->pb, 5, s->qscale);
519 put_mb_modes(s, 5, 0x03, 0, 0);
520 s->qscale -= s->dquant;
522 s->misc_bits+= get_bits_diff(s);
524 memset(s->last_mv, 0, sizeof(s->last_mv));
525 } else if (s->pict_type == P_TYPE) {
526 if(s->mv_type == MV_TYPE_16X16){
528 if ((motion_x|motion_y) == 0) {
530 put_mb_modes(s, 5, 1, 0, 0); /* macroblock_pattern & quant */
531 put_bits(&s->pb, 5, s->qscale);
533 put_mb_modes(s, 2, 1, 0, 0); /* macroblock_pattern only */
535 s->misc_bits+= get_bits_diff(s);
538 put_mb_modes(s, 5, 2, 1, 0); /* motion + cbp */
539 put_bits(&s->pb, 5, s->qscale);
541 put_mb_modes(s, 1, 1, 1, 0); /* motion + cbp */
543 s->misc_bits+= get_bits_diff(s);
544 mpeg1_encode_motion(s, motion_x - s->last_mv[0][0][0], s->f_code); // RAL: f_code parameter added
545 mpeg1_encode_motion(s, motion_y - s->last_mv[0][0][1], s->f_code); // RAL: f_code parameter added
546 s->mv_bits+= get_bits_diff(s);
549 put_bits(&s->pb, 3, 1); /* motion only */
550 if (!s->frame_pred_frame_dct)
551 put_bits(&s->pb, 2, 2); /* motion_type: frame */
552 s->misc_bits+= get_bits_diff(s);
553 mpeg1_encode_motion(s, motion_x - s->last_mv[0][0][0], s->f_code); // RAL: f_code parameter added
554 mpeg1_encode_motion(s, motion_y - s->last_mv[0][0][1], s->f_code); // RAL: f_code parameter added
555 s->qscale -= s->dquant;
556 s->mv_bits+= get_bits_diff(s);
558 s->last_mv[0][1][0]= s->last_mv[0][0][0]= motion_x;
559 s->last_mv[0][1][1]= s->last_mv[0][0][1]= motion_y;
561 assert(!s->frame_pred_frame_dct && s->mv_type == MV_TYPE_FIELD);
565 put_mb_modes(s, 5, 2, 1, 1); /* motion + cbp */
566 put_bits(&s->pb, 5, s->qscale);
568 put_mb_modes(s, 1, 1, 1, 1); /* motion + cbp */
571 put_bits(&s->pb, 3, 1); /* motion only */
572 put_bits(&s->pb, 2, 1); /* motion_type: field */
573 s->qscale -= s->dquant;
575 s->misc_bits+= get_bits_diff(s);
577 put_bits(&s->pb, 1, s->field_select[0][i]);
578 mpeg1_encode_motion(s, s->mv[0][i][0] - s->last_mv[0][i][0] , s->f_code);
579 mpeg1_encode_motion(s, s->mv[0][i][1] - (s->last_mv[0][i][1]>>1), s->f_code);
580 s->last_mv[0][i][0]= s->mv[0][i][0];
581 s->last_mv[0][i][1]= 2*s->mv[0][i][1];
583 s->mv_bits+= get_bits_diff(s);
586 put_bits(&s->pb, mbPatTable[cbp - 1][1], mbPatTable[cbp - 1][0]);
589 static const int mb_type_len[4]={0,3,4,2}; //bak,for,bi
591 if(s->mv_type == MV_TYPE_16X16){
592 if (cbp){ // With coded bloc pattern
594 if(s->mv_dir == MV_DIR_FORWARD)
595 put_mb_modes(s, 6, 3, 1, 0);
597 put_mb_modes(s, mb_type_len[s->mv_dir]+3, 2, 1, 0);
598 put_bits(&s->pb, 5, s->qscale);
600 put_mb_modes(s, mb_type_len[s->mv_dir], 3, 1, 0);
602 }else{ // No coded bloc pattern
603 put_bits(&s->pb, mb_type_len[s->mv_dir], 2);
604 if (!s->frame_pred_frame_dct)
605 put_bits(&s->pb, 2, 2); /* motion_type: frame */
606 s->qscale -= s->dquant;
608 s->misc_bits += get_bits_diff(s);
609 if (s->mv_dir&MV_DIR_FORWARD){
610 mpeg1_encode_motion(s, s->mv[0][0][0] - s->last_mv[0][0][0], s->f_code);
611 mpeg1_encode_motion(s, s->mv[0][0][1] - s->last_mv[0][0][1], s->f_code);
612 s->last_mv[0][0][0]=s->last_mv[0][1][0]= s->mv[0][0][0];
613 s->last_mv[0][0][1]=s->last_mv[0][1][1]= s->mv[0][0][1];
616 if (s->mv_dir&MV_DIR_BACKWARD){
617 mpeg1_encode_motion(s, s->mv[1][0][0] - s->last_mv[1][0][0], s->b_code);
618 mpeg1_encode_motion(s, s->mv[1][0][1] - s->last_mv[1][0][1], s->b_code);
619 s->last_mv[1][0][0]=s->last_mv[1][1][0]= s->mv[1][0][0];
620 s->last_mv[1][0][1]=s->last_mv[1][1][1]= s->mv[1][0][1];
624 assert(s->mv_type == MV_TYPE_FIELD);
625 assert(!s->frame_pred_frame_dct);
626 if (cbp){ // With coded bloc pattern
628 if(s->mv_dir == MV_DIR_FORWARD)
629 put_mb_modes(s, 6, 3, 1, 1);
631 put_mb_modes(s, mb_type_len[s->mv_dir]+3, 2, 1, 1);
632 put_bits(&s->pb, 5, s->qscale);
634 put_mb_modes(s, mb_type_len[s->mv_dir], 3, 1, 1);
636 }else{ // No coded bloc pattern
637 put_bits(&s->pb, mb_type_len[s->mv_dir], 2);
638 put_bits(&s->pb, 2, 1); /* motion_type: field */
639 s->qscale -= s->dquant;
641 s->misc_bits += get_bits_diff(s);
642 if (s->mv_dir&MV_DIR_FORWARD){
644 put_bits(&s->pb, 1, s->field_select[0][i]);
645 mpeg1_encode_motion(s, s->mv[0][i][0] - s->last_mv[0][i][0] , s->f_code);
646 mpeg1_encode_motion(s, s->mv[0][i][1] - (s->last_mv[0][i][1]>>1), s->f_code);
647 s->last_mv[0][i][0]= s->mv[0][i][0];
648 s->last_mv[0][i][1]= 2*s->mv[0][i][1];
652 if (s->mv_dir&MV_DIR_BACKWARD){
654 put_bits(&s->pb, 1, s->field_select[1][i]);
655 mpeg1_encode_motion(s, s->mv[1][i][0] - s->last_mv[1][i][0] , s->b_code);
656 mpeg1_encode_motion(s, s->mv[1][i][1] - (s->last_mv[1][i][1]>>1), s->b_code);
657 s->last_mv[1][i][0]= s->mv[1][i][0];
658 s->last_mv[1][i][1]= 2*s->mv[1][i][1];
663 s->mv_bits += get_bits_diff(s);
665 put_bits(&s->pb, mbPatTable[cbp - 1][1], mbPatTable[cbp - 1][0]);
668 if (cbp & (1 << (5 - i))) {
669 mpeg1_encode_block(s, block[i], i);
674 s->i_tex_bits+= get_bits_diff(s);
676 s->p_tex_bits+= get_bits_diff(s);
680 // RAL: Parameter added: f_or_b_code
681 static void mpeg1_encode_motion(MpegEncContext *s, int val, int f_or_b_code)
683 int code, bit_size, l, m, bits, range, sign;
689 mbMotionVectorTable[0][1],
690 mbMotionVectorTable[0][0]);
692 bit_size = f_or_b_code - 1;
693 range = 1 << bit_size;
694 /* modulo encoding */
699 } else if (val >= l) {
705 code = (val >> bit_size) + 1;
706 bits = val & (range - 1);
711 code = (val >> bit_size) + 1;
712 bits = val & (range - 1);
716 assert(code > 0 && code <= 16);
719 mbMotionVectorTable[code][1],
720 mbMotionVectorTable[code][0]);
722 put_bits(&s->pb, 1, sign);
724 put_bits(&s->pb, bit_size, bits);
729 void ff_mpeg1_encode_init(MpegEncContext *s)
745 mpeg1_max_level[0][i]= rl_mpeg1.max_level[0][i];
746 mpeg1_index_run[0][i]= rl_mpeg1.index_run[0][i];
749 init_uni_ac_vlc(&rl_mpeg1, uni_mpeg1_ac_vlc_bits, uni_mpeg1_ac_vlc_len);
751 /* build unified dc encoding tables */
752 for(i=-255; i<256; i++)
760 index = vlc_dc_table[adiff];
762 bits= vlc_dc_lum_bits[index] + index;
763 code= (vlc_dc_lum_code[index]<<index) + (diff & ((1 << index) - 1));
764 mpeg1_lum_dc_uni[i+255]= bits + (code<<8);
766 bits= vlc_dc_chroma_bits[index] + index;
767 code= (vlc_dc_chroma_code[index]<<index) + (diff & ((1 << index) - 1));
768 mpeg1_chr_dc_uni[i+255]= bits + (code<<8);
771 mv_penalty= av_mallocz( sizeof(uint8_t)*(MAX_FCODE+1)*(2*MAX_MV+1) );
773 for(f_code=1; f_code<=MAX_FCODE; f_code++){
774 for(mv=-MAX_MV; mv<=MAX_MV; mv++){
777 if(mv==0) len= mbMotionVectorTable[0][1];
779 int val, bit_size, range, code;
781 bit_size = s->f_code - 1;
782 range = 1 << bit_size;
788 code = (val >> bit_size) + 1;
790 len= mbMotionVectorTable[code][1] + 1 + bit_size;
792 len= mbMotionVectorTable[16][1] + 2 + bit_size;
796 mv_penalty[f_code][mv+MAX_MV]= len;
801 for(f_code=MAX_FCODE; f_code>0; f_code--){
802 for(mv=-(8<<f_code); mv<(8<<f_code); mv++){
803 fcode_tab[mv+MAX_MV]= f_code;
807 s->me.mv_penalty= mv_penalty;
808 s->fcode_tab= fcode_tab;
809 if(s->codec_id == CODEC_ID_MPEG1VIDEO){
816 s->intra_ac_vlc_length=
817 s->inter_ac_vlc_length=
818 s->intra_ac_vlc_last_length=
819 s->inter_ac_vlc_last_length= uni_mpeg1_ac_vlc_len;
822 static inline void encode_dc(MpegEncContext *s, int diff, int component)
824 if (component == 0) {
827 mpeg1_lum_dc_uni[diff+255]&0xFF,
828 mpeg1_lum_dc_uni[diff+255]>>8);
832 mpeg1_chr_dc_uni[diff+255]&0xFF,
833 mpeg1_chr_dc_uni[diff+255]>>8);
837 static void mpeg1_encode_block(MpegEncContext *s,
841 int alevel, level, last_non_zero, dc, diff, i, j, run, last_index, sign;
843 // RLTable *rl = &rl_mpeg1;
845 last_index = s->block_last_index[n];
849 component = (n <= 3 ? 0 : n - 4 + 1);
850 dc = block[0]; /* overflow is impossible */
851 diff = dc - s->last_dc[component];
852 encode_dc(s, diff, component);
853 s->last_dc[component] = dc;
856 if (s->intra_vlc_format)
862 /* encode the first coefficient : needs to be done here because
863 it is handled slightly differently */
865 if (abs(level) == 1) {
866 code = ((uint32_t)level >> 31); /* the sign bit */
867 put_bits(&s->pb, 2, code | 0x02);
876 /* now quantify & encode AC coefs */
877 last_non_zero = i - 1;
879 for(;i<=last_index;i++) {
880 j = s->intra_scantable.permutated[i];
885 dprintf("level[%d]=%d\n", i, level);
887 /* encode using VLC */
889 run = i - last_non_zero - 1;
892 MASK_ABS(sign, alevel)
895 // code = get_rl_index(rl, 0, run, alevel);
896 if (alevel <= mpeg1_max_level[0][run]){
897 code= mpeg1_index_run[0][run] + alevel - 1;
898 /* store the vlc & sign at once */
899 put_bits(&s->pb, mpeg1_vlc[code][1]+1, (mpeg1_vlc[code][0]<<1) + sign);
901 /* escape seems to be pretty rare <5% so i dont optimize it */
902 put_bits(&s->pb, mpeg1_vlc[111/*rl->n*/][1], mpeg1_vlc[111/*rl->n*/][0]);
903 /* escape: only clip in this case */
904 put_bits(&s->pb, 6, run);
905 if(s->codec_id == CODEC_ID_MPEG1VIDEO){
907 put_bits(&s->pb, 8, level & 0xff);
910 put_bits(&s->pb, 16, 0x8001 + level + 255);
912 put_bits(&s->pb, 16, level & 0xffff);
916 put_bits(&s->pb, 12, level & 0xfff);
923 put_bits(&s->pb, 2, 0x2);
925 #endif //CONFIG_ENCODERS
927 /******************************************/
930 static VLC dc_lum_vlc;
931 static VLC dc_chroma_vlc;
933 static VLC mbincr_vlc;
934 static VLC mb_ptype_vlc;
935 static VLC mb_btype_vlc;
936 static VLC mb_pat_vlc;
938 static void init_vlcs()
945 init_vlc(&dc_lum_vlc, DC_VLC_BITS, 12,
946 vlc_dc_lum_bits, 1, 1,
947 vlc_dc_lum_code, 2, 2);
948 init_vlc(&dc_chroma_vlc, DC_VLC_BITS, 12,
949 vlc_dc_chroma_bits, 1, 1,
950 vlc_dc_chroma_code, 2, 2);
951 init_vlc(&mv_vlc, MV_VLC_BITS, 17,
952 &mbMotionVectorTable[0][1], 2, 1,
953 &mbMotionVectorTable[0][0], 2, 1);
954 init_vlc(&mbincr_vlc, MBINCR_VLC_BITS, 36,
955 &mbAddrIncrTable[0][1], 2, 1,
956 &mbAddrIncrTable[0][0], 2, 1);
957 init_vlc(&mb_pat_vlc, MB_PAT_VLC_BITS, 63,
958 &mbPatTable[0][1], 2, 1,
959 &mbPatTable[0][0], 2, 1);
961 init_vlc(&mb_ptype_vlc, MB_PTYPE_VLC_BITS, 7,
962 &table_mb_ptype[0][1], 2, 1,
963 &table_mb_ptype[0][0], 2, 1);
964 init_vlc(&mb_btype_vlc, MB_BTYPE_VLC_BITS, 11,
965 &table_mb_btype[0][1], 2, 1,
966 &table_mb_btype[0][0], 2, 1);
970 init_2d_vlc_rl(&rl_mpeg1);
971 init_2d_vlc_rl(&rl_mpeg2);
975 static inline int get_dmv(MpegEncContext *s)
977 if(get_bits1(&s->gb))
978 return 1 - (get_bits1(&s->gb) << 1);
983 static inline int get_qscale(MpegEncContext *s)
985 int qscale = get_bits(&s->gb, 5);
986 if (s->q_scale_type) {
987 return non_linear_qscale[qscale];
993 /* motion type (for mpeg2) */
999 static int mpeg_decode_mb(MpegEncContext *s,
1000 DCTELEM block[6][64])
1002 int i, j, k, cbp, val, mb_type, motion_type;
1004 dprintf("decode_mb: x=%d y=%d\n", s->mb_x, s->mb_y);
1006 assert(s->mb_skiped==0);
1008 if (s->mb_skip_run-- != 0) {
1009 if(s->pict_type == I_TYPE){
1010 av_log(s->avctx, AV_LOG_ERROR, "skiped MB in I frame at %d %d\n", s->mb_x, s->mb_y);
1017 s->block_last_index[i] = -1;
1018 s->mv_type = MV_TYPE_16X16;
1019 if (s->pict_type == P_TYPE) {
1020 /* if P type, zero motion vector is implied */
1021 s->mv_dir = MV_DIR_FORWARD;
1022 s->mv[0][0][0] = s->mv[0][0][1] = 0;
1023 s->last_mv[0][0][0] = s->last_mv[0][0][1] = 0;
1024 s->last_mv[0][1][0] = s->last_mv[0][1][1] = 0;
1026 s->current_picture.mb_type[ s->mb_x + s->mb_y*s->mb_stride ]= MB_TYPE_SKIP | MB_TYPE_L0 | MB_TYPE_16x16;
1028 /* if B type, reuse previous vectors and directions */
1029 s->mv[0][0][0] = s->last_mv[0][0][0];
1030 s->mv[0][0][1] = s->last_mv[0][0][1];
1031 s->mv[1][0][0] = s->last_mv[1][0][0];
1032 s->mv[1][0][1] = s->last_mv[1][0][1];
1034 s->current_picture.mb_type[ s->mb_x + s->mb_y*s->mb_stride ]=
1035 s->current_picture.mb_type[ s->mb_x + s->mb_y*s->mb_stride - 1] | MB_TYPE_SKIP;
1036 // assert(s->current_picture.mb_type[ s->mb_x + s->mb_y*s->mb_stride - 1]&(MB_TYPE_16x16|MB_TYPE_16x8));
1038 if((s->mv[0][0][0]|s->mv[0][0][1]|s->mv[1][0][0]|s->mv[1][0][1])==0)
1045 switch(s->pict_type) {
1048 if (get_bits1(&s->gb) == 0) {
1049 if (get_bits1(&s->gb) == 0){
1050 av_log(s->avctx, AV_LOG_ERROR, "invalid mb type in I Frame at %d %d\n", s->mb_x, s->mb_y);
1053 mb_type = MB_TYPE_QUANT | MB_TYPE_INTRA;
1055 mb_type = MB_TYPE_INTRA;
1059 mb_type = get_vlc2(&s->gb, mb_ptype_vlc.table, MB_PTYPE_VLC_BITS, 1);
1061 av_log(s->avctx, AV_LOG_ERROR, "invalid mb type in P Frame at %d %d\n", s->mb_x, s->mb_y);
1064 mb_type = ptype2mb_type[ mb_type ];
1067 mb_type = get_vlc2(&s->gb, mb_btype_vlc.table, MB_BTYPE_VLC_BITS, 1);
1069 av_log(s->avctx, AV_LOG_ERROR, "invalid mb type in B Frame at %d %d\n", s->mb_x, s->mb_y);
1072 mb_type = btype2mb_type[ mb_type ];
1075 dprintf("mb_type=%x\n", mb_type);
1076 // motion_type = 0; /* avoid warning */
1077 if (IS_INTRA(mb_type)) {
1078 /* compute dct type */
1079 if (s->picture_structure == PICT_FRAME && //FIXME add a interlaced_dct coded var?
1080 !s->frame_pred_frame_dct) {
1081 s->interlaced_dct = get_bits1(&s->gb);
1084 if (IS_QUANT(mb_type))
1085 s->qscale = get_qscale(s);
1087 if (s->concealment_motion_vectors) {
1088 /* just parse them */
1089 if (s->picture_structure != PICT_FRAME)
1090 skip_bits1(&s->gb); /* field select */
1092 s->mv[0][0][0]= s->last_mv[0][0][0]= s->last_mv[0][1][0] =
1093 mpeg_decode_motion(s, s->mpeg_f_code[0][0], s->last_mv[0][0][0]);
1094 s->mv[0][0][1]= s->last_mv[0][0][1]= s->last_mv[0][1][1] =
1095 mpeg_decode_motion(s, s->mpeg_f_code[0][1], s->last_mv[0][0][1]);
1097 skip_bits1(&s->gb); /* marker */
1099 memset(s->last_mv, 0, sizeof(s->last_mv)); /* reset mv prediction */
1102 //one 1 we memcpy blocks in xvmcvideo
1103 if(s->avctx->xvmc_acceleration > 1){
1104 XVMC_pack_pblocks(s,-1);//inter are always full blocks
1111 if (s->codec_id == CODEC_ID_MPEG2VIDEO) {
1113 if (mpeg2_decode_block_intra(s, s->pblocks[i], i) < 0)
1118 if (mpeg1_decode_block_intra(s, s->pblocks[i], i) < 0)
1123 if (mb_type & MB_TYPE_ZERO_MV){
1124 assert(mb_type & MB_TYPE_CBP);
1126 /* compute dct type */
1127 if (s->picture_structure == PICT_FRAME && //FIXME add a interlaced_dct coded var?
1128 !s->frame_pred_frame_dct) {
1129 s->interlaced_dct = get_bits1(&s->gb);
1132 if (IS_QUANT(mb_type))
1133 s->qscale = get_qscale(s);
1135 s->mv_dir = MV_DIR_FORWARD;
1136 s->mv_type = MV_TYPE_16X16;
1137 s->last_mv[0][0][0] = 0;
1138 s->last_mv[0][0][1] = 0;
1139 s->last_mv[0][1][0] = 0;
1140 s->last_mv[0][1][1] = 0;
1144 assert(mb_type & MB_TYPE_L0L1);
1145 //FIXME decide if MBs in field pictures are MB_TYPE_INTERLACED
1146 /* get additionnal motion vector type */
1147 if (s->frame_pred_frame_dct)
1148 motion_type = MT_FRAME;
1150 motion_type = get_bits(&s->gb, 2);
1153 /* compute dct type */
1154 if (s->picture_structure == PICT_FRAME && //FIXME add a interlaced_dct coded var?
1155 !s->frame_pred_frame_dct && HAS_CBP(mb_type)) {
1156 s->interlaced_dct = get_bits1(&s->gb);
1159 if (IS_QUANT(mb_type))
1160 s->qscale = get_qscale(s);
1162 /* motion vectors */
1165 if (USES_LIST(mb_type, i)) {
1166 s->mv_dir |= (MV_DIR_FORWARD >> i);
1167 dprintf("motion_type=%d\n", motion_type);
1168 switch(motion_type) {
1169 case MT_FRAME: /* or MT_16X8 */
1170 if (s->picture_structure == PICT_FRAME) {
1172 mb_type |= MB_TYPE_16x16;
1173 s->mv_type = MV_TYPE_16X16;
1174 s->mv[i][0][0]= s->last_mv[i][0][0]= s->last_mv[i][1][0] =
1175 mpeg_decode_motion(s, s->mpeg_f_code[i][0], s->last_mv[i][0][0]);
1176 s->mv[i][0][1]= s->last_mv[i][0][1]= s->last_mv[i][1][1] =
1177 mpeg_decode_motion(s, s->mpeg_f_code[i][1], s->last_mv[i][0][1]);
1178 /* full_pel: only for mpeg1 */
1179 if (s->full_pel[i]){
1180 s->mv[i][0][0] <<= 1;
1181 s->mv[i][0][1] <<= 1;
1185 mb_type |= MB_TYPE_16x8 | MB_TYPE_INTERLACED;
1186 s->mv_type = MV_TYPE_16X8;
1188 s->field_select[i][j] = get_bits1(&s->gb);
1190 val = mpeg_decode_motion(s, s->mpeg_f_code[i][k],
1191 s->last_mv[i][j][k]);
1192 s->last_mv[i][j][k] = val;
1193 s->mv[i][j][k] = val;
1199 s->mv_type = MV_TYPE_FIELD;
1200 if (s->picture_structure == PICT_FRAME) {
1201 mb_type |= MB_TYPE_16x8 | MB_TYPE_INTERLACED;
1203 s->field_select[i][j] = get_bits1(&s->gb);
1204 val = mpeg_decode_motion(s, s->mpeg_f_code[i][0],
1205 s->last_mv[i][j][0]);
1206 s->last_mv[i][j][0] = val;
1207 s->mv[i][j][0] = val;
1208 dprintf("fmx=%d\n", val);
1209 val = mpeg_decode_motion(s, s->mpeg_f_code[i][1],
1210 s->last_mv[i][j][1] >> 1);
1211 s->last_mv[i][j][1] = val << 1;
1212 s->mv[i][j][1] = val;
1213 dprintf("fmy=%d\n", val);
1216 mb_type |= MB_TYPE_16x16 | MB_TYPE_INTERLACED;
1217 s->field_select[i][0] = get_bits1(&s->gb);
1219 val = mpeg_decode_motion(s, s->mpeg_f_code[i][k],
1220 s->last_mv[i][0][k]);
1221 s->last_mv[i][0][k] = val;
1222 s->last_mv[i][1][k] = val;
1223 s->mv[i][0][k] = val;
1229 int dmx, dmy, mx, my, m;
1231 mx = mpeg_decode_motion(s, s->mpeg_f_code[i][0],
1232 s->last_mv[i][0][0]);
1233 s->last_mv[i][0][0] = mx;
1234 s->last_mv[i][1][0] = mx;
1236 my = mpeg_decode_motion(s, s->mpeg_f_code[i][1],
1237 s->last_mv[i][0][1] >> 1);
1239 s->mv_type = MV_TYPE_DMV;
1242 s->last_mv[i][0][1] = my<<1;
1243 s->last_mv[i][1][1] = my<<1;
1245 s->mv[i][0][0] = mx;
1246 s->mv[i][0][1] = my;
1247 s->mv[i][1][0] = mx;//not used
1248 s->mv[i][1][1] = my;//not used
1250 if (s->picture_structure == PICT_FRAME) {
1251 mb_type |= MB_TYPE_16x16 | MB_TYPE_INTERLACED;
1253 //m = 1 + 2 * s->top_field_first;
1254 m = s->top_field_first ? 1 : 3;
1256 /* top -> top pred */
1257 s->mv[i][2][0] = ((mx * m + (mx > 0)) >> 1) + dmx;
1258 s->mv[i][2][1] = ((my * m + (my > 0)) >> 1) + dmy - 1;
1260 s->mv[i][3][0] = ((mx * m + (mx > 0)) >> 1) + dmx;
1261 s->mv[i][3][1] = ((my * m + (my > 0)) >> 1) + dmy + 1;
1263 mb_type |= MB_TYPE_16x16;
1265 s->mv[i][2][0] = ((mx + (mx > 0)) >> 1) + dmx;
1266 s->mv[i][2][1] = ((my + (my > 0)) >> 1) + dmy;
1267 if(s->picture_structure == PICT_TOP_FIELD)
1275 av_log(s->avctx, AV_LOG_ERROR, "00 motion_type at %d %d\n", s->mb_x, s->mb_y);
1284 if (HAS_CBP(mb_type)) {
1285 cbp = get_vlc2(&s->gb, mb_pat_vlc.table, MB_PAT_VLC_BITS, 1);
1287 av_log(s->avctx, AV_LOG_ERROR, "invalid cbp at %d %d\n", s->mb_x, s->mb_y);
1293 //on 1 we memcpy blocks in xvmcvideo
1294 if(s->avctx->xvmc_acceleration > 1){
1295 XVMC_pack_pblocks(s,cbp);
1302 if (s->codec_id == CODEC_ID_MPEG2VIDEO) {
1305 if (mpeg2_decode_block_non_intra(s, s->pblocks[i], i) < 0)
1308 s->block_last_index[i] = -1;
1315 if (mpeg1_decode_block_inter(s, s->pblocks[i], i) < 0)
1318 s->block_last_index[i] = -1;
1325 s->block_last_index[i] = -1;
1329 s->current_picture.mb_type[ s->mb_x + s->mb_y*s->mb_stride ]= mb_type;
1334 /* as h263, but only 17 codes */
1335 static int mpeg_decode_motion(MpegEncContext *s, int fcode, int pred)
1337 int code, sign, val, l, shift;
1339 code = get_vlc2(&s->gb, mv_vlc.table, MV_VLC_BITS, 2);
1347 sign = get_bits1(&s->gb);
1351 val = (val - 1) << shift;
1352 val |= get_bits(&s->gb, shift);
1359 /* modulo decoding */
1361 val = ((val + l)&(l*2-1)) - l;
1365 static inline int decode_dc(GetBitContext *gb, int component)
1369 if (component == 0) {
1370 code = get_vlc2(gb, dc_lum_vlc.table, DC_VLC_BITS, 2);
1372 code = get_vlc2(gb, dc_chroma_vlc.table, DC_VLC_BITS, 2);
1375 av_log(NULL, AV_LOG_ERROR, "invalid dc code at\n");
1381 diff = get_xbits(gb, code);
1386 static inline int mpeg1_decode_block_intra(MpegEncContext *s,
1390 int level, dc, diff, i, j, run;
1392 RLTable *rl = &rl_mpeg1;
1393 uint8_t * const scantable= s->intra_scantable.permutated;
1394 const uint16_t *quant_matrix= s->intra_matrix;
1395 const int qscale= s->qscale;
1398 component = (n <= 3 ? 0 : n - 4 + 1);
1399 diff = decode_dc(&s->gb, component);
1402 dc = s->last_dc[component];
1404 s->last_dc[component] = dc;
1406 dprintf("dc=%d diff=%d\n", dc, diff);
1409 OPEN_READER(re, &s->gb);
1410 /* now quantify & encode AC coefs */
1412 UPDATE_CACHE(re, &s->gb);
1413 GET_RL_VLC(level, run, re, &s->gb, rl->rl_vlc[0], TEX_VLC_BITS, 2);
1417 } else if(level != 0) {
1420 level= (level*qscale*quant_matrix[j])>>4;
1422 level = (level ^ SHOW_SBITS(re, &s->gb, 1)) - SHOW_SBITS(re, &s->gb, 1);
1423 LAST_SKIP_BITS(re, &s->gb, 1);
1426 run = SHOW_UBITS(re, &s->gb, 6)+1; LAST_SKIP_BITS(re, &s->gb, 6);
1427 UPDATE_CACHE(re, &s->gb);
1428 level = SHOW_SBITS(re, &s->gb, 8); SKIP_BITS(re, &s->gb, 8);
1429 if (level == -128) {
1430 level = SHOW_UBITS(re, &s->gb, 8) - 256; LAST_SKIP_BITS(re, &s->gb, 8);
1431 } else if (level == 0) {
1432 level = SHOW_UBITS(re, &s->gb, 8) ; LAST_SKIP_BITS(re, &s->gb, 8);
1438 level= (level*qscale*quant_matrix[j])>>4;
1442 level= (level*qscale*quant_matrix[j])>>4;
1447 av_log(s->avctx, AV_LOG_ERROR, "ac-tex damaged at %d %d\n", s->mb_x, s->mb_y);
1453 CLOSE_READER(re, &s->gb);
1455 s->block_last_index[n] = i;
1459 static inline int mpeg1_decode_block_inter(MpegEncContext *s,
1463 int level, i, j, run;
1464 RLTable *rl = &rl_mpeg1;
1465 uint8_t * const scantable= s->intra_scantable.permutated;
1466 const uint16_t *quant_matrix= s->inter_matrix;
1467 const int qscale= s->qscale;
1471 OPEN_READER(re, &s->gb);
1473 /* special case for the first coef. no need to add a second vlc table */
1474 UPDATE_CACHE(re, &s->gb);
1475 v= SHOW_UBITS(re, &s->gb, 2);
1477 LAST_SKIP_BITS(re, &s->gb, 2);
1478 level= (3*qscale*quant_matrix[0])>>5;
1486 /* now quantify & encode AC coefs */
1488 UPDATE_CACHE(re, &s->gb);
1489 GET_RL_VLC(level, run, re, &s->gb, rl->rl_vlc[0], TEX_VLC_BITS, 2);
1493 } else if(level != 0) {
1496 level= ((level*2+1)*qscale*quant_matrix[j])>>5;
1498 level = (level ^ SHOW_SBITS(re, &s->gb, 1)) - SHOW_SBITS(re, &s->gb, 1);
1499 LAST_SKIP_BITS(re, &s->gb, 1);
1502 run = SHOW_UBITS(re, &s->gb, 6)+1; LAST_SKIP_BITS(re, &s->gb, 6);
1503 UPDATE_CACHE(re, &s->gb);
1504 level = SHOW_SBITS(re, &s->gb, 8); SKIP_BITS(re, &s->gb, 8);
1505 if (level == -128) {
1506 level = SHOW_UBITS(re, &s->gb, 8) - 256; LAST_SKIP_BITS(re, &s->gb, 8);
1507 } else if (level == 0) {
1508 level = SHOW_UBITS(re, &s->gb, 8) ; LAST_SKIP_BITS(re, &s->gb, 8);
1514 level= ((level*2+1)*qscale*quant_matrix[j])>>5;
1518 level= ((level*2+1)*qscale*quant_matrix[j])>>5;
1523 av_log(s->avctx, AV_LOG_ERROR, "ac-tex damaged at %d %d\n", s->mb_x, s->mb_y);
1529 CLOSE_READER(re, &s->gb);
1531 s->block_last_index[n] = i;
1535 /* Also does unquantization here, since I will never support mpeg2
1537 static inline int mpeg2_decode_block_non_intra(MpegEncContext *s,
1541 int level, i, j, run;
1542 RLTable *rl = &rl_mpeg1;
1543 uint8_t * const scantable= s->intra_scantable.permutated;
1544 const uint16_t *quant_matrix;
1545 const int qscale= s->qscale;
1552 OPEN_READER(re, &s->gb);
1555 quant_matrix = s->inter_matrix;
1557 quant_matrix = s->chroma_inter_matrix;
1559 /* special case for the first coef. no need to add a second vlc table */
1560 UPDATE_CACHE(re, &s->gb);
1561 v= SHOW_UBITS(re, &s->gb, 2);
1563 LAST_SKIP_BITS(re, &s->gb, 2);
1564 level= (3*qscale*quant_matrix[0])>>5;
1572 /* now quantify & encode AC coefs */
1574 UPDATE_CACHE(re, &s->gb);
1575 GET_RL_VLC(level, run, re, &s->gb, rl->rl_vlc[0], TEX_VLC_BITS, 2);
1579 } else if(level != 0) {
1582 level= ((level*2+1)*qscale*quant_matrix[j])>>5;
1583 level = (level ^ SHOW_SBITS(re, &s->gb, 1)) - SHOW_SBITS(re, &s->gb, 1);
1584 LAST_SKIP_BITS(re, &s->gb, 1);
1587 run = SHOW_UBITS(re, &s->gb, 6)+1; LAST_SKIP_BITS(re, &s->gb, 6);
1588 UPDATE_CACHE(re, &s->gb);
1589 level = SHOW_SBITS(re, &s->gb, 12); SKIP_BITS(re, &s->gb, 12);
1594 level= ((-level*2+1)*qscale*quant_matrix[j])>>5;
1597 level= ((level*2+1)*qscale*quant_matrix[j])>>5;
1601 av_log(s->avctx, AV_LOG_ERROR, "ac-tex damaged at %d %d\n", s->mb_x, s->mb_y);
1608 CLOSE_READER(re, &s->gb);
1610 block[63] ^= (mismatch & 1);
1612 s->block_last_index[n] = i;
1616 static inline int mpeg2_decode_block_intra(MpegEncContext *s,
1620 int level, dc, diff, i, j, run;
1623 uint8_t * const scantable= s->intra_scantable.permutated;
1624 const uint16_t *quant_matrix;
1625 const int qscale= s->qscale;
1630 quant_matrix = s->intra_matrix;
1633 quant_matrix = s->chroma_intra_matrix;
1636 diff = decode_dc(&s->gb, component);
1639 dc = s->last_dc[component];
1641 s->last_dc[component] = dc;
1642 block[0] = dc << (3 - s->intra_dc_precision);
1643 dprintf("dc=%d\n", block[0]);
1644 mismatch = block[0] ^ 1;
1646 if (s->intra_vlc_format)
1652 OPEN_READER(re, &s->gb);
1653 /* now quantify & encode AC coefs */
1655 UPDATE_CACHE(re, &s->gb);
1656 GET_RL_VLC(level, run, re, &s->gb, rl->rl_vlc[0], TEX_VLC_BITS, 2);
1660 } else if(level != 0) {
1663 level= (level*qscale*quant_matrix[j])>>4;
1664 level = (level ^ SHOW_SBITS(re, &s->gb, 1)) - SHOW_SBITS(re, &s->gb, 1);
1665 LAST_SKIP_BITS(re, &s->gb, 1);
1668 run = SHOW_UBITS(re, &s->gb, 6)+1; LAST_SKIP_BITS(re, &s->gb, 6);
1669 UPDATE_CACHE(re, &s->gb);
1670 level = SHOW_SBITS(re, &s->gb, 12); SKIP_BITS(re, &s->gb, 12);
1674 level= (-level*qscale*quant_matrix[j])>>4;
1677 level= (level*qscale*quant_matrix[j])>>4;
1681 av_log(s->avctx, AV_LOG_ERROR, "ac-tex damaged at %d %d\n", s->mb_x, s->mb_y);
1688 CLOSE_READER(re, &s->gb);
1690 block[63]^= mismatch&1;
1692 s->block_last_index[n] = i;
1696 typedef struct Mpeg1Context {
1697 MpegEncContext mpeg_enc_ctx;
1698 int mpeg_enc_ctx_allocated; /* true if decoding context allocated */
1699 int repeat_field; /* true if we must repeat the field */
1700 AVPanScan pan_scan; /** some temporary storage for the panscan */
1703 static int mpeg_decode_init(AVCodecContext *avctx)
1705 Mpeg1Context *s = avctx->priv_data;
1707 s->mpeg_enc_ctx.avctx= avctx;
1708 s->mpeg_enc_ctx.flags= avctx->flags;
1709 s->mpeg_enc_ctx.flags2= avctx->flags2;
1710 common_init(&s->mpeg_enc_ctx);
1713 s->mpeg_enc_ctx_allocated = 0;
1714 s->mpeg_enc_ctx.picture_number = 0;
1715 s->repeat_field = 0;
1716 s->mpeg_enc_ctx.codec_id= avctx->codec->id;
1720 /* return the 8 bit start code value and update the search
1721 state. Return -1 if no start code found */
1722 static int find_start_code(uint8_t **pbuf_ptr, uint8_t *buf_end)
1725 unsigned int state=0xFFFFFFFF, v;
1728 buf_ptr = *pbuf_ptr;
1729 while (buf_ptr < buf_end) {
1731 if (state == 0x000001) {
1732 state = ((state << 8) | v) & 0xffffff;
1736 state = ((state << 8) | v) & 0xffffff;
1740 *pbuf_ptr = buf_ptr;
1744 static int mpeg1_decode_picture(AVCodecContext *avctx,
1745 uint8_t *buf, int buf_size)
1747 Mpeg1Context *s1 = avctx->priv_data;
1748 MpegEncContext *s = &s1->mpeg_enc_ctx;
1749 int ref, f_code, vbv_delay;
1751 init_get_bits(&s->gb, buf, buf_size*8);
1753 ref = get_bits(&s->gb, 10); /* temporal ref */
1754 s->pict_type = get_bits(&s->gb, 3);
1756 vbv_delay= get_bits(&s->gb, 16);
1757 if (s->pict_type == P_TYPE || s->pict_type == B_TYPE) {
1758 s->full_pel[0] = get_bits1(&s->gb);
1759 f_code = get_bits(&s->gb, 3);
1762 s->mpeg_f_code[0][0] = f_code;
1763 s->mpeg_f_code[0][1] = f_code;
1765 if (s->pict_type == B_TYPE) {
1766 s->full_pel[1] = get_bits1(&s->gb);
1767 f_code = get_bits(&s->gb, 3);
1770 s->mpeg_f_code[1][0] = f_code;
1771 s->mpeg_f_code[1][1] = f_code;
1773 s->current_picture.pict_type= s->pict_type;
1774 s->current_picture.key_frame= s->pict_type == I_TYPE;
1776 // if(avctx->debug & FF_DEBUG_PICT_INFO)
1777 // av_log(avctx, AV_LOG_DEBUG, "vbv_delay %d, ref %d\n", vbv_delay, ref);
1785 static void mpeg_decode_sequence_extension(MpegEncContext *s)
1787 int horiz_size_ext, vert_size_ext;
1789 int frame_rate_ext_n, frame_rate_ext_d;
1792 skip_bits(&s->gb, 1); /* profil and level esc*/
1793 profile= get_bits(&s->gb, 3);
1794 level= get_bits(&s->gb, 4);
1795 s->progressive_sequence = get_bits1(&s->gb); /* progressive_sequence */
1796 skip_bits(&s->gb, 2); /* chroma_format */
1797 horiz_size_ext = get_bits(&s->gb, 2);
1798 vert_size_ext = get_bits(&s->gb, 2);
1799 s->width |= (horiz_size_ext << 12);
1800 s->height |= (vert_size_ext << 12);
1801 bit_rate_ext = get_bits(&s->gb, 12); /* XXX: handle it */
1802 s->bit_rate = ((s->bit_rate / 400) | (bit_rate_ext << 12)) * 400;
1803 skip_bits1(&s->gb); /* marker */
1804 s->avctx->rc_buffer_size += get_bits(&s->gb, 8)*1024*16<<10;
1806 s->low_delay = get_bits1(&s->gb);
1807 if(s->flags & CODEC_FLAG_LOW_DELAY) s->low_delay=1;
1809 frame_rate_ext_n = get_bits(&s->gb, 2);
1810 frame_rate_ext_d = get_bits(&s->gb, 5);
1812 &s->avctx->frame_rate,
1813 &s->avctx->frame_rate_base,
1814 frame_rate_tab[s->frame_rate_index] * (frame_rate_ext_n+1),
1815 MPEG1_FRAME_RATE_BASE * (frame_rate_ext_d+1),
1818 dprintf("sequence extension\n");
1819 s->codec_id= s->avctx->codec_id= CODEC_ID_MPEG2VIDEO;
1820 s->avctx->sub_id = 2; /* indicates mpeg2 found */
1822 if(s->aspect_ratio_info <= 1)
1823 s->avctx->sample_aspect_ratio= mpeg2_aspect[s->aspect_ratio_info];
1825 s->avctx->sample_aspect_ratio=
1827 mpeg2_aspect[s->aspect_ratio_info],
1828 (AVRational){s->width, s->height}
1832 if(s->avctx->debug & FF_DEBUG_PICT_INFO)
1833 av_log(s->avctx, AV_LOG_DEBUG, "profile: %d, level: %d vbv buffer: %d, bitrate:%d\n",
1834 profile, level, s->avctx->rc_buffer_size, s->bit_rate);
1837 static void mpeg_decode_sequence_display_extension(Mpeg1Context *s1)
1839 MpegEncContext *s= &s1->mpeg_enc_ctx;
1840 int color_description, w, h;
1842 skip_bits(&s->gb, 3); /* video format */
1843 color_description= get_bits1(&s->gb);
1844 if(color_description){
1845 skip_bits(&s->gb, 8); /* color primaries */
1846 skip_bits(&s->gb, 8); /* transfer_characteristics */
1847 skip_bits(&s->gb, 8); /* matrix_coefficients */
1849 w= get_bits(&s->gb, 14);
1850 skip_bits(&s->gb, 1); //marker
1851 h= get_bits(&s->gb, 14);
1852 skip_bits(&s->gb, 1); //marker
1854 s1->pan_scan.width= 16*w;
1855 s1->pan_scan.height=16*h;
1857 if(s->aspect_ratio_info > 1)
1858 s->avctx->sample_aspect_ratio=
1860 mpeg2_aspect[s->aspect_ratio_info],
1864 if(s->avctx->debug & FF_DEBUG_PICT_INFO)
1865 av_log(s->avctx, AV_LOG_DEBUG, "sde w:%d, h:%d\n", w, h);
1868 static void mpeg_decode_picture_display_extension(Mpeg1Context *s1)
1870 MpegEncContext *s= &s1->mpeg_enc_ctx;
1873 for(i=0; i<1; i++){ //FIXME count
1874 s1->pan_scan.position[i][0]= get_sbits(&s->gb, 16);
1875 skip_bits(&s->gb, 1); //marker
1876 s1->pan_scan.position[i][1]= get_sbits(&s->gb, 16);
1877 skip_bits(&s->gb, 1); //marker
1880 if(s->avctx->debug & FF_DEBUG_PICT_INFO)
1881 av_log(s->avctx, AV_LOG_DEBUG, "pde (%d,%d) (%d,%d) (%d,%d)\n",
1882 s1->pan_scan.position[0][0], s1->pan_scan.position[0][1],
1883 s1->pan_scan.position[1][0], s1->pan_scan.position[1][1],
1884 s1->pan_scan.position[2][0], s1->pan_scan.position[2][1]
1888 static void mpeg_decode_quant_matrix_extension(MpegEncContext *s)
1892 dprintf("matrix extension\n");
1894 if (get_bits1(&s->gb)) {
1896 v = get_bits(&s->gb, 8);
1897 j= s->dsp.idct_permutation[ ff_zigzag_direct[i] ];
1898 s->intra_matrix[j] = v;
1899 s->chroma_intra_matrix[j] = v;
1902 if (get_bits1(&s->gb)) {
1904 v = get_bits(&s->gb, 8);
1905 j= s->dsp.idct_permutation[ ff_zigzag_direct[i] ];
1906 s->inter_matrix[j] = v;
1907 s->chroma_inter_matrix[j] = v;
1910 if (get_bits1(&s->gb)) {
1912 v = get_bits(&s->gb, 8);
1913 j= s->dsp.idct_permutation[ ff_zigzag_direct[i] ];
1914 s->chroma_intra_matrix[j] = v;
1917 if (get_bits1(&s->gb)) {
1919 v = get_bits(&s->gb, 8);
1920 j= s->dsp.idct_permutation[ ff_zigzag_direct[i] ];
1921 s->chroma_inter_matrix[j] = v;
1926 static void mpeg_decode_picture_coding_extension(MpegEncContext *s)
1928 s->full_pel[0] = s->full_pel[1] = 0;
1929 s->mpeg_f_code[0][0] = get_bits(&s->gb, 4);
1930 s->mpeg_f_code[0][1] = get_bits(&s->gb, 4);
1931 s->mpeg_f_code[1][0] = get_bits(&s->gb, 4);
1932 s->mpeg_f_code[1][1] = get_bits(&s->gb, 4);
1933 s->intra_dc_precision = get_bits(&s->gb, 2);
1934 s->picture_structure = get_bits(&s->gb, 2);
1935 s->top_field_first = get_bits1(&s->gb);
1936 s->frame_pred_frame_dct = get_bits1(&s->gb);
1937 s->concealment_motion_vectors = get_bits1(&s->gb);
1938 s->q_scale_type = get_bits1(&s->gb);
1939 s->intra_vlc_format = get_bits1(&s->gb);
1940 s->alternate_scan = get_bits1(&s->gb);
1941 s->repeat_first_field = get_bits1(&s->gb);
1942 s->chroma_420_type = get_bits1(&s->gb);
1943 s->progressive_frame = get_bits1(&s->gb);
1945 if(s->picture_structure == PICT_FRAME)
1948 s->first_field ^= 1;
1949 memset(s->mbskip_table, 0, s->mb_stride*s->mb_height);
1952 if(s->alternate_scan){
1953 ff_init_scantable(s->dsp.idct_permutation, &s->inter_scantable , ff_alternate_vertical_scan);
1954 ff_init_scantable(s->dsp.idct_permutation, &s->intra_scantable , ff_alternate_vertical_scan);
1956 ff_init_scantable(s->dsp.idct_permutation, &s->inter_scantable , ff_zigzag_direct);
1957 ff_init_scantable(s->dsp.idct_permutation, &s->intra_scantable , ff_zigzag_direct);
1960 /* composite display not parsed */
1961 dprintf("intra_dc_precision=%d\n", s->intra_dc_precision);
1962 dprintf("picture_structure=%d\n", s->picture_structure);
1963 dprintf("top field first=%d\n", s->top_field_first);
1964 dprintf("repeat first field=%d\n", s->repeat_first_field);
1965 dprintf("conceal=%d\n", s->concealment_motion_vectors);
1966 dprintf("intra_vlc_format=%d\n", s->intra_vlc_format);
1967 dprintf("alternate_scan=%d\n", s->alternate_scan);
1968 dprintf("frame_pred_frame_dct=%d\n", s->frame_pred_frame_dct);
1969 dprintf("progressive_frame=%d\n", s->progressive_frame);
1972 static void mpeg_decode_extension(AVCodecContext *avctx,
1973 uint8_t *buf, int buf_size)
1975 Mpeg1Context *s1 = avctx->priv_data;
1976 MpegEncContext *s = &s1->mpeg_enc_ctx;
1979 init_get_bits(&s->gb, buf, buf_size*8);
1981 ext_type = get_bits(&s->gb, 4);
1984 mpeg_decode_sequence_extension(s);
1987 mpeg_decode_sequence_display_extension(s1);
1990 mpeg_decode_quant_matrix_extension(s);
1993 mpeg_decode_picture_display_extension(s1);
1996 mpeg_decode_picture_coding_extension(s);
2001 static void exchange_uv(MpegEncContext *s){
2004 tmp = s->pblocks[4];
2005 s->pblocks[4] = s->pblocks[5];
2006 s->pblocks[5] = tmp;
2009 #define DECODE_SLICE_FATAL_ERROR -2
2010 #define DECODE_SLICE_ERROR -1
2011 #define DECODE_SLICE_OK 0
2015 * @return DECODE_SLICE_FATAL_ERROR if a non recoverable error occured<br>
2016 * DECODE_SLICE_ERROR if the slice is damaged<br>
2017 * DECODE_SLICE_OK if this slice is ok<br>
2019 static int mpeg_decode_slice(AVCodecContext *avctx,
2022 uint8_t **buf, int buf_size)
2024 Mpeg1Context *s1 = avctx->priv_data;
2025 MpegEncContext *s = &s1->mpeg_enc_ctx;
2027 const int field_pic= s->picture_structure != PICT_FRAME;
2029 s->resync_mb_x= s->mb_x =
2030 s->resync_mb_y= s->mb_y = -1;
2032 start_code = (start_code - 1) & 0xff;
2033 if (start_code >= s->mb_height){
2034 av_log(s->avctx, AV_LOG_ERROR, "slice below image (%d >= %d)\n", start_code, s->mb_height);
2038 ff_mpeg1_clean_buffers(s);
2039 s->interlaced_dct = 0;
2041 /* start frame decoding */
2042 if (s->first_slice) {
2043 if(s->first_field || s->picture_structure==PICT_FRAME){
2044 if(MPV_frame_start(s, avctx) < 0)
2045 return DECODE_SLICE_FATAL_ERROR;
2047 ff_er_frame_start(s);
2049 /* first check if we must repeat the frame */
2050 s->current_picture_ptr->repeat_pict = 0;
2051 if (s->repeat_first_field) {
2052 if (s->progressive_sequence) {
2053 if (s->top_field_first)
2054 s->current_picture_ptr->repeat_pict = 4;
2056 s->current_picture_ptr->repeat_pict = 2;
2057 } else if (s->progressive_frame) {
2058 s->current_picture_ptr->repeat_pict = 1;
2062 *s->current_picture_ptr->pan_scan= s1->pan_scan;
2063 }else{ //second field
2066 if(!s->current_picture_ptr){
2067 av_log(s->avctx, AV_LOG_ERROR, "first field missing\n");
2072 s->current_picture.data[i] = s->current_picture_ptr->data[i];
2073 if(s->picture_structure == PICT_BOTTOM_FIELD){
2074 s->current_picture.data[i] += s->current_picture_ptr->linesize[i];
2079 // MPV_frame_start will call this function too,
2080 // but we need to call it on every field
2081 if(s->avctx->xvmc_acceleration)
2082 XVMC_field_start(s,avctx);
2084 }//fi(s->first_slice)
2086 init_get_bits(&s->gb, *buf, buf_size*8);
2088 s->qscale = get_qscale(s);
2089 if (s->first_slice && (s->first_field || s->picture_structure==PICT_FRAME)) {
2090 if(s->avctx->debug&FF_DEBUG_PICT_INFO){
2091 av_log(s->avctx, AV_LOG_DEBUG, "qp:%d fc:%2d%2d%2d%2d %s %s %s %s %s dc:%d pstruct:%d fdct:%d cmv:%d qtype:%d ivlc:%d rff:%d %s\n",
2092 s->qscale, s->mpeg_f_code[0][0],s->mpeg_f_code[0][1],s->mpeg_f_code[1][0],s->mpeg_f_code[1][1],
2093 s->pict_type == I_TYPE ? "I" : (s->pict_type == P_TYPE ? "P" : (s->pict_type == B_TYPE ? "B" : "S")),
2094 s->progressive_sequence ? "ps" :"", s->progressive_frame ? "pf" : "", s->alternate_scan ? "alt" :"", s->top_field_first ? "top" :"",
2095 s->intra_dc_precision, s->picture_structure, s->frame_pred_frame_dct, s->concealment_motion_vectors,
2096 s->q_scale_type, s->intra_vlc_format, s->repeat_first_field, s->chroma_420_type ? "420" :"");
2102 av_log(s->avctx, AV_LOG_ERROR, "qscale == 0\n");
2106 /* extra slice info */
2107 while (get_bits1(&s->gb) != 0) {
2108 skip_bits(&s->gb, 8);
2114 int code = get_vlc2(&s->gb, mbincr_vlc.table, MBINCR_VLC_BITS, 2);
2116 av_log(s->avctx, AV_LOG_ERROR, "first mb_incr damaged\n");
2123 /* otherwise, stuffing, nothing to do */
2130 s->resync_mb_x= s->mb_x;
2131 s->resync_mb_y= s->mb_y = start_code;
2133 ff_init_block_index(s);
2137 //one 1 we memcpy blocks in xvmcvideo
2138 if(s->avctx->xvmc_acceleration > 1)
2139 XVMC_init_block(s);//set s->block
2142 s->dsp.clear_blocks(s->block[0]);
2144 ret = mpeg_decode_mb(s, s->block);
2145 s->chroma_qscale= s->qscale;
2147 dprintf("ret=%d\n", ret);
2151 if(s->current_picture.motion_val[0] && !s->encoding){ //note motion_val is normally NULL unless we want to extract the MVs
2152 const int wrap = field_pic ? 2*s->block_wrap[0] : s->block_wrap[0];
2153 int xy = s->mb_x*2 + 1 + (s->mb_y*2 +1)*wrap;
2154 int motion_for_top_x, motion_for_top_y, motion_back_top_x, motion_back_top_y;
2155 int motion_for_bottom_x, motion_for_bottom_y, motion_back_bottom_x, motion_back_bottom_y;
2156 if(field_pic && !s->first_field)
2160 motion_for_top_x = motion_for_top_y = motion_back_top_x = motion_back_top_y =
2161 motion_for_bottom_x = motion_for_bottom_y = motion_back_bottom_x = motion_back_bottom_y = 0;
2162 }else if (s->mv_type == MV_TYPE_16X16){
2163 motion_for_top_x = motion_for_bottom_x = s->mv[0][0][0];
2164 motion_for_top_y = motion_for_bottom_y = s->mv[0][0][1];
2165 motion_back_top_x = motion_back_bottom_x = s->mv[1][0][0];
2166 motion_back_top_y = motion_back_bottom_y = s->mv[1][0][1];
2167 } else /*if ((s->mv_type == MV_TYPE_FIELD) || (s->mv_type == MV_TYPE_16X8))*/ {
2168 motion_for_top_x = s->mv[0][0][0];
2169 motion_for_top_y = s->mv[0][0][1];
2170 motion_for_bottom_x = s->mv[0][1][0];
2171 motion_for_bottom_y = s->mv[0][1][1];
2172 motion_back_top_x = s->mv[1][0][0];
2173 motion_back_top_y = s->mv[1][0][1];
2174 motion_back_bottom_x = s->mv[1][1][0];
2175 motion_back_bottom_y = s->mv[1][1][1];
2178 s->current_picture.motion_val[0][xy][0] = motion_for_top_x;
2179 s->current_picture.motion_val[0][xy][1] = motion_for_top_y;
2180 s->current_picture.motion_val[0][xy + 1][0] = motion_for_top_x;
2181 s->current_picture.motion_val[0][xy + 1][1] = motion_for_top_y;
2182 s->current_picture.motion_val[0][xy + wrap][0] = motion_for_bottom_x;
2183 s->current_picture.motion_val[0][xy + wrap][1] = motion_for_bottom_y;
2184 s->current_picture.motion_val[0][xy + 1 + wrap][0] = motion_for_bottom_x;
2185 s->current_picture.motion_val[0][xy + 1 + wrap][1] = motion_for_bottom_y;
2187 if(s->pict_type != B_TYPE){
2188 motion_back_top_x = motion_back_top_y = motion_back_bottom_x = motion_back_bottom_y = 0;
2191 s->current_picture.motion_val[1][xy][0] = motion_back_top_x;
2192 s->current_picture.motion_val[1][xy][1] = motion_back_top_y;
2193 s->current_picture.motion_val[1][xy + 1][0] = motion_back_top_x;
2194 s->current_picture.motion_val[1][xy + 1][1] = motion_back_top_y;
2195 s->current_picture.motion_val[1][xy + wrap][0] = motion_back_bottom_x;
2196 s->current_picture.motion_val[1][xy + wrap][1] = motion_back_bottom_y;
2197 s->current_picture.motion_val[1][xy + 1 + wrap][0] = motion_back_bottom_x;
2198 s->current_picture.motion_val[1][xy + 1 + wrap][1] = motion_back_bottom_y;
2205 MPV_decode_mb(s, s->block);
2207 if (++s->mb_x >= s->mb_width) {
2209 ff_draw_horiz_band(s, 16*s->mb_y, 16);
2214 if(s->mb_y<<field_pic >= s->mb_height){
2215 int left= s->gb.size_in_bits - get_bits_count(&s->gb);
2217 if(left < 0 || (left && show_bits(&s->gb, FFMIN(left, 23)))
2218 || (avctx->error_resilience >= FF_ER_AGGRESSIVE && left>8)){
2219 av_log(avctx, AV_LOG_ERROR, "end mismatch left=%d\n", left);
2225 ff_init_block_index(s);
2228 /* skip mb handling */
2229 if (s->mb_skip_run == -1) {
2230 /* read again increment */
2233 int code = get_vlc2(&s->gb, mbincr_vlc.table, MBINCR_VLC_BITS, 2);
2235 av_log(s->avctx, AV_LOG_ERROR, "mb incr damaged\n");
2240 s->mb_skip_run += 33;
2241 }else if(code == 35){
2242 if(s->mb_skip_run != 0 || show_bits(&s->gb, 15) != 0){
2243 av_log(s->avctx, AV_LOG_ERROR, "slice mismatch\n");
2246 goto eos; /* end of slice */
2248 /* otherwise, stuffing, nothing to do */
2250 s->mb_skip_run += code;
2256 eos: // end of slice
2257 *buf += get_bits_count(&s->gb)/8 - 1;
2258 //printf("y %d %d %d %d\n", s->resync_mb_x, s->resync_mb_y, s->mb_x, s->mb_y);
2263 * handles slice ends.
2264 * @return 1 if it seems to be the last slice of
2266 static int slice_end(AVCodecContext *avctx, AVFrame *pict)
2268 Mpeg1Context *s1 = avctx->priv_data;
2269 MpegEncContext *s = &s1->mpeg_enc_ctx;
2271 if (!s1->mpeg_enc_ctx_allocated || !s->current_picture_ptr)
2275 if(s->avctx->xvmc_acceleration)
2278 /* end of slice reached */
2279 if (/*s->mb_y<<field_pic == s->mb_height &&*/ !s->first_field) {
2282 s->current_picture_ptr->qscale_type= FF_QSCALE_TYPE_MPEG2;
2288 if (s->pict_type == B_TYPE || s->low_delay) {
2289 *pict= *(AVFrame*)s->current_picture_ptr;
2290 ff_print_debug_info(s, pict);
2292 s->picture_number++;
2293 /* latency of 1 frame for I and P frames */
2294 /* XXX: use another variable than picture_number */
2295 if (s->last_picture_ptr != NULL) {
2296 *pict= *(AVFrame*)s->last_picture_ptr;
2297 ff_print_debug_info(s, pict);
2307 static int mpeg1_decode_sequence(AVCodecContext *avctx,
2308 uint8_t *buf, int buf_size)
2310 Mpeg1Context *s1 = avctx->priv_data;
2311 MpegEncContext *s = &s1->mpeg_enc_ctx;
2312 int width, height, i, v, j;
2315 init_get_bits(&s->gb, buf, buf_size*8);
2317 width = get_bits(&s->gb, 12);
2318 height = get_bits(&s->gb, 12);
2319 s->aspect_ratio_info= get_bits(&s->gb, 4);
2320 if (s->aspect_ratio_info == 0)
2322 aspect= 1.0/mpeg1_aspect[s->aspect_ratio_info];
2323 avctx->sample_aspect_ratio= av_d2q(aspect, 255);
2325 s->frame_rate_index = get_bits(&s->gb, 4);
2326 if (s->frame_rate_index == 0)
2328 s->bit_rate = get_bits(&s->gb, 18) * 400;
2329 if (get_bits1(&s->gb) == 0) /* marker */
2331 if (width <= 0 || height <= 0 ||
2332 (width % 2) != 0 || (height % 2) != 0)
2334 if (width != s->width ||
2335 height != s->height) {
2336 /* start new mpeg1 context decoding */
2337 s->out_format = FMT_MPEG1;
2338 if (s1->mpeg_enc_ctx_allocated) {
2343 avctx->has_b_frames= 1;
2344 avctx->width = width;
2345 avctx->height = height;
2348 &avctx->frame_rate_base,
2349 frame_rate_tab[s->frame_rate_index],
2350 MPEG1_FRAME_RATE_BASE, //FIXME store in allready reduced form
2353 avctx->bit_rate = s->bit_rate;
2355 //get_format() or set_video(width,height,aspect,pix_fmt);
2356 //until then pix_fmt may be changed right after codec init
2357 if( avctx->pix_fmt == PIX_FMT_XVMC_MPEG2_IDCT )
2358 if( avctx->idct_algo == FF_IDCT_AUTO )
2359 avctx->idct_algo = FF_IDCT_SIMPLE;
2361 if (MPV_common_init(s) < 0)
2363 s1->mpeg_enc_ctx_allocated = 1;
2364 s->swap_uv = 0;//just in case vcr2 and mpeg2 stream have been concatinated
2367 s->avctx->rc_buffer_size= get_bits(&s->gb, 10) * 1024*16;
2368 skip_bits(&s->gb, 1);
2371 if (get_bits1(&s->gb)) {
2373 v = get_bits(&s->gb, 8);
2374 j = s->intra_scantable.permutated[i];
2375 s->intra_matrix[j] = v;
2376 s->chroma_intra_matrix[j] = v;
2379 dprintf("intra matrix present\n");
2381 dprintf(" %d", s->intra_matrix[s->intra_scantable.permutated[i]]);
2386 int j= s->dsp.idct_permutation[i];
2387 v = ff_mpeg1_default_intra_matrix[i];
2388 s->intra_matrix[j] = v;
2389 s->chroma_intra_matrix[j] = v;
2392 if (get_bits1(&s->gb)) {
2394 v = get_bits(&s->gb, 8);
2395 j = s->intra_scantable.permutated[i];
2396 s->inter_matrix[j] = v;
2397 s->chroma_inter_matrix[j] = v;
2400 dprintf("non intra matrix present\n");
2402 dprintf(" %d", s->inter_matrix[s->intra_scantable.permutated[i]]);
2407 int j= s->dsp.idct_permutation[i];
2408 v = ff_mpeg1_default_non_intra_matrix[i];
2409 s->inter_matrix[j] = v;
2410 s->chroma_inter_matrix[j] = v;
2414 /* we set mpeg2 parameters so that it emulates mpeg1 */
2415 s->progressive_sequence = 1;
2416 s->progressive_frame = 1;
2417 s->picture_structure = PICT_FRAME;
2418 s->frame_pred_frame_dct = 1;
2419 s->codec_id= s->avctx->codec_id= CODEC_ID_MPEG1VIDEO;
2420 avctx->sub_id = 1; /* indicates mpeg1 */
2421 if(s->flags & CODEC_FLAG_LOW_DELAY) s->low_delay=1;
2423 if(s->avctx->debug & FF_DEBUG_PICT_INFO)
2424 av_log(s->avctx, AV_LOG_DEBUG, "vbv buffer: %d, bitrate:%d\n",
2425 s->avctx->rc_buffer_size, s->bit_rate);
2430 static int vcr2_init_sequence(AVCodecContext *avctx)
2432 Mpeg1Context *s1 = avctx->priv_data;
2433 MpegEncContext *s = &s1->mpeg_enc_ctx;
2436 /* start new mpeg1 context decoding */
2437 s->out_format = FMT_MPEG1;
2438 if (s1->mpeg_enc_ctx_allocated) {
2441 s->width = avctx->width;
2442 s->height = avctx->height;
2443 avctx->has_b_frames= 0; //true?
2446 //get_format() or set_video(width,height,aspect,pix_fmt);
2447 //until then pix_fmt may be changed right after codec init
2448 if( avctx->pix_fmt == PIX_FMT_XVMC_MPEG2_IDCT )
2449 if( avctx->idct_algo == FF_IDCT_AUTO )
2450 avctx->idct_algo = FF_IDCT_SIMPLE;
2452 if (MPV_common_init(s) < 0)
2454 exchange_uv(s);//common init reset pblocks, so we swap them here
2455 s->swap_uv = 1;// in case of xvmc we need to swap uv for each MB
2456 s1->mpeg_enc_ctx_allocated = 1;
2459 int j= s->dsp.idct_permutation[i];
2460 v = ff_mpeg1_default_intra_matrix[i];
2461 s->intra_matrix[j] = v;
2462 s->chroma_intra_matrix[j] = v;
2464 v = ff_mpeg1_default_non_intra_matrix[i];
2465 s->inter_matrix[j] = v;
2466 s->chroma_inter_matrix[j] = v;
2469 s->progressive_sequence = 1;
2470 s->progressive_frame = 1;
2471 s->picture_structure = PICT_FRAME;
2472 s->frame_pred_frame_dct = 1;
2473 s->codec_id= s->avctx->codec_id= CODEC_ID_MPEG2VIDEO;
2474 avctx->sub_id = 2; /* indicates mpeg2 */
2479 static void mpeg_decode_user_data(AVCodecContext *avctx,
2480 const uint8_t *buf, int buf_size)
2487 /* we parse the DTG active format information */
2489 p[0] == 'D' && p[1] == 'T' && p[2] == 'G' && p[3] == '1') {
2503 avctx->dtg_active_format = p[0] & 0x0f;
2509 * finds the end of the current frame in the bitstream.
2510 * @return the position of the first byte of the next frame, or -1
2512 static int mpeg1_find_frame_end(MpegEncContext *s, uint8_t *buf, int buf_size){
2513 ParseContext *pc= &s->parse_context;
2520 if(!pc->frame_start_found){
2521 for(i=0; i<buf_size; i++){
2522 state= (state<<8) | buf[i];
2523 if(state >= SLICE_MIN_START_CODE && state <= SLICE_MAX_START_CODE){
2525 pc->frame_start_found=1;
2531 if(pc->frame_start_found){
2532 for(; i<buf_size; i++){
2533 state= (state<<8) | buf[i];
2534 if((state&0xFFFFFF00) == 0x100){
2535 if(state < SLICE_MIN_START_CODE || state > SLICE_MAX_START_CODE){
2536 pc->frame_start_found=0;
2544 return END_NOT_FOUND;
2547 /* handle buffering and image synchronisation */
2548 static int mpeg_decode_frame(AVCodecContext *avctx,
2549 void *data, int *data_size,
2550 uint8_t *buf, int buf_size)
2552 Mpeg1Context *s = avctx->priv_data;
2553 uint8_t *buf_end, *buf_ptr;
2554 int ret, start_code, input_size;
2555 AVFrame *picture = data;
2556 MpegEncContext *s2 = &s->mpeg_enc_ctx;
2557 dprintf("fill_buffer\n");
2561 /* special case for last picture */
2562 if (buf_size == 0 && s2->low_delay==0 && s2->next_picture_ptr) {
2563 *picture= *(AVFrame*)s2->next_picture_ptr;
2564 s2->next_picture_ptr= NULL;
2566 *data_size = sizeof(AVFrame);
2570 if(s2->flags&CODEC_FLAG_TRUNCATED){
2571 int next= mpeg1_find_frame_end(s2, buf, buf_size);
2573 if( ff_combine_frame(s2, next, &buf, &buf_size) < 0 )
2578 buf_end = buf + buf_size;
2581 if (s->repeat_field % 2 == 1) {
2583 //fprintf(stderr,"\nRepeating last frame: %d -> %d! pict: %d %d", avctx->frame_number-1, avctx->frame_number,
2584 // s2->picture_number, s->repeat_field);
2585 if (avctx->flags & CODEC_FLAG_REPEAT_FIELD) {
2586 *data_size = sizeof(AVPicture);
2592 if(s->mpeg_enc_ctx_allocated==0 && avctx->codec_tag == ff_get_fourcc("VCR2"))
2593 vcr2_init_sequence(avctx);
2596 /* find start next code */
2597 start_code = find_start_code(&buf_ptr, buf_end);
2598 if (start_code < 0){
2599 if(s2->pict_type != B_TYPE || avctx->hurry_up==0){
2600 if (slice_end(avctx, picture)) {
2601 if(s2->last_picture_ptr || s2->low_delay) //FIXME merge with the stuff in mpeg_decode_slice
2602 *data_size = sizeof(AVPicture);
2605 return FFMAX(0, buf_ptr - buf - s2->parse_context.last_index);
2608 input_size = buf_end - buf_ptr;
2610 if(avctx->debug & FF_DEBUG_STARTCODE){
2611 av_log(avctx, AV_LOG_DEBUG, "%3X at %d left %d\n", start_code, buf_ptr-buf, input_size);
2614 /* prepare data for next start code */
2615 switch(start_code) {
2616 case SEQ_START_CODE:
2617 mpeg1_decode_sequence(avctx, buf_ptr,
2621 case PICTURE_START_CODE:
2622 /* we have a complete image : we try to decompress it */
2623 mpeg1_decode_picture(avctx,
2624 buf_ptr, input_size);
2626 case EXT_START_CODE:
2627 mpeg_decode_extension(avctx,
2628 buf_ptr, input_size);
2630 case USER_START_CODE:
2631 mpeg_decode_user_data(avctx,
2632 buf_ptr, input_size);
2634 case GOP_START_CODE:
2638 if (start_code >= SLICE_MIN_START_CODE &&
2639 start_code <= SLICE_MAX_START_CODE) {
2641 /* skip b frames if we dont have reference frames */
2642 if(s2->last_picture_ptr==NULL && s2->pict_type==B_TYPE) break;
2643 /* skip b frames if we are in a hurry */
2644 if(avctx->hurry_up && s2->pict_type==B_TYPE) break;
2645 /* skip everything if we are in a hurry>=5 */
2646 if(avctx->hurry_up>=5) break;
2648 if (!s->mpeg_enc_ctx_allocated) break;
2650 ret = mpeg_decode_slice(avctx, picture,
2651 start_code, &buf_ptr, input_size);
2655 if(s2->resync_mb_x>=0 && s2->resync_mb_y>=0)
2656 ff_er_add_slice(s2, s2->resync_mb_x, s2->resync_mb_y, s2->mb_x, s2->mb_y, AC_ERROR|DC_ERROR|MV_ERROR);
2657 if(ret==DECODE_SLICE_FATAL_ERROR) return -1;
2659 ff_er_add_slice(s2, s2->resync_mb_x, s2->resync_mb_y, s2->mb_x-1, s2->mb_y, AC_END|DC_END|MV_END);
2667 static int mpeg_decode_end(AVCodecContext *avctx)
2669 Mpeg1Context *s = avctx->priv_data;
2671 if (s->mpeg_enc_ctx_allocated)
2672 MPV_common_end(&s->mpeg_enc_ctx);
2676 AVCodec mpeg1video_decoder = {
2679 CODEC_ID_MPEG1VIDEO,
2680 sizeof(Mpeg1Context),
2685 CODEC_CAP_DRAW_HORIZ_BAND | CODEC_CAP_DR1 | CODEC_CAP_TRUNCATED,
2686 .flush= ff_mpeg_flush,
2689 AVCodec mpeg2video_decoder = {
2692 CODEC_ID_MPEG2VIDEO,
2693 sizeof(Mpeg1Context),
2698 CODEC_CAP_DRAW_HORIZ_BAND | CODEC_CAP_DR1 | CODEC_CAP_TRUNCATED,
2699 .flush= ff_mpeg_flush,
2703 AVCodec mpegvideo_decoder = {
2706 CODEC_ID_MPEG2VIDEO,
2707 sizeof(Mpeg1Context),
2712 CODEC_CAP_DRAW_HORIZ_BAND | CODEC_CAP_DR1 | CODEC_CAP_TRUNCATED,
2713 .flush= ff_mpeg_flush,
2716 #ifdef CONFIG_ENCODERS
2718 AVCodec mpeg1video_encoder = {
2721 CODEC_ID_MPEG1VIDEO,
2722 sizeof(MpegEncContext),
2730 AVCodec mpeg2video_encoder = {
2733 CODEC_ID_MPEG2VIDEO,
2734 sizeof(MpegEncContext),
2743 static int mpeg_mc_decode_init(AVCodecContext *avctx){
2746 if( !(avctx->slice_flags & SLICE_FLAG_CODED_ORDER) )
2748 if( !(avctx->slice_flags & SLICE_FLAG_ALLOW_FIELD) ){
2749 dprintf("mpeg12.c: XvMC decoder will work better if SLICE_FLAG_ALLOW_FIELD is set\n");
2751 mpeg_decode_init(avctx);
2752 s = avctx->priv_data;
2754 avctx->pix_fmt = PIX_FMT_XVMC_MPEG2_IDCT;
2755 avctx->xvmc_acceleration = 2;//2 - the blocks are packed!
2760 AVCodec mpeg_xvmc_decoder = {
2763 CODEC_ID_MPEG2VIDEO_XVMC,
2764 sizeof(Mpeg1Context),
2765 mpeg_mc_decode_init,
2769 CODEC_CAP_DRAW_HORIZ_BAND | CODEC_CAP_DR1 | CODEC_CAP_TRUNCATED,
2774 /* this is ugly i know, but the alternative is too make
2775 hundreds of vars global and prefix them with ff_mpeg1_
2776 which is far uglier. */