diff options
author | Juanjo <pulento@users.sourceforge.net> | 2002-03-16 02:41:00 +0000 |
---|---|---|
committer | Juanjo <pulento@users.sourceforge.net> | 2002-03-16 02:41:00 +0000 |
commit | 1cb0edb40b8e94e1a50ad40c40d43e34ed8435fe (patch) | |
tree | 039381a325e1315f034c025e04137e33c3e6759f /libavcodec/mpeg12.c | |
parent | 4278e7a6f5a9c2fd3e43efdeee583972fe5fb72f (diff) | |
download | ffmpeg-1cb0edb40b8e94e1a50ad40c40d43e34ed8435fe.tar.gz |
- Bug fix MPEG-2 decoder to handle "repeat_first_field" (Telecine)
- Hack in MPEG-2 demux to cope with buggy VOBs.
Originally committed as revision 333 to svn://svn.ffmpeg.org/ffmpeg/trunk
Diffstat (limited to 'libavcodec/mpeg12.c')
-rw-r--r-- | libavcodec/mpeg12.c | 30 |
1 files changed, 26 insertions, 4 deletions
diff --git a/libavcodec/mpeg12.c b/libavcodec/mpeg12.c index 41bf524e4a..e366702273 100644 --- a/libavcodec/mpeg12.c +++ b/libavcodec/mpeg12.c @@ -1119,6 +1119,7 @@ typedef struct Mpeg1Context { UINT8 *buf_ptr; int buffer_size; int mpeg_enc_ctx_allocated; /* true if decoding context allocated */ + int repeat_field; /* true if we must repeat the field */ } Mpeg1Context; static int mpeg_decode_init(AVCodecContext *avctx) @@ -1131,6 +1132,7 @@ static int mpeg_decode_init(AVCodecContext *avctx) s->start_code = -1; s->buf_ptr = s->buffer; s->mpeg_enc_ctx.picture_number = 0; + s->repeat_field = 0; return 0; } @@ -1203,7 +1205,7 @@ static void mpeg_decode_sequence_extension(MpegEncContext *s) int frame_rate_ext_n, frame_rate_ext_d; skip_bits(&s->gb, 8); /* profil and level */ - skip_bits(&s->gb, 1); /* progressive_sequence */ + s->progressive_sequence = get_bits1(&s->gb); /* progressive_sequence */ skip_bits(&s->gb, 2); /* chroma_format */ horiz_size_ext = get_bits(&s->gb, 2); vert_size_ext = get_bits(&s->gb, 2); @@ -1279,12 +1281,13 @@ static void mpeg_decode_picture_coding_extension(MpegEncContext *s) s->chroma_420_type = get_bits1(&s->gb); s->progressive_frame = get_bits1(&s->gb); /* composite display not parsed */ - dprintf("intra_dc_precion=%d\n", s->intra_dc_precision); + dprintf("intra_dc_precision=%d\n", s->intra_dc_precision); dprintf("picture_structure=%d\n", s->picture_structure); dprintf("conceal=%d\n", s->concealment_motion_vectors); dprintf("intra_vlc_format=%d\n", s->intra_vlc_format); dprintf("alternate_scan=%d\n", s->alternate_scan); dprintf("frame_pred_frame_dct=%d\n", s->frame_pred_frame_dct); + dprintf("progressive_frame=%d\n", s->progressive_frame); } static void mpeg_decode_extension(AVCodecContext *avctx, @@ -1434,6 +1437,7 @@ static int mpeg1_decode_sequence(AVCodecContext *avctx, avctx->width = width; avctx->height = height; avctx->frame_rate = frame_rate_tab[s->frame_rate_index]; + s->frame_rate = avctx->frame_rate; avctx->bit_rate = s->bit_rate; if (MPV_common_init(s) < 0) @@ -1505,13 +1509,14 @@ static int mpeg_decode_frame(AVCodecContext *avctx, UINT8 *buf_end, *buf_ptr, *buf_start; int len, start_code_found, ret, code, start_code, input_size; AVPicture *picture = data; - + MpegEncContext *s2 = &s->mpeg_enc_ctx; + dprintf("fill_buffer\n"); *data_size = 0; + /* special case for last picture */ if (buf_size == 0) { - MpegEncContext *s2 = &s->mpeg_enc_ctx; if (s2->picture_number > 0) { picture->data[0] = s2->next_picture[0]; picture->data[1] = s2->next_picture[1]; @@ -1526,6 +1531,15 @@ static int mpeg_decode_frame(AVCodecContext *avctx, buf_ptr = buf; buf_end = buf + buf_size; + + if (s->repeat_field % 2 == 1) { + s->repeat_field++; + //fprintf(stderr,"\nRepeating last frame: %d -> %d! pict: %d %d", avctx->frame_number-1, avctx->frame_number, + // s2->picture_number, s->repeat_field); + *data_size = 1; + goto the_end; + } + while (buf_ptr < buf_end) { buf_start = buf_ptr; /* find start next code */ @@ -1574,6 +1588,14 @@ static int mpeg_decode_frame(AVCodecContext *avctx, start_code, s->buffer, input_size); if (ret == 1) { /* got a picture: exit */ + /* first check if we must repeat the frame */ + if (s2->progressive_frame && s2->repeat_first_field) { + //fprintf(stderr,"\nRepeat this frame: %d! pict: %d",avctx->frame_number,s2->picture_number); + s2->repeat_first_field = 0; + s2->progressive_frame = 0; + if (++s->repeat_field > 2) + s->repeat_field = 0; + } *data_size = sizeof(AVPicture); goto the_end; } |