Check for out of bound reads in xan_huffman_decode() of the xan decoder.
Signed-off-by: Michael Niedermayer <michaelni@gmx.at> (cherry picked from commit c8b835954ae4aef797112afda3b52f8dfe3c7b74)
This commit is contained in:
parent
626f11b3bc
commit
f9efe1d76e
@ -114,7 +114,10 @@ static int xan_huffman_decode(unsigned char *dest, int dest_len,
|
||||
init_get_bits(&gb, ptr, ptr_len * 8);
|
||||
|
||||
while ( val != 0x16 ) {
|
||||
val = src[val - 0x17 + get_bits1(&gb) * byte];
|
||||
unsigned idx = val - 0x17 + get_bits1(&gb) * byte;
|
||||
if (idx >= 2 * byte)
|
||||
return -1;
|
||||
val = src[idx];
|
||||
|
||||
if ( val < 0x16 ) {
|
||||
if (dest >= dest_end)
|
||||
|
Loading…
x
Reference in New Issue
Block a user