diff options
author | Michael Niedermayer <michaelni@gmx.at> | 2014-02-03 05:04:42 +0100 |
---|---|---|
committer | Michael Niedermayer <michaelni@gmx.at> | 2014-02-03 05:15:41 +0100 |
commit | 6e42ccb9dbc13836cd52cda594f819d17af9afa2 (patch) | |
tree | fcc5d939b346875aa04dad78b43155ff0321a984 /libavcodec/aacdec.c | |
parent | 4d7d9a57825ee7a6394d361b5c5b6f16422b361c (diff) | |
download | ffmpeg-6e42ccb9dbc13836cd52cda594f819d17af9afa2.tar.gz |
avcodec/aacdec: Fix pulse position checks in decode_pulses()
Fixes out of array read
Fixes: asan_static-oob_1efed25_1887_cov_2013541199_HeyYa_RA10_AAC_192K_30s.rm
Found-by: Mateusz "j00ru" Jurczyk and Gynvael Coldwind
Signed-off-by: Michael Niedermayer <michaelni@gmx.at>
Diffstat (limited to 'libavcodec/aacdec.c')
-rw-r--r-- | libavcodec/aacdec.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/libavcodec/aacdec.c b/libavcodec/aacdec.c index 27f4b4c660..a420c3643a 100644 --- a/libavcodec/aacdec.c +++ b/libavcodec/aacdec.c @@ -1426,12 +1426,12 @@ static int decode_pulses(Pulse *pulse, GetBitContext *gb, return -1; pulse->pos[0] = swb_offset[pulse_swb]; pulse->pos[0] += get_bits(gb, 5); - if (pulse->pos[0] > 1023) + if (pulse->pos[0] >= swb_offset[num_swb]) return -1; pulse->amp[0] = get_bits(gb, 4); for (i = 1; i < pulse->num_pulse; i++) { pulse->pos[i] = get_bits(gb, 5) + pulse->pos[i - 1]; - if (pulse->pos[i] > 1023) + if (pulse->pos[i] >= swb_offset[num_swb]) return -1; pulse->amp[i] = get_bits(gb, 4); } |