mirror of
https://git.ffmpeg.org/ffmpeg.git
synced 2025-03-04 03:28:05 +00:00
fix multiple slices per frame
Originally committed as revision 17137 to svn://svn.ffmpeg.org/ffmpeg/trunk
This commit is contained in:
parent
4ca6f4b29c
commit
b9fce05205
@ -608,8 +608,6 @@ int ff_cavs_next_mb(AVSContext *h) {
|
|||||||
h->cv = h->picture.data[2] + h->mby*8*h->c_stride;
|
h->cv = h->picture.data[2] + h->mby*8*h->c_stride;
|
||||||
if(h->mby == h->mb_height) { //frame end
|
if(h->mby == h->mb_height) { //frame end
|
||||||
return 0;
|
return 0;
|
||||||
} else {
|
|
||||||
//check_for_slice(h);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return 1;
|
return 1;
|
||||||
|
@ -415,6 +415,9 @@ static inline int decode_slice_header(AVSContext *h, GetBitContext *gb) {
|
|||||||
if(h->stc > 0xAF)
|
if(h->stc > 0xAF)
|
||||||
av_log(h->s.avctx, AV_LOG_ERROR, "unexpected start code 0x%02x\n", h->stc);
|
av_log(h->s.avctx, AV_LOG_ERROR, "unexpected start code 0x%02x\n", h->stc);
|
||||||
h->mby = h->stc;
|
h->mby = h->stc;
|
||||||
|
|
||||||
|
/* mark top macroblocks as unavailable */
|
||||||
|
h->flags &= ~(B_AVAIL|C_AVAIL);
|
||||||
if((h->mby == 0) && (!h->qp_fixed)){
|
if((h->mby == 0) && (!h->qp_fixed)){
|
||||||
h->qp_fixed = get_bits1(gb);
|
h->qp_fixed = get_bits1(gb);
|
||||||
h->qp = get_bits(gb,6);
|
h->qp = get_bits(gb,6);
|
||||||
@ -431,6 +434,9 @@ static inline int decode_slice_header(AVSContext *h, GetBitContext *gb) {
|
|||||||
static inline void check_for_slice(AVSContext *h) {
|
static inline void check_for_slice(AVSContext *h) {
|
||||||
GetBitContext *gb = &h->s.gb;
|
GetBitContext *gb = &h->s.gb;
|
||||||
int align;
|
int align;
|
||||||
|
|
||||||
|
if(h->mbx)
|
||||||
|
return;
|
||||||
align = (-get_bits_count(gb)) & 7;
|
align = (-get_bits_count(gb)) & 7;
|
||||||
if((show_bits_long(gb,24+align) & 0xFFFFFF) == 0x000001) {
|
if((show_bits_long(gb,24+align) & 0xFFFFFF) == 0x000001) {
|
||||||
skip_bits_long(gb,24+align);
|
skip_bits_long(gb,24+align);
|
||||||
@ -525,13 +531,14 @@ static int decode_pic(AVSContext *h) {
|
|||||||
} else {
|
} else {
|
||||||
h->alpha_offset = h->beta_offset = 0;
|
h->alpha_offset = h->beta_offset = 0;
|
||||||
}
|
}
|
||||||
check_for_slice(h);
|
|
||||||
if(h->pic_type == FF_I_TYPE) {
|
if(h->pic_type == FF_I_TYPE) {
|
||||||
do {
|
do {
|
||||||
|
check_for_slice(h);
|
||||||
decode_mb_i(h, 0);
|
decode_mb_i(h, 0);
|
||||||
} while(ff_cavs_next_mb(h));
|
} while(ff_cavs_next_mb(h));
|
||||||
} else if(h->pic_type == FF_P_TYPE) {
|
} else if(h->pic_type == FF_P_TYPE) {
|
||||||
do {
|
do {
|
||||||
|
check_for_slice(h);
|
||||||
if(h->skip_mode_flag) {
|
if(h->skip_mode_flag) {
|
||||||
skip_count = get_ue_golomb(&s->gb);
|
skip_count = get_ue_golomb(&s->gb);
|
||||||
while(skip_count--) {
|
while(skip_count--) {
|
||||||
@ -539,6 +546,7 @@ static int decode_pic(AVSContext *h) {
|
|||||||
if(!ff_cavs_next_mb(h))
|
if(!ff_cavs_next_mb(h))
|
||||||
goto done;
|
goto done;
|
||||||
}
|
}
|
||||||
|
check_for_slice(h);
|
||||||
mb_type = get_ue_golomb(&s->gb) + P_16X16;
|
mb_type = get_ue_golomb(&s->gb) + P_16X16;
|
||||||
} else
|
} else
|
||||||
mb_type = get_ue_golomb(&s->gb) + P_SKIP;
|
mb_type = get_ue_golomb(&s->gb) + P_SKIP;
|
||||||
@ -549,6 +557,7 @@ static int decode_pic(AVSContext *h) {
|
|||||||
} while(ff_cavs_next_mb(h));
|
} while(ff_cavs_next_mb(h));
|
||||||
} else { /* FF_B_TYPE */
|
} else { /* FF_B_TYPE */
|
||||||
do {
|
do {
|
||||||
|
check_for_slice(h);
|
||||||
if(h->skip_mode_flag) {
|
if(h->skip_mode_flag) {
|
||||||
skip_count = get_ue_golomb(&s->gb);
|
skip_count = get_ue_golomb(&s->gb);
|
||||||
while(skip_count--) {
|
while(skip_count--) {
|
||||||
@ -556,6 +565,7 @@ static int decode_pic(AVSContext *h) {
|
|||||||
if(!ff_cavs_next_mb(h))
|
if(!ff_cavs_next_mb(h))
|
||||||
goto done;
|
goto done;
|
||||||
}
|
}
|
||||||
|
check_for_slice(h);
|
||||||
mb_type = get_ue_golomb(&s->gb) + B_DIRECT;
|
mb_type = get_ue_golomb(&s->gb) + B_DIRECT;
|
||||||
} else
|
} else
|
||||||
mb_type = get_ue_golomb(&s->gb) + B_SKIP;
|
mb_type = get_ue_golomb(&s->gb) + B_SKIP;
|
||||||
|
Loading…
Reference in New Issue
Block a user