aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMichael Niedermayer <michaelni@gmx.at>2010-03-10 09:55:03 +0000
committerMichael Niedermayer <michaelni@gmx.at>2010-03-10 09:55:03 +0000
commit9885284c2259847b0d2b34b5574e3276607e37e4 (patch)
tree1cec243e66d6e9df26bf1108a1c5b95da12eb468
parent83c2bc7abba62e1de16584b5adb82f77f2e9604e (diff)
downloadffmpeg-9885284c2259847b0d2b34b5574e3276607e37e4.tar.gz
Check level_prefix a bit (this just checks the max our bitreader can handle,
as i did nt find a limit in the spec) This should stop cavlc_decode_residual() on a zero bitstream Originally committed as revision 22429 to svn://svn.ffmpeg.org/ffmpeg/trunk
-rw-r--r--libavcodec/h264_cavlc.c7
1 files changed, 6 insertions, 1 deletions
diff --git a/libavcodec/h264_cavlc.c b/libavcodec/h264_cavlc.c
index ef92218b4f..7da645dcd3 100644
--- a/libavcodec/h264_cavlc.c
+++ b/libavcodec/h264_cavlc.c
@@ -431,8 +431,13 @@ static int decode_residual(H264Context *h, GetBitContext *gb, DCTELEM *block, in
level_code= prefix + get_bits(gb, 4); //part
}else{
level_code= 30 + get_bits(gb, prefix-3); //part
- if(prefix>=16)
+ if(prefix>=16){
+ if(prefix > 25+3){
+ av_log(h->s.avctx, AV_LOG_ERROR, "Invalid level prefix\n");
+ return -1;
+ }
level_code += (1<<(prefix-3))-4096;
+ }
}
if(trailing_ones < 3) level_code += 2;