Commit 99ca4f73 authored by Justin Ruggles's avatar Justin Ruggles

Don't use nested loops to iterate valid sample rates.

Eliminates a goto and mirrors the bitrate validation.

Originally committed as revision 25980 to svn://svn.ffmpeg.org/ffmpeg/trunk
parent 1607db0a
...@@ -1252,7 +1252,7 @@ static av_cold int set_channel_info(AC3EncodeContext *s, int channels, ...@@ -1252,7 +1252,7 @@ static av_cold int set_channel_info(AC3EncodeContext *s, int channels,
static av_cold int validate_options(AVCodecContext *avctx, AC3EncodeContext *s) static av_cold int validate_options(AVCodecContext *avctx, AC3EncodeContext *s)
{ {
int i, j; int i;
if (!avctx->channel_layout) { if (!avctx->channel_layout) {
av_log(avctx, AV_LOG_WARNING, "No channel layout specified. The " av_log(avctx, AV_LOG_WARNING, "No channel layout specified. The "
...@@ -1265,16 +1265,16 @@ static av_cold int validate_options(AVCodecContext *avctx, AC3EncodeContext *s) ...@@ -1265,16 +1265,16 @@ static av_cold int validate_options(AVCodecContext *avctx, AC3EncodeContext *s)
} }
/* frequency */ /* frequency */
for (i = 0; i < 3; i++) { for (i = 0; i < 9; i++) {
for (j = 0; j < 3; j++) if ((ff_ac3_sample_rate_tab[i / 3] >> (i % 3)) == avctx->sample_rate)
if ((ff_ac3_sample_rate_tab[j] >> i) == avctx->sample_rate) break;
goto found;
} }
if (i == 9) {
return -1; return -1;
found: }
s->sample_rate = avctx->sample_rate; s->sample_rate = avctx->sample_rate;
s->bit_alloc.sr_shift = i; s->bit_alloc.sr_shift = i % 3;
s->bit_alloc.sr_code = j; s->bit_alloc.sr_code = i / 3;
s->bitstream_id = 8 + s->bit_alloc.sr_shift; s->bitstream_id = 8 + s->bit_alloc.sr_shift;
s->bitstream_mode = 0; /* complete main audio service */ s->bitstream_mode = 0; /* complete main audio service */
......
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