# HG changeset patch # User superdump # Date 1229836112 0 # Node ID 2d48043ab521f794177c9338a5829131a821b993 # Parent b749b637ecfa2ba8e8a9c20eb2d0a65d43b0abdb AAC: Don't write an illegal sampling_index in a PCE to the MPEG4AudioConfig member Patch by Alex Converse (alex converse gmail com) diff -r b749b637ecfa -r 2d48043ab521 aac.c --- a/aac.c Sat Dec 20 23:11:30 2008 +0000 +++ b/aac.c Sun Dec 21 05:08:32 2008 +0000 @@ -167,15 +167,16 @@ */ static int decode_pce(AACContext * ac, enum ChannelPosition new_che_pos[4][MAX_ELEM_ID], GetBitContext * gb) { - int num_front, num_side, num_back, num_lfe, num_assoc_data, num_cc; + int num_front, num_side, num_back, num_lfe, num_assoc_data, num_cc, sampling_index; skip_bits(gb, 2); // object_type - ac->m4ac.sampling_index = get_bits(gb, 4); - if(ac->m4ac.sampling_index > 11) { + sampling_index = get_bits(gb, 4); + if(sampling_index > 11) { av_log(ac->avccontext, AV_LOG_ERROR, "invalid sampling rate index %d\n", ac->m4ac.sampling_index); return -1; } + ac->m4ac.sampling_index = sampling_index; ac->m4ac.sample_rate = ff_mpeg4audio_sample_rates[ac->m4ac.sampling_index]; num_front = get_bits(gb, 4); num_side = get_bits(gb, 4);