mirror of
				https://github.com/nyanmisaka/ffmpeg-rockchip.git
				synced 2025-10-26 02:10:55 +08:00 
			
		
		
		
	- 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
This commit is contained in:
		| @@ -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; | ||||
|                         } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Juanjo
					Juanjo