[FFmpeg-cvslog] r18146 - trunk/libavcodec/flacdec.c
jbr
subversion
Sun Mar 22 19:52:15 CET 2009
Author: jbr
Date: Sun Mar 22 19:52:15 2009
New Revision: 18146
Log:
flacdec: use a local variable for GetBitContext in decode_frame()
Modified:
trunk/libavcodec/flacdec.c
Modified: trunk/libavcodec/flacdec.c
==============================================================================
--- trunk/libavcodec/flacdec.c Sun Mar 22 17:10:37 2009 (r18145)
+++ trunk/libavcodec/flacdec.c Sun Mar 22 19:52:15 2009 (r18146)
@@ -484,12 +484,13 @@ static int decode_frame(FLACContext *s,
{
int blocksize_code, sample_rate_code, sample_size_code, i, crc8;
int ch_mode, bps, blocksize, samplerate;
+ GetBitContext *gb = &s->gb;
- blocksize_code = get_bits(&s->gb, 4);
+ blocksize_code = get_bits(gb, 4);
- sample_rate_code = get_bits(&s->gb, 4);
+ sample_rate_code = get_bits(gb, 4);
- ch_mode = get_bits(&s->gb, 4); /* channel assignment */
+ ch_mode = get_bits(gb, 4); /* channel assignment */
if (ch_mode < FLAC_MAX_CHANNELS && s->channels == ch_mode+1) {
ch_mode = FLAC_CHMODE_INDEPENDENT;
} else if (ch_mode > FLAC_CHMODE_MID_SIDE || s->channels != 2) {
@@ -498,7 +499,7 @@ static int decode_frame(FLACContext *s,
return -1;
}
- sample_size_code = get_bits(&s->gb, 3);
+ sample_size_code = get_bits(gb, 3);
if (sample_size_code == 0)
bps= s->bps;
else if ((sample_size_code != 3) && (sample_size_code != 7))
@@ -519,12 +520,12 @@ static int decode_frame(FLACContext *s,
}
s->bps = s->avctx->bits_per_raw_sample = bps;
- if (get_bits1(&s->gb)) {
+ if (get_bits1(gb)) {
av_log(s->avctx, AV_LOG_ERROR, "broken stream, invalid padding\n");
return -1;
}
- if (get_utf8(&s->gb) < 0) {
+ if (get_utf8(gb) < 0) {
av_log(s->avctx, AV_LOG_ERROR, "utf8 fscked\n");
return -1;
}
@@ -533,9 +534,9 @@ static int decode_frame(FLACContext *s,
av_log(s->avctx, AV_LOG_ERROR, "reserved blocksize code: 0\n");
return -1;
} else if (blocksize_code == 6)
- blocksize = get_bits(&s->gb, 8)+1;
+ blocksize = get_bits(gb, 8)+1;
else if (blocksize_code == 7)
- blocksize = get_bits(&s->gb, 16)+1;
+ blocksize = get_bits(gb, 16)+1;
else
blocksize = ff_flac_blocksize_table[blocksize_code];
@@ -553,20 +554,20 @@ static int decode_frame(FLACContext *s,
else if (sample_rate_code < 12)
samplerate = ff_flac_sample_rate_table[sample_rate_code];
else if (sample_rate_code == 12)
- samplerate = get_bits(&s->gb, 8) * 1000;
+ samplerate = get_bits(gb, 8) * 1000;
else if (sample_rate_code == 13)
- samplerate = get_bits(&s->gb, 16);
+ samplerate = get_bits(gb, 16);
else if (sample_rate_code == 14)
- samplerate = get_bits(&s->gb, 16) * 10;
+ samplerate = get_bits(gb, 16) * 10;
else {
av_log(s->avctx, AV_LOG_ERROR, "illegal sample rate code %d\n",
sample_rate_code);
return -1;
}
- skip_bits(&s->gb, 8);
+ skip_bits(gb, 8);
crc8 = av_crc(av_crc_get_table(AV_CRC_8_ATM), 0,
- s->gb.buffer, get_bits_count(&s->gb)/8);
+ gb->buffer, get_bits_count(gb)/8);
if (crc8) {
av_log(s->avctx, AV_LOG_ERROR, "header crc mismatch crc=%2X\n", crc8);
return -1;
@@ -585,10 +586,10 @@ static int decode_frame(FLACContext *s,
return -1;
}
- align_get_bits(&s->gb);
+ align_get_bits(gb);
/* frame footer */
- skip_bits(&s->gb, 16); /* data crc */
+ skip_bits(gb, 16); /* data crc */
return 0;
}
More information about the ffmpeg-cvslog
mailing list