Commit 65410e35 authored by michael's avatar michael

prevent assert failures and infinite loops with broken streams


git-svn-id: file:///var/local/repositories/ffmpeg/trunk@4538 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent a6555840
...@@ -5363,6 +5363,8 @@ static int decode_cabac_mb_dqp( H264Context *h) { ...@@ -5363,6 +5363,8 @@ static int decode_cabac_mb_dqp( H264Context *h) {
else else
ctx = 3; ctx = 3;
val++; val++;
if(val > 52) //prevent infinite loop
return INT_MIN;
} }
if( val&0x01 ) if( val&0x01 )
...@@ -6548,7 +6550,7 @@ static void filter_mb( H264Context *h, int mb_x, int mb_y, uint8_t *img_y, uint8 ...@@ -6548,7 +6550,7 @@ static void filter_mb( H264Context *h, int mb_x, int mb_y, uint8_t *img_y, uint8
bS[0] = bS[1] = bS[2] = bS[3] = 3; bS[0] = bS[1] = bS[2] = bS[3] = 3;
} else { } else {
// TODO // TODO
assert(0); av_log(h->s.avctx, AV_LOG_ERROR, "both non intra (TODO)\n");
} }
/* Filter edge */ /* Filter edge */
// Do not use s->qscale as luma quantizer because it has not the same // Do not use s->qscale as luma quantizer because it has not the same
...@@ -6569,7 +6571,7 @@ static void filter_mb( H264Context *h, int mb_x, int mb_y, uint8_t *img_y, uint8 ...@@ -6569,7 +6571,7 @@ static void filter_mb( H264Context *h, int mb_x, int mb_y, uint8_t *img_y, uint8
bS[0] = bS[1] = bS[2] = bS[3] = 3; bS[0] = bS[1] = bS[2] = bS[3] = 3;
} else { } else {
// TODO // TODO
assert(0); av_log(h->s.avctx, AV_LOG_ERROR, "both non intra (TODO)\n");
} }
/* Filter edge */ /* Filter edge */
// Do not use s->qscale as luma quantizer because it has not the same // Do not use s->qscale as luma quantizer because it has not the same
...@@ -6701,7 +6703,7 @@ static int decode_slice(H264Context *h){ ...@@ -6701,7 +6703,7 @@ static int decode_slice(H264Context *h){
if(ret>=0) ret = decode_mb_cabac(h); if(ret>=0) ret = decode_mb_cabac(h);
hl_decode_mb(h); if(ret>=0) hl_decode_mb(h);
s->mb_y--; s->mb_y--;
} }
eos = get_cabac_terminate( &h->cabac ); eos = get_cabac_terminate( &h->cabac );
......
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