mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2025-01-13 21:28:01 +02:00
flacdec: factor out code setting avctx->sample_fmt
This commit is contained in:
parent
d155b60fc8
commit
87466f8124
@ -100,6 +100,19 @@ int avpriv_flac_is_extradata_valid(AVCodecContext *avctx,
|
|||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void flac_set_bps(FLACContext *s)
|
||||||
|
{
|
||||||
|
if (s->bps > 16) {
|
||||||
|
s->avctx->sample_fmt = AV_SAMPLE_FMT_S32;
|
||||||
|
s->sample_shift = 32 - s->bps;
|
||||||
|
s->is32 = 1;
|
||||||
|
} else {
|
||||||
|
s->avctx->sample_fmt = AV_SAMPLE_FMT_S16;
|
||||||
|
s->sample_shift = 16 - s->bps;
|
||||||
|
s->is32 = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
static av_cold int flac_decode_init(AVCodecContext *avctx)
|
static av_cold int flac_decode_init(AVCodecContext *avctx)
|
||||||
{
|
{
|
||||||
enum FLACExtradataFormat format;
|
enum FLACExtradataFormat format;
|
||||||
@ -117,11 +130,8 @@ static av_cold int flac_decode_init(AVCodecContext *avctx)
|
|||||||
|
|
||||||
/* initialize based on the demuxer-supplied streamdata header */
|
/* initialize based on the demuxer-supplied streamdata header */
|
||||||
avpriv_flac_parse_streaminfo(avctx, (FLACStreaminfo *)s, streaminfo);
|
avpriv_flac_parse_streaminfo(avctx, (FLACStreaminfo *)s, streaminfo);
|
||||||
if (s->bps > 16)
|
|
||||||
avctx->sample_fmt = AV_SAMPLE_FMT_S32;
|
|
||||||
else
|
|
||||||
avctx->sample_fmt = AV_SAMPLE_FMT_S16;
|
|
||||||
allocate_buffers(s);
|
allocate_buffers(s);
|
||||||
|
flac_set_bps(s);
|
||||||
s->got_streaminfo = 1;
|
s->got_streaminfo = 1;
|
||||||
|
|
||||||
avcodec_get_frame_defaults(&s->frame);
|
avcodec_get_frame_defaults(&s->frame);
|
||||||
@ -512,15 +522,7 @@ static int decode_frame(FLACContext *s)
|
|||||||
}
|
}
|
||||||
s->bps = s->avctx->bits_per_raw_sample = fi.bps;
|
s->bps = s->avctx->bits_per_raw_sample = fi.bps;
|
||||||
|
|
||||||
if (s->bps > 16) {
|
flac_set_bps(s);
|
||||||
s->avctx->sample_fmt = AV_SAMPLE_FMT_S32;
|
|
||||||
s->sample_shift = 32 - s->bps;
|
|
||||||
s->is32 = 1;
|
|
||||||
} else {
|
|
||||||
s->avctx->sample_fmt = AV_SAMPLE_FMT_S16;
|
|
||||||
s->sample_shift = 16 - s->bps;
|
|
||||||
s->is32 = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!s->max_blocksize)
|
if (!s->max_blocksize)
|
||||||
s->max_blocksize = FLAC_MAX_BLOCKSIZE;
|
s->max_blocksize = FLAC_MAX_BLOCKSIZE;
|
||||||
|
Loading…
Reference in New Issue
Block a user