summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorLaurent Aimar <fenrir@videolan.org>2011-09-12 23:49:36 +0200
committerReinhard Tartler <siretart@tauware.de>2011-09-26 19:26:32 +0200
commit0d93b03e6861fafd3eddd9ee164cf56630c9d899 (patch)
tree2533c8266d71328b5f8253ec4b7f1a5b53cad311
parent5b1f79b092a4684c1e700ea21d5da77c68ca7d44 (diff)
downloadffmpeg-0d93b03e6861fafd3eddd9ee164cf56630c9d899.tar.gz
Check for invalid VLC value in smacker decoder.
Signed-off-by: Martin Storsjö <martin@martin.st> (cherry picked from commit 6489455495fc5bfbebcfe3f57e5d4fdd6a781091) Signed-off-by: Anton Khirnov <anton@khirnov.net>
-rw-r--r--libavcodec/smacker.c2
1 files changed, 2 insertions, 0 deletions
diff --git a/libavcodec/smacker.c b/libavcodec/smacker.c
index e8de0d89c5..9628b07492 100644
--- a/libavcodec/smacker.c
+++ b/libavcodec/smacker.c
@@ -139,6 +139,8 @@ static int smacker_decode_bigtree(GetBitContext *gb, HuffContext *hc, DBCtx *ctx
b2 = get_bits_count(gb);
i2 = ctx->v2->table ? get_vlc2(gb, ctx->v2->table, SMKTREE_BITS, 3) : 0;
b2 = get_bits_count(gb) - b2;
+ if (i1 < 0 || i2 < 0)
+ return -1;
val = ctx->recode1[i1] | (ctx->recode2[i2] << 8);
if(val == ctx->escapes[0]) {
ctx->last[0] = hc->current;