[FFmpeg-cvslog] r9823 - trunk/libavcodec/ac3dec.c
jbr
subversion
Sun Jul 29 02:35:31 CEST 2007
Author: jbr
Date: Sun Jul 29 02:35:30 2007
New Revision: 9823
Log:
change 2 fields from context to local variables
Modified:
trunk/libavcodec/ac3dec.c
Modified: trunk/libavcodec/ac3dec.c
==============================================================================
--- trunk/libavcodec/ac3dec.c (original)
+++ trunk/libavcodec/ac3dec.c Sun Jul 29 02:35:30 2007
@@ -89,8 +89,6 @@ typedef struct {
int cplinu;
int chincpl[AC3_MAX_CHANNELS];
int phsflginu;
- int cplbegf;
- int cplendf;
int cplcoe;
uint32_t cplbndstrc;
int rematstr;
@@ -801,23 +799,25 @@ static int ac3_parse_audio_block(AC3Deco
ctx->cplinu = get_bits1(gb);
ctx->cplbndstrc = 0;
if (ctx->cplinu) { /* coupling in use */
+ int cplbegf, cplendf;
+
for (i = 0; i < nfchans; i++)
ctx->chincpl[i] = get_bits1(gb);
if (acmod == AC3_ACMOD_STEREO)
ctx->phsflginu = get_bits1(gb); //phase flag in use
- ctx->cplbegf = get_bits(gb, 4);
- ctx->cplendf = get_bits(gb, 4);
+ cplbegf = get_bits(gb, 4);
+ cplendf = get_bits(gb, 4);
- if (3 + ctx->cplendf - ctx->cplbegf < 0) {
- av_log(NULL, AV_LOG_ERROR, "cplendf = %d < cplbegf = %d\n", ctx->cplendf, ctx->cplbegf);
+ if (3 + cplendf - cplbegf < 0) {
+ av_log(NULL, AV_LOG_ERROR, "cplendf = %d < cplbegf = %d\n", cplendf, cplbegf);
return -1;
}
- ctx->ncplbnd = ctx->ncplsubnd = 3 + ctx->cplendf - ctx->cplbegf;
- ctx->cplstrtmant = ctx->cplbegf * 12 + 37;
- ctx->cplendmant = ctx->cplendf * 12 + 73;
+ ctx->ncplbnd = ctx->ncplsubnd = 3 + cplendf - cplbegf;
+ ctx->cplstrtmant = cplbegf * 12 + 37;
+ ctx->cplendmant = cplendf * 12 + 73;
for (i = 0; i < ctx->ncplsubnd - 1; i++) /* coupling band structure */
if (get_bits1(gb)) {
ctx->cplbndstrc |= 1 << i;
@@ -857,13 +857,13 @@ static int ac3_parse_audio_block(AC3Deco
if (acmod == AC3_ACMOD_STEREO) {/* rematrixing */
ctx->rematstr = get_bits1(gb);
if (ctx->rematstr) {
- if (!(ctx->cplinu) || ctx->cplbegf > 2)
+ if (!(ctx->cplinu) || ctx->cplstrtmant > 61)
for (rbnd = 0; rbnd < 4; rbnd++)
ctx->rematflg[rbnd] = get_bits1(gb);
- if (ctx->cplbegf > 0 && ctx->cplbegf <= 2 && ctx->cplinu)
+ if (ctx->cplstrtmant > 37 && ctx->cplstrtmant <= 61 && ctx->cplinu)
for (rbnd = 0; rbnd < 3; rbnd++)
ctx->rematflg[rbnd] = get_bits1(gb);
- if (ctx->cplbegf == 0 && ctx->cplinu)
+ if (ctx->cplstrtmant == 37 && ctx->cplinu)
for (rbnd = 0; rbnd < 2; rbnd++)
ctx->rematflg[rbnd] = get_bits1(gb);
}
More information about the ffmpeg-cvslog
mailing list