Commit 73abc3a6 authored by Michael Niedermayer's avatar Michael Niedermayer

aacdec: check init_get_bits return

Also fixes an integer overflow
Signed-off-by: 's avatarMichael Niedermayer <michaelni@gmx.at>
parent 8888c72f
...@@ -774,13 +774,15 @@ static int decode_audio_specific_config(AACContext *ac, ...@@ -774,13 +774,15 @@ static int decode_audio_specific_config(AACContext *ac,
{ {
GetBitContext gb; GetBitContext gb;
int i; int i;
int ret;
av_dlog(avctx, "audio specific config size %d\n", bit_size >> 3); av_dlog(avctx, "audio specific config size %d\n", bit_size >> 3);
for (i = 0; i < bit_size >> 3; i++) for (i = 0; i < bit_size >> 3; i++)
av_dlog(avctx, "%02x ", data[i]); av_dlog(avctx, "%02x ", data[i]);
av_dlog(avctx, "\n"); av_dlog(avctx, "\n");
init_get_bits(&gb, data, bit_size); if ((ret = init_get_bits(&gb, data, bit_size)) < 0)
return ret;
if ((i = avpriv_mpeg4audio_get_config(m4ac, data, bit_size, sync_extension)) < 0) if ((i = avpriv_mpeg4audio_get_config(m4ac, data, bit_size, sync_extension)) < 0)
return -1; return -1;
...@@ -2922,7 +2924,8 @@ static int latm_decode_frame(AVCodecContext *avctx, void *out, ...@@ -2922,7 +2924,8 @@ static int latm_decode_frame(AVCodecContext *avctx, void *out,
int muxlength, err; int muxlength, err;
GetBitContext gb; GetBitContext gb;
init_get_bits(&gb, avpkt->data, avpkt->size * 8); if ((err = init_get_bits8(&gb, avpkt->data, avpkt->size)) < 0)
return err;
// check for LOAS sync word // check for LOAS sync word
if (get_bits(&gb, 11) != LOAS_SYNC_WORD) if (get_bits(&gb, 11) != LOAS_SYNC_WORD)
......
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