aboutsummaryrefslogtreecommitdiffstats
path: root/libavcodec/flacdec.c
diff options
context:
space:
mode:
authorJustin Ruggles <justin.ruggles@gmail.com>2009-03-22 22:10:33 +0000
committerJustin Ruggles <justin.ruggles@gmail.com>2009-03-22 22:10:33 +0000
commite2a38af96eb1c1ee80e9f967d26f61d1e29eabdb (patch)
treeda6bae9f0f9e3285b02e5c5a572321a7130f7002 /libavcodec/flacdec.c
parentf91eaf5deb3c02f1d1a439b9fa4e3608a0d6a08b (diff)
downloadffmpeg-e2a38af96eb1c1ee80e9f967d26f61d1e29eabdb.tar.gz
flacdec: change frame bps validation to return an error value if bps
changes since this is not currently supported by the decoder. Originally committed as revision 18157 to svn://svn.ffmpeg.org/ffmpeg/trunk
Diffstat (limited to 'libavcodec/flacdec.c')
-rw-r--r--libavcodec/flacdec.c19
1 files changed, 10 insertions, 9 deletions
diff --git a/libavcodec/flacdec.c b/libavcodec/flacdec.c
index d33dc27760..da578f3112 100644
--- a/libavcodec/flacdec.c
+++ b/libavcodec/flacdec.c
@@ -512,25 +512,26 @@ static int decode_frame(FLACContext *s)
/* bits per sample */
bps_code = get_bits(gb, 3);
- if (bps_code == 0) {
- bps= s->bps;
- } else if ((bps_code != 3) && (bps_code != 7)) {
- bps = sample_size_table[bps_code];
- } else {
+ if (bps_code == 3 || bps_code == 7) {
av_log(s->avctx, AV_LOG_ERROR, "invalid sample size code (%d)\n",
bps_code);
return -1;
}
- if (bps > 16) {
+ bps = sample_size_table[bps_code];
+ if (bps && bps != s->bps) {
+ av_log(s->avctx, AV_LOG_ERROR, "switching bps mid-stream is not "
+ "supported\n");
+ return -1;
+ }
+ if (s->bps > 16) {
s->avctx->sample_fmt = SAMPLE_FMT_S32;
- s->sample_shift = 32 - bps;
+ s->sample_shift = 32 - s->bps;
s->is32 = 1;
} else {
s->avctx->sample_fmt = SAMPLE_FMT_S16;
- s->sample_shift = 16 - bps;
+ s->sample_shift = 16 - s->bps;
s->is32 = 0;
}
- s->bps = s->avctx->bits_per_raw_sample = bps;
/* reserved bit */
if (get_bits1(gb)) {