From 0fd7e57e7d284176839bff612cd1af3cadc3fe86 Mon Sep 17 00:00:00 2001 From: Peter Ross Date: Mon, 4 Aug 2008 07:47:23 +0000 Subject: [PATCH] Simplify PCM codec; use sample_fmts field to set the avctx->sample_fmt field. Originally committed as revision 14533 to svn://svn.ffmpeg.org/ffmpeg/trunk --- libavcodec/pcm.c | 18 ++++++------------ 1 file changed, 6 insertions(+), 12 deletions(-) diff --git a/libavcodec/pcm.c b/libavcodec/pcm.c index 2935d01a7e..e86532437c 100644 --- a/libavcodec/pcm.c +++ b/libavcodec/pcm.c @@ -358,14 +358,7 @@ static av_cold int pcm_decode_init(AVCodecContext * avctx) break; } - switch(avctx->codec->id) { - case CODEC_ID_PCM_F32BE: - avctx->sample_fmt = SAMPLE_FMT_FLT; - break; - default: - avctx->sample_fmt = SAMPLE_FMT_S16; - break; - } + avctx->sample_fmt = avctx->codec->sample_fmts[0]; return 0; } @@ -571,7 +564,7 @@ AVCodec name ## _encoder = { \ #endif #ifdef CONFIG_DECODERS -#define PCM_DECODER(id,name,long_name_) \ +#define PCM_DECODER(id,sample_fmt_,name,long_name_) \ AVCodec name ## _decoder = { \ #name, \ CODEC_TYPE_AUDIO, \ @@ -581,14 +574,15 @@ AVCodec name ## _decoder = { \ NULL, \ NULL, \ pcm_decode_frame, \ + .sample_fmts = (enum SampleFormat[]){sample_fmt_,SAMPLE_FMT_NONE}, \ .long_name = NULL_IF_CONFIG_SMALL(long_name_), \ }; #else -#define PCM_DECODER(id,name,long_name_) +#define PCM_DECODER(id,sample_fmt_,name,long_name_) #endif #define PCM_CODEC(id, sample_fmt_, name, long_name_) \ - PCM_ENCODER(id,sample_fmt_,name,long_name_) PCM_DECODER(id,name,long_name_) + PCM_ENCODER(id,sample_fmt_,name,long_name_) PCM_DECODER(id,sample_fmt_,name,long_name_) /* Note: Do not forget to add new entries to the Makefile as well. */ PCM_CODEC (CODEC_ID_PCM_ALAW, SAMPLE_FMT_S16, pcm_alaw, "A-law PCM"); @@ -598,7 +592,7 @@ PCM_CODEC (CODEC_ID_PCM_MULAW, SAMPLE_FMT_S16, pcm_mulaw, "mu-law PCM"); PCM_CODEC (CODEC_ID_PCM_S8, SAMPLE_FMT_S16, pcm_s8, "signed 8-bit PCM"); PCM_CODEC (CODEC_ID_PCM_S16BE, SAMPLE_FMT_S16, pcm_s16be, "signed 16-bit big-endian PCM"); PCM_CODEC (CODEC_ID_PCM_S16LE, SAMPLE_FMT_S16, pcm_s16le, "signed 16-bit little-endian PCM"); -PCM_DECODER(CODEC_ID_PCM_S16LE_PLANAR, pcm_s16le_planar, "16-bit little-endian planar PCM"); +PCM_DECODER(CODEC_ID_PCM_S16LE_PLANAR, SAMPLE_FMT_S16, pcm_s16le_planar, "16-bit little-endian planar PCM"); PCM_CODEC (CODEC_ID_PCM_S24BE, SAMPLE_FMT_S16, pcm_s24be, "signed 24-bit big-endian PCM"); PCM_CODEC (CODEC_ID_PCM_S24DAUD, SAMPLE_FMT_S16, pcm_s24daud, "D-Cinema audio signed 24-bit PCM"); PCM_CODEC (CODEC_ID_PCM_S24LE, SAMPLE_FMT_S16, pcm_s24le, "signed 24-bit little-endian PCM");