Commit 48efe9ec authored by Michael Niedermayer's avatar Michael Niedermayer

avcodec/utvideodec: Fix undefined behavior in shift

Fixes: asan_heap-oob_2573085_3783_utvideo_rgba_median.avi
Found-by: Mateusz "j00ru" Jurczyk and Gynvael Coldwind
Signed-off-by: 's avatarMichael Niedermayer <michaelni@gmx.at>
parent 35dcc8a0
...@@ -56,13 +56,14 @@ static int build_huff(const uint8_t *src, VLC *vlc, int *fsym) ...@@ -56,13 +56,14 @@ static int build_huff(const uint8_t *src, VLC *vlc, int *fsym)
*fsym = he[0].sym; *fsym = he[0].sym;
return 0; return 0;
} }
if (he[0].len > 32)
return -1;
last = 255; last = 255;
while (he[last].len == 255 && last) while (he[last].len == 255 && last)
last--; last--;
if (he[last].len > 32)
return -1;
code = 1; code = 1;
for (i = last; i >= 0; i--) { for (i = last; i >= 0; i--) {
codes[i] = code >> (32 - he[i].len); codes[i] = code >> (32 - he[i].len);
......
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