1
0
mirror of https://github.com/FFmpeg/FFmpeg.git synced 2025-01-13 21:28:01 +02:00

cosmetics: rename common ac3 variables

Originally committed as revision 11196 to svn://svn.ffmpeg.org/ffmpeg/trunk
This commit is contained in:
Justin Ruggles 2007-12-09 03:27:14 +00:00
parent 8001d92345
commit e59cc20593
4 changed files with 111 additions and 111 deletions

View File

@ -53,14 +53,14 @@ typedef enum {
/** Channel mode (audio coding mode) */ /** Channel mode (audio coding mode) */
typedef enum { typedef enum {
AC3_ACMOD_DUALMONO = 0, AC3_CHMODE_DUALMONO = 0,
AC3_ACMOD_MONO, AC3_CHMODE_MONO,
AC3_ACMOD_STEREO, AC3_CHMODE_STEREO,
AC3_ACMOD_3F, AC3_CHMODE_3F,
AC3_ACMOD_2F1R, AC3_CHMODE_2F1R,
AC3_ACMOD_3F1R, AC3_CHMODE_3F1R,
AC3_ACMOD_2F2R, AC3_CHMODE_2F2R,
AC3_ACMOD_3F2R AC3_CHMODE_3F2R
} AC3ChannelMode; } AC3ChannelMode;
typedef struct AC3BitAllocParameters { typedef struct AC3BitAllocParameters {
@ -81,14 +81,14 @@ typedef struct {
uint16_t sync_word; uint16_t sync_word;
uint16_t crc1; uint16_t crc1;
uint8_t sr_code; uint8_t sr_code;
uint8_t frmsizecod; uint8_t frame_size_code;
uint8_t bsid; uint8_t bitstream_id;
uint8_t bsmod; uint8_t bitstream_mode;
uint8_t acmod; uint8_t channel_mode;
uint8_t cmixlev; uint8_t center_mix_level;
uint8_t surmixlev; uint8_t surround_mix_level;
uint8_t dsurmod; uint8_t dolby_surround_mode;
uint8_t lfeon; uint8_t lfe_on;
/** @} */ /** @} */
/** @defgroup derived Derived values /** @defgroup derived Derived values

View File

@ -47,8 +47,8 @@ int ff_ac3_parse_header(const uint8_t buf[7], AC3HeaderInfo *hdr)
return AC3_PARSE_ERROR_SYNC; return AC3_PARSE_ERROR_SYNC;
/* read ahead to bsid to make sure this is AC-3, not E-AC-3 */ /* read ahead to bsid to make sure this is AC-3, not E-AC-3 */
hdr->bsid = show_bits_long(&gbc, 29) & 0x1F; hdr->bitstream_id = show_bits_long(&gbc, 29) & 0x1F;
if(hdr->bsid > 10) if(hdr->bitstream_id > 10)
return AC3_PARSE_ERROR_BSID; return AC3_PARSE_ERROR_BSID;
hdr->crc1 = get_bits(&gbc, 16); hdr->crc1 = get_bits(&gbc, 16);
@ -56,30 +56,30 @@ int ff_ac3_parse_header(const uint8_t buf[7], AC3HeaderInfo *hdr)
if(hdr->sr_code == 3) if(hdr->sr_code == 3)
return AC3_PARSE_ERROR_SAMPLE_RATE; return AC3_PARSE_ERROR_SAMPLE_RATE;
hdr->frmsizecod = get_bits(&gbc, 6); hdr->frame_size_code = get_bits(&gbc, 6);
if(hdr->frmsizecod > 37) if(hdr->frame_size_code > 37)
return AC3_PARSE_ERROR_FRAME_SIZE; return AC3_PARSE_ERROR_FRAME_SIZE;
skip_bits(&gbc, 5); // skip bsid, already got it skip_bits(&gbc, 5); // skip bsid, already got it
hdr->bsmod = get_bits(&gbc, 3); hdr->bitstream_mode = get_bits(&gbc, 3);
hdr->acmod = get_bits(&gbc, 3); hdr->channel_mode = get_bits(&gbc, 3);
if((hdr->acmod & 1) && hdr->acmod != AC3_ACMOD_MONO) { if((hdr->channel_mode & 1) && hdr->channel_mode != AC3_CHMODE_MONO) {
hdr->cmixlev = get_bits(&gbc, 2); hdr->center_mix_level = get_bits(&gbc, 2);
} }
if(hdr->acmod & 4) { if(hdr->channel_mode & 4) {
hdr->surmixlev = get_bits(&gbc, 2); hdr->surround_mix_level = get_bits(&gbc, 2);
} }
if(hdr->acmod == AC3_ACMOD_STEREO) { if(hdr->channel_mode == AC3_CHMODE_STEREO) {
hdr->dsurmod = get_bits(&gbc, 2); hdr->dolby_surround_mode = get_bits(&gbc, 2);
} }
hdr->lfeon = get_bits1(&gbc); hdr->lfe_on = get_bits1(&gbc);
hdr->sr_shift = FFMAX(hdr->bsid, 8) - 8; hdr->sr_shift = FFMAX(hdr->bitstream_id, 8) - 8;
hdr->sample_rate = ff_ac3_sample_rate_tab[hdr->sr_code] >> hdr->sr_shift; hdr->sample_rate = ff_ac3_sample_rate_tab[hdr->sr_code] >> hdr->sr_shift;
hdr->bit_rate = (ff_ac3_bitrate_tab[hdr->frmsizecod>>1] * 1000) >> hdr->sr_shift; hdr->bit_rate = (ff_ac3_bitrate_tab[hdr->frame_size_code>>1] * 1000) >> hdr->sr_shift;
hdr->channels = ff_ac3_channels_tab[hdr->acmod] + hdr->lfeon; hdr->channels = ff_ac3_channels_tab[hdr->channel_mode] + hdr->lfe_on;
hdr->frame_size = ff_ac3_frame_size_tab[hdr->frmsizecod][hdr->sr_code] * 2; hdr->frame_size = ff_ac3_frame_size_tab[hdr->frame_size_code][hdr->sr_code] * 2;
return 0; return 0;
} }
@ -88,8 +88,8 @@ static int ac3_sync(const uint8_t *buf, int *channels, int *sample_rate,
int *bit_rate, int *samples) int *bit_rate, int *samples)
{ {
int err; int err;
unsigned int sr_code, acmod, bsid, lfeon; unsigned int sr_code, channel_mode, bitstream_id, lfe_on;
unsigned int strmtyp, substreamid, frmsiz, sr_code2, numblkscod; unsigned int stream_type, substream_id, frame_size, sr_code2, num_blocks_code;
GetBitContext bits; GetBitContext bits;
AC3HeaderInfo hdr; AC3HeaderInfo hdr;
@ -98,48 +98,48 @@ static int ac3_sync(const uint8_t *buf, int *channels, int *sample_rate,
if(err < 0 && err != -2) if(err < 0 && err != -2)
return 0; return 0;
bsid = hdr.bsid; bitstream_id = hdr.bitstream_id;
if(bsid <= 10) { /* Normal AC-3 */ if(bitstream_id <= 10) { /* Normal AC-3 */
*sample_rate = hdr.sample_rate; *sample_rate = hdr.sample_rate;
*bit_rate = hdr.bit_rate; *bit_rate = hdr.bit_rate;
*channels = hdr.channels; *channels = hdr.channels;
*samples = AC3_FRAME_SIZE; *samples = AC3_FRAME_SIZE;
return hdr.frame_size; return hdr.frame_size;
} else if (bsid > 10 && bsid <= 16) { /* Enhanced AC-3 */ } else if (bitstream_id > 10 && bitstream_id <= 16) { /* Enhanced AC-3 */
init_get_bits(&bits, &buf[2], (AC3_HEADER_SIZE-2) * 8); init_get_bits(&bits, &buf[2], (AC3_HEADER_SIZE-2) * 8);
strmtyp = get_bits(&bits, 2); stream_type = get_bits(&bits, 2);
substreamid = get_bits(&bits, 3); substream_id = get_bits(&bits, 3);
if (strmtyp != 0 || substreamid != 0) if (stream_type != 0 || substream_id != 0)
return 0; /* Currently don't support additional streams */ return 0; /* Currently don't support additional streams */
frmsiz = get_bits(&bits, 11) + 1; frame_size = get_bits(&bits, 11) + 1;
if(frmsiz*2 < AC3_HEADER_SIZE) if(frame_size*2 < AC3_HEADER_SIZE)
return 0; return 0;
sr_code = get_bits(&bits, 2); sr_code = get_bits(&bits, 2);
if (sr_code == 3) { if (sr_code == 3) {
sr_code2 = get_bits(&bits, 2); sr_code2 = get_bits(&bits, 2);
numblkscod = 3; num_blocks_code = 3;
if(sr_code2 == 3) if(sr_code2 == 3)
return 0; return 0;
*sample_rate = ff_ac3_sample_rate_tab[sr_code2] / 2; *sample_rate = ff_ac3_sample_rate_tab[sr_code2] / 2;
} else { } else {
numblkscod = get_bits(&bits, 2); num_blocks_code = get_bits(&bits, 2);
*sample_rate = ff_ac3_sample_rate_tab[sr_code]; *sample_rate = ff_ac3_sample_rate_tab[sr_code];
} }
acmod = get_bits(&bits, 3); channel_mode = get_bits(&bits, 3);
lfeon = get_bits1(&bits); lfe_on = get_bits1(&bits);
*samples = eac3_blocks[numblkscod] * 256; *samples = eac3_blocks[num_blocks_code] * 256;
*bit_rate = frmsiz * (*sample_rate) * 16 / (*samples); *bit_rate = frame_size * (*sample_rate) * 16 / (*samples);
*channels = ff_ac3_channels_tab[acmod] + lfeon; *channels = ff_ac3_channels_tab[channel_mode] + lfe_on;
return frmsiz * 2; return frame_size * 2;
} }
/* Unsupported bitstream version */ /* Unsupported bitstream version */

View File

@ -97,13 +97,13 @@ static const float gain_levels[6] = {
* Table for center mix levels * Table for center mix levels
* reference: Section 5.4.2.4 cmixlev * reference: Section 5.4.2.4 cmixlev
*/ */
static const uint8_t clevs[4] = { 2, 3, 4, 3 }; static const uint8_t center_levels[4] = { 2, 3, 4, 3 };
/** /**
* Table for surround mix levels * Table for surround mix levels
* reference: Section 5.4.2.5 surmixlev * reference: Section 5.4.2.5 surmixlev
*/ */
static const uint8_t slevs[4] = { 2, 4, 0, 4 }; static const uint8_t surround_levels[4] = { 2, 4, 0, 4 };
/** /**
* Table for default stereo downmixing coefficients * Table for default stereo downmixing coefficients
@ -128,8 +128,8 @@ static const uint8_t ac3_default_coeffs[8][5][2] = {
#define AC3_OUTPUT_LFEON 8 #define AC3_OUTPUT_LFEON 8
typedef struct { typedef struct {
int acmod; ///< audio coding mode int channel_mode; ///< channel mode (acmod)
int dsurmod; ///< dolby surround mode int dolby_surround_mode; ///< dolby surround mode
int blksw[AC3_MAX_CHANNELS]; ///< block switch flags int blksw[AC3_MAX_CHANNELS]; ///< block switch flags
int dithflag[AC3_MAX_CHANNELS]; ///< dither flags int dithflag[AC3_MAX_CHANNELS]; ///< dither flags
int dither_all; ///< true if all channels are dithered int dither_all; ///< true if all channels are dithered
@ -155,7 +155,7 @@ typedef struct {
int nchans; ///< number of total channels int nchans; ///< number of total channels
int nfchans; ///< number of full-bandwidth channels int nfchans; ///< number of full-bandwidth channels
int lfeon; ///< lfe channel in use int lfe_on; ///< lfe channel in use
int lfe_ch; ///< index of LFE channel int lfe_ch; ///< index of LFE channel
int output_mode; ///< output channel configuration int output_mode; ///< output channel configuration
int out_channels; ///< number of output channels int out_channels; ///< number of output channels
@ -336,7 +336,7 @@ static int ac3_parse_header(AC3DecodeContext *ctx)
{ {
AC3HeaderInfo hdr; AC3HeaderInfo hdr;
GetBitContext *gb = &ctx->gb; GetBitContext *gb = &ctx->gb;
float cmixlev, surmixlev; float center_mix_level, surround_mix_level;
int err, i; int err, i;
err = ff_ac3_parse_header(gb->buffer, &hdr); err = ff_ac3_parse_header(gb->buffer, &hdr);
@ -345,23 +345,23 @@ static int ac3_parse_header(AC3DecodeContext *ctx)
/* get decoding parameters from header info */ /* get decoding parameters from header info */
ctx->bit_alloc_params.sr_code = hdr.sr_code; ctx->bit_alloc_params.sr_code = hdr.sr_code;
ctx->acmod = hdr.acmod; ctx->channel_mode = hdr.channel_mode;
cmixlev = gain_levels[clevs[hdr.cmixlev]]; center_mix_level = gain_levels[center_levels[hdr.center_mix_level]];
surmixlev = gain_levels[slevs[hdr.surmixlev]]; surround_mix_level = gain_levels[surround_levels[hdr.surround_mix_level]];
ctx->dsurmod = hdr.dsurmod; ctx->dolby_surround_mode = hdr.dolby_surround_mode;
ctx->lfeon = hdr.lfeon; ctx->lfe_on = hdr.lfe_on;
ctx->bit_alloc_params.sr_shift = hdr.sr_shift; ctx->bit_alloc_params.sr_shift = hdr.sr_shift;
ctx->sampling_rate = hdr.sample_rate; ctx->sampling_rate = hdr.sample_rate;
ctx->bit_rate = hdr.bit_rate; ctx->bit_rate = hdr.bit_rate;
ctx->nchans = hdr.channels; ctx->nchans = hdr.channels;
ctx->nfchans = ctx->nchans - ctx->lfeon; ctx->nfchans = ctx->nchans - ctx->lfe_on;
ctx->lfe_ch = ctx->nfchans + 1; ctx->lfe_ch = ctx->nfchans + 1;
ctx->frame_size = hdr.frame_size; ctx->frame_size = hdr.frame_size;
/* set default output to all source channels */ /* set default output to all source channels */
ctx->out_channels = ctx->nchans; ctx->out_channels = ctx->nchans;
ctx->output_mode = ctx->acmod; ctx->output_mode = ctx->channel_mode;
if(ctx->lfeon) if(ctx->lfe_on)
ctx->output_mode |= AC3_OUTPUT_LFEON; ctx->output_mode |= AC3_OUTPUT_LFEON;
/* skip over portion of header which has already been read */ /* skip over portion of header which has already been read */
@ -369,18 +369,18 @@ static int ac3_parse_header(AC3DecodeContext *ctx)
skip_bits(gb, 16); // skip crc1 skip_bits(gb, 16); // skip crc1
skip_bits(gb, 8); // skip fscod and frmsizecod skip_bits(gb, 8); // skip fscod and frmsizecod
skip_bits(gb, 11); // skip bsid, bsmod, and acmod skip_bits(gb, 11); // skip bsid, bsmod, and acmod
if(ctx->acmod == AC3_ACMOD_STEREO) { if(ctx->channel_mode == AC3_CHMODE_STEREO) {
skip_bits(gb, 2); // skip dsurmod skip_bits(gb, 2); // skip dsurmod
} else { } else {
if((ctx->acmod & 1) && ctx->acmod != AC3_ACMOD_MONO) if((ctx->channel_mode & 1) && ctx->channel_mode != AC3_CHMODE_MONO)
skip_bits(gb, 2); // skip cmixlev skip_bits(gb, 2); // skip cmixlev
if(ctx->acmod & 4) if(ctx->channel_mode & 4)
skip_bits(gb, 2); // skip surmixlev skip_bits(gb, 2); // skip surmixlev
} }
skip_bits1(gb); // skip lfeon skip_bits1(gb); // skip lfeon
/* read the rest of the bsi. read twice for dual mono mode. */ /* read the rest of the bsi. read twice for dual mono mode. */
i = !(ctx->acmod); i = !(ctx->channel_mode);
do { do {
ctx->dialnorm[i] = dialnorm_tab[get_bits(gb, 5)]; // dialog normalization ctx->dialnorm[i] = dialnorm_tab[get_bits(gb, 5)]; // dialog normalization
if (get_bits1(gb)) if (get_bits1(gb))
@ -411,19 +411,19 @@ static int ac3_parse_header(AC3DecodeContext *ctx)
/* set stereo downmixing coefficients /* set stereo downmixing coefficients
reference: Section 7.8.2 Downmixing Into Two Channels */ reference: Section 7.8.2 Downmixing Into Two Channels */
for(i=0; i<ctx->nfchans; i++) { for(i=0; i<ctx->nfchans; i++) {
ctx->downmix_coeffs[i][0] = gain_levels[ac3_default_coeffs[ctx->acmod][i][0]]; ctx->downmix_coeffs[i][0] = gain_levels[ac3_default_coeffs[ctx->channel_mode][i][0]];
ctx->downmix_coeffs[i][1] = gain_levels[ac3_default_coeffs[ctx->acmod][i][1]]; ctx->downmix_coeffs[i][1] = gain_levels[ac3_default_coeffs[ctx->channel_mode][i][1]];
} }
if(ctx->acmod > 1 && ctx->acmod & 1) { if(ctx->channel_mode > 1 && ctx->channel_mode & 1) {
ctx->downmix_coeffs[1][0] = ctx->downmix_coeffs[1][1] = cmixlev; ctx->downmix_coeffs[1][0] = ctx->downmix_coeffs[1][1] = center_mix_level;
} }
if(ctx->acmod == AC3_ACMOD_2F1R || ctx->acmod == AC3_ACMOD_3F1R) { if(ctx->channel_mode == AC3_CHMODE_2F1R || ctx->channel_mode == AC3_CHMODE_3F1R) {
int nf = ctx->acmod - 2; int nf = ctx->channel_mode - 2;
ctx->downmix_coeffs[nf][0] = ctx->downmix_coeffs[nf][1] = surmixlev * LEVEL_MINUS_3DB; ctx->downmix_coeffs[nf][0] = ctx->downmix_coeffs[nf][1] = surround_mix_level * LEVEL_MINUS_3DB;
} }
if(ctx->acmod == AC3_ACMOD_2F2R || ctx->acmod == AC3_ACMOD_3F2R) { if(ctx->channel_mode == AC3_CHMODE_2F2R || ctx->channel_mode == AC3_CHMODE_3F2R) {
int nf = ctx->acmod - 4; int nf = ctx->channel_mode - 4;
ctx->downmix_coeffs[nf][0] = ctx->downmix_coeffs[nf+1][1] = surmixlev; ctx->downmix_coeffs[nf][0] = ctx->downmix_coeffs[nf+1][1] = surround_mix_level;
} }
return 0; return 0;
@ -766,9 +766,9 @@ static void ac3_downmix(float samples[AC3_MAX_CHANNELS][256], int nfchans,
} }
v0 /= s0; v0 /= s0;
v1 /= s1; v1 /= s1;
if(output_mode == AC3_ACMOD_MONO) { if(output_mode == AC3_CHMODE_MONO) {
samples[0][i] = (v0 + v1) * LEVEL_MINUS_3DB; samples[0][i] = (v0 + v1) * LEVEL_MINUS_3DB;
} else if(output_mode == AC3_ACMOD_STEREO) { } else if(output_mode == AC3_CHMODE_STEREO) {
samples[0][i] = v0; samples[0][i] = v0;
samples[1][i] = v1; samples[1][i] = v1;
} }
@ -781,7 +781,7 @@ static void ac3_downmix(float samples[AC3_MAX_CHANNELS][256], int nfchans,
static int ac3_parse_audio_block(AC3DecodeContext *ctx, int blk) static int ac3_parse_audio_block(AC3DecodeContext *ctx, int blk)
{ {
int nfchans = ctx->nfchans; int nfchans = ctx->nfchans;
int acmod = ctx->acmod; int channel_mode = ctx->channel_mode;
int i, bnd, seg, ch; int i, bnd, seg, ch;
GetBitContext *gb = &ctx->gb; GetBitContext *gb = &ctx->gb;
uint8_t bit_alloc_stages[AC3_MAX_CHANNELS]; uint8_t bit_alloc_stages[AC3_MAX_CHANNELS];
@ -801,7 +801,7 @@ static int ac3_parse_audio_block(AC3DecodeContext *ctx, int blk)
} }
/* dynamic range */ /* dynamic range */
i = !(ctx->acmod); i = !(ctx->channel_mode);
do { do {
if(get_bits1(gb)) { if(get_bits1(gb)) {
ctx->dynrng[i] = dynrng_tab[get_bits(gb, 8)]; ctx->dynrng[i] = dynrng_tab[get_bits(gb, 8)];
@ -823,7 +823,7 @@ static int ac3_parse_audio_block(AC3DecodeContext *ctx, int blk)
ctx->chincpl[ch] = get_bits1(gb); ctx->chincpl[ch] = get_bits1(gb);
/* phase flags in use */ /* phase flags in use */
if (acmod == AC3_ACMOD_STEREO) if (channel_mode == AC3_CHMODE_STEREO)
ctx->phsflginu = get_bits1(gb); ctx->phsflginu = get_bits1(gb);
/* coupling frequency range and band structure */ /* coupling frequency range and band structure */
@ -872,7 +872,7 @@ static int ac3_parse_audio_block(AC3DecodeContext *ctx, int blk)
} }
} }
/* phase flags */ /* phase flags */
if (acmod == AC3_ACMOD_STEREO && ctx->phsflginu && cplcoe) { if (channel_mode == AC3_CHMODE_STEREO && ctx->phsflginu && cplcoe) {
for (bnd = 0; bnd < ctx->ncplbnd; bnd++) { for (bnd = 0; bnd < ctx->ncplbnd; bnd++) {
if (get_bits1(gb)) if (get_bits1(gb))
ctx->cplco[2][bnd] = -ctx->cplco[2][bnd]; ctx->cplco[2][bnd] = -ctx->cplco[2][bnd];
@ -881,7 +881,7 @@ static int ac3_parse_audio_block(AC3DecodeContext *ctx, int blk)
} }
/* stereo rematrixing strategy and band structure */ /* stereo rematrixing strategy and band structure */
if (acmod == AC3_ACMOD_STEREO) { if (channel_mode == AC3_CHMODE_STEREO) {
ctx->rematstr = get_bits1(gb); ctx->rematstr = get_bits1(gb);
if (ctx->rematstr) { if (ctx->rematstr) {
ctx->nrematbnd = 4; ctx->nrematbnd = 4;
@ -1046,13 +1046,13 @@ static int ac3_parse_audio_block(AC3DecodeContext *ctx, int blk)
} }
/* recover coefficients if rematrixing is in use */ /* recover coefficients if rematrixing is in use */
if(ctx->acmod == AC3_ACMOD_STEREO) if(ctx->channel_mode == AC3_CHMODE_STEREO)
do_rematrixing(ctx); do_rematrixing(ctx);
/* apply scaling to coefficients (headroom, dialnorm, dynrng) */ /* apply scaling to coefficients (headroom, dialnorm, dynrng) */
for(ch=1; ch<=ctx->nchans; ch++) { for(ch=1; ch<=ctx->nchans; ch++) {
float gain = 2.0f * ctx->mul_bias; float gain = 2.0f * ctx->mul_bias;
if(ctx->acmod == AC3_ACMOD_DUALMONO) { if(ctx->channel_mode == AC3_CHMODE_DUALMONO) {
gain *= ctx->dialnorm[ch-1] * ctx->dynrng[ch-1]; gain *= ctx->dialnorm[ch-1] * ctx->dynrng[ch-1];
} else { } else {
gain *= ctx->dialnorm[0] * ctx->dynrng[0]; gain *= ctx->dialnorm[0] * ctx->dynrng[0];
@ -1136,9 +1136,9 @@ static int ac3_decode_frame(AVCodecContext * avctx, void *data, int *data_size,
return -1; return -1;
} }
if(avctx->channels == 2) { if(avctx->channels == 2) {
ctx->output_mode = AC3_ACMOD_STEREO; ctx->output_mode = AC3_CHMODE_STEREO;
} else if(avctx->channels == 1) { } else if(avctx->channels == 1) {
ctx->output_mode = AC3_ACMOD_MONO; ctx->output_mode = AC3_CHMODE_MONO;
} else if(avctx->channels != ctx->out_channels) { } else if(avctx->channels != ctx->out_channels) {
av_log(avctx, AV_LOG_ERROR, "Cannot downmix AC3 from %d to %d channels.\n", av_log(avctx, AV_LOG_ERROR, "Cannot downmix AC3 from %d to %d channels.\n",
ctx->out_channels, avctx->channels); ctx->out_channels, avctx->channels);

View File

@ -37,17 +37,17 @@ typedef struct AC3EncodeContext {
int lfe_channel; int lfe_channel;
int bit_rate; int bit_rate;
unsigned int sample_rate; unsigned int sample_rate;
unsigned int bsid; unsigned int bitstream_id;
unsigned int frame_size_min; /* minimum frame size in case rounding is necessary */ unsigned int frame_size_min; /* minimum frame size in case rounding is necessary */
unsigned int frame_size; /* current frame size in words */ unsigned int frame_size; /* current frame size in words */
unsigned int bits_written; unsigned int bits_written;
unsigned int samples_written; unsigned int samples_written;
int sr_shift; int sr_shift;
unsigned int frmsizecod; unsigned int frame_size_code;
unsigned int sr_code; /* frequency */ unsigned int sr_code; /* frequency */
unsigned int acmod; unsigned int channel_mode;
int lfe; int lfe;
unsigned int bsmod; unsigned int bitstream_mode;
short last_samples[AC3_MAX_CHANNELS][256]; short last_samples[AC3_MAX_CHANNELS][256];
unsigned int chbwcod[AC3_MAX_CHANNELS]; unsigned int chbwcod[AC3_MAX_CHANNELS];
int nb_coefs[AC3_MAX_CHANNELS]; int nb_coefs[AC3_MAX_CHANNELS];
@ -527,14 +527,14 @@ static int compute_bit_allocation(AC3EncodeContext *s,
/* header size */ /* header size */
frame_bits += 65; frame_bits += 65;
// if (s->acmod == 2) // if (s->channel_mode == 2)
// frame_bits += 2; // frame_bits += 2;
frame_bits += frame_bits_inc[s->acmod]; frame_bits += frame_bits_inc[s->channel_mode];
/* audio blocks */ /* audio blocks */
for(i=0;i<NB_BLOCKS;i++) { for(i=0;i<NB_BLOCKS;i++) {
frame_bits += s->nb_channels * 2 + 2; /* blksw * c, dithflag * c, dynrnge, cplstre */ frame_bits += s->nb_channels * 2 + 2; /* blksw * c, dithflag * c, dynrnge, cplstre */
if (s->acmod == AC3_ACMOD_STEREO) { if (s->channel_mode == AC3_CHMODE_STEREO) {
frame_bits++; /* rematstr */ frame_bits++; /* rematstr */
if(i==0) frame_bits += 4; if(i==0) frame_bits += 4;
} }
@ -632,7 +632,7 @@ static int AC3_encode_init(AVCodecContext *avctx)
AC3EncodeContext *s = avctx->priv_data; AC3EncodeContext *s = avctx->priv_data;
int i, j, ch; int i, j, ch;
float alpha; float alpha;
static const uint8_t acmod_defs[6] = { static const uint8_t channel_mode_defs[6] = {
0x01, /* C */ 0x01, /* C */
0x02, /* L R */ 0x02, /* L R */
0x03, /* L C R */ 0x03, /* L C R */
@ -648,7 +648,7 @@ static int AC3_encode_init(AVCodecContext *avctx)
/* number of channels */ /* number of channels */
if (channels < 1 || channels > 6) if (channels < 1 || channels > 6)
return -1; return -1;
s->acmod = acmod_defs[channels - 1]; s->channel_mode = channel_mode_defs[channels - 1];
s->lfe = (channels == 6) ? 1 : 0; s->lfe = (channels == 6) ? 1 : 0;
s->nb_all_channels = channels; s->nb_all_channels = channels;
s->nb_channels = channels > 5 ? 5 : channels; s->nb_channels = channels > 5 ? 5 : channels;
@ -665,8 +665,8 @@ static int AC3_encode_init(AVCodecContext *avctx)
s->sample_rate = freq; s->sample_rate = freq;
s->sr_shift = i; s->sr_shift = i;
s->sr_code = j; s->sr_code = j;
s->bsid = 8 + s->sr_shift; s->bitstream_id = 8 + s->sr_shift;
s->bsmod = 0; /* complete main audio service */ s->bitstream_mode = 0; /* complete main audio service */
/* bitrate & frame size */ /* bitrate & frame size */
bitrate /= 1000; bitrate /= 1000;
@ -677,8 +677,8 @@ static int AC3_encode_init(AVCodecContext *avctx)
if (i == 19) if (i == 19)
return -1; return -1;
s->bit_rate = bitrate; s->bit_rate = bitrate;
s->frmsizecod = i << 1; s->frame_size_code = i << 1;
s->frame_size_min = ff_ac3_frame_size_tab[s->frmsizecod][s->sr_code]; s->frame_size_min = ff_ac3_frame_size_tab[s->frame_size_code][s->sr_code];
s->bits_written = 0; s->bits_written = 0;
s->samples_written = 0; s->samples_written = 0;
s->frame_size = s->frame_size_min; s->frame_size = s->frame_size_min;
@ -719,15 +719,15 @@ static void output_frame_header(AC3EncodeContext *s, unsigned char *frame)
put_bits(&s->pb, 16, 0x0b77); /* frame header */ put_bits(&s->pb, 16, 0x0b77); /* frame header */
put_bits(&s->pb, 16, 0); /* crc1: will be filled later */ put_bits(&s->pb, 16, 0); /* crc1: will be filled later */
put_bits(&s->pb, 2, s->sr_code); put_bits(&s->pb, 2, s->sr_code);
put_bits(&s->pb, 6, s->frmsizecod + (s->frame_size - s->frame_size_min)); put_bits(&s->pb, 6, s->frame_size_code + (s->frame_size - s->frame_size_min));
put_bits(&s->pb, 5, s->bsid); put_bits(&s->pb, 5, s->bitstream_id);
put_bits(&s->pb, 3, s->bsmod); put_bits(&s->pb, 3, s->bitstream_mode);
put_bits(&s->pb, 3, s->acmod); put_bits(&s->pb, 3, s->channel_mode);
if ((s->acmod & 0x01) && s->acmod != AC3_ACMOD_MONO) if ((s->channel_mode & 0x01) && s->channel_mode != AC3_CHMODE_MONO)
put_bits(&s->pb, 2, 1); /* XXX -4.5 dB */ put_bits(&s->pb, 2, 1); /* XXX -4.5 dB */
if (s->acmod & 0x04) if (s->channel_mode & 0x04)
put_bits(&s->pb, 2, 1); /* XXX -6 dB */ put_bits(&s->pb, 2, 1); /* XXX -6 dB */
if (s->acmod == AC3_ACMOD_STEREO) if (s->channel_mode == AC3_CHMODE_STEREO)
put_bits(&s->pb, 2, 0); /* surround not indicated */ put_bits(&s->pb, 2, 0); /* surround not indicated */
put_bits(&s->pb, 1, s->lfe); /* LFE */ put_bits(&s->pb, 1, s->lfe); /* LFE */
put_bits(&s->pb, 5, 31); /* dialog norm: -31 db */ put_bits(&s->pb, 5, 31); /* dialog norm: -31 db */
@ -810,7 +810,7 @@ static void output_audio_block(AC3EncodeContext *s,
put_bits(&s->pb, 1, 0); /* no new coupling strategy */ put_bits(&s->pb, 1, 0); /* no new coupling strategy */
} }
if (s->acmod == AC3_ACMOD_STEREO) if (s->channel_mode == AC3_CHMODE_STEREO)
{ {
if(block_num==0) if(block_num==0)
{ {