Commit fe906830 authored by Michael Niedermayer's avatar Michael Niedermayer

Revert "mpeg12: move closed_gop from MpegEncContext to Mpeg1Context"

This reverts commit 3fc08304.
The revert is done because the reasoning behind the commit was
flawed, closed_gop is not mpeg1/2 specific.

Conflicts:

	libavcodec/mpeg12.c
	libavcodec/mpeg12.h
parent 2b0cdb73
...@@ -2158,7 +2158,7 @@ static void mpeg_decode_gop(AVCodecContext *avctx, ...@@ -2158,7 +2158,7 @@ static void mpeg_decode_gop(AVCodecContext *avctx,
time_code_seconds = get_bits(&s->gb, 6); time_code_seconds = get_bits(&s->gb, 6);
time_code_pictures = get_bits(&s->gb, 6); time_code_pictures = get_bits(&s->gb, 6);
s1->closed_gop = get_bits1(&s->gb); s->closed_gop = get_bits1(&s->gb);
/*broken_link indicate that after editing the /*broken_link indicate that after editing the
reference frames of the first B-Frames after GOP I-Frame reference frames of the first B-Frames after GOP I-Frame
are missing (open gop)*/ are missing (open gop)*/
...@@ -2438,7 +2438,7 @@ static int decode_chunks(AVCodecContext *avctx, ...@@ -2438,7 +2438,7 @@ static int decode_chunks(AVCodecContext *avctx,
if (s2->last_picture_ptr == NULL) { if (s2->last_picture_ptr == NULL) {
/* Skip B-frames if we do not have reference frames and gop is not closed */ /* Skip B-frames if we do not have reference frames and gop is not closed */
if (s2->pict_type == AV_PICTURE_TYPE_B) { if (s2->pict_type == AV_PICTURE_TYPE_B) {
if (!s->closed_gop) if (!s2->closed_gop)
break; break;
} }
} }
...@@ -2523,7 +2523,6 @@ static void flush(AVCodecContext *avctx) ...@@ -2523,7 +2523,6 @@ static void flush(AVCodecContext *avctx)
Mpeg1Context *s = avctx->priv_data; Mpeg1Context *s = avctx->priv_data;
s->sync=0; s->sync=0;
s->closed_gop = 0;
ff_mpeg_flush(avctx); ff_mpeg_flush(avctx);
} }
......
...@@ -42,7 +42,6 @@ typedef struct Mpeg1Context { ...@@ -42,7 +42,6 @@ typedef struct Mpeg1Context {
AVRational frame_rate_ext; ///< MPEG-2 specific framerate modificator AVRational frame_rate_ext; ///< MPEG-2 specific framerate modificator
int sync; ///< Did we reach a sync point like a GOP/SEQ/KEYFrame? int sync; ///< Did we reach a sync point like a GOP/SEQ/KEYFrame?
int full_pel[2]; int full_pel[2];
int closed_gop; ///< GOP is closed
int tmpgexs; int tmpgexs;
} Mpeg1Context; } Mpeg1Context;
......
...@@ -2425,6 +2425,7 @@ void ff_mpeg_flush(AVCodecContext *avctx){ ...@@ -2425,6 +2425,7 @@ void ff_mpeg_flush(AVCodecContext *avctx){
s->current_picture_ptr = s->last_picture_ptr = s->next_picture_ptr = NULL; s->current_picture_ptr = s->last_picture_ptr = s->next_picture_ptr = NULL;
s->mb_x= s->mb_y= 0; s->mb_x= s->mb_y= 0;
s->closed_gop= 0;
s->parse_context.state= -1; s->parse_context.state= -1;
s->parse_context.frame_start_found= 0; s->parse_context.frame_start_found= 0;
......
...@@ -331,6 +331,7 @@ typedef struct MpegEncContext { ...@@ -331,6 +331,7 @@ typedef struct MpegEncContext {
int *lambda_table; int *lambda_table;
int adaptive_quant; ///< use adaptive quantization int adaptive_quant; ///< use adaptive quantization
int dquant; ///< qscale difference to prev qscale int dquant; ///< qscale difference to prev qscale
int closed_gop; ///< MPEG1/2 GOP is closed
int pict_type; ///< AV_PICTURE_TYPE_I, AV_PICTURE_TYPE_P, AV_PICTURE_TYPE_B, ... int pict_type; ///< AV_PICTURE_TYPE_I, AV_PICTURE_TYPE_P, AV_PICTURE_TYPE_B, ...
int last_pict_type; //FIXME removes int last_pict_type; //FIXME removes
int last_non_b_pict_type; ///< used for mpeg4 gmc b-frames & ratecontrol int last_non_b_pict_type; ///< used for mpeg4 gmc b-frames & ratecontrol
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment