Commit 4fef4b6d authored by Rémi Denis-Courmont's avatar Rémi Denis-Courmont

avcodec: simplify audio sample format mapping

parent 0198b074
...@@ -407,33 +407,18 @@ void EndAudioDec( decoder_t *p_dec ) ...@@ -407,33 +407,18 @@ void EndAudioDec( decoder_t *p_dec )
* *
*****************************************************************************/ *****************************************************************************/
void GetVlcAudioFormat( vlc_fourcc_t *pi_codec, unsigned *pi_bits, int i_sample_fmt ) vlc_fourcc_t GetVlcAudioFormat( int fmt )
{ {
switch( i_sample_fmt ) static const vlc_fourcc_t fcc[] = {
{ [AV_SAMPLE_FMT_U8] = VLC_CODEC_U8,
case AV_SAMPLE_FMT_U8: [AV_SAMPLE_FMT_S16] = VLC_CODEC_S16N,
*pi_codec = VLC_CODEC_U8; [AV_SAMPLE_FMT_S32] = VLC_CODEC_S32N,
*pi_bits = 8; [AV_SAMPLE_FMT_FLT] = VLC_CODEC_FL32,
break; [AV_SAMPLE_FMT_DBL] = VLC_CODEC_FL64,
case AV_SAMPLE_FMT_S32: };
*pi_codec = VLC_CODEC_S32N; if( sizeof(fcc) / sizeof(fcc[0]) < (unsigned)fmt )
*pi_bits = 32; return fcc[fmt];
break; return VLC_CODEC_S16N;
case AV_SAMPLE_FMT_FLT:
*pi_codec = VLC_CODEC_FL32;
*pi_bits = 32;
break;
case AV_SAMPLE_FMT_DBL:
*pi_codec = VLC_CODEC_FL64;
*pi_bits = 64;
break;
case AV_SAMPLE_FMT_S16:
default:
*pi_codec = VLC_CODEC_S16N;
*pi_bits = 16;
break;
}
} }
static const uint64_t pi_channels_map[][2] = static const uint64_t pi_channels_map[][2] =
...@@ -464,9 +449,8 @@ static void SetupOutputFormat( decoder_t *p_dec, bool b_trust ) ...@@ -464,9 +449,8 @@ static void SetupOutputFormat( decoder_t *p_dec, bool b_trust )
{ {
decoder_sys_t *p_sys = p_dec->p_sys; decoder_sys_t *p_sys = p_dec->p_sys;
GetVlcAudioFormat( &p_dec->fmt_out.i_codec, p_dec->fmt_out.i_codec = GetVlcAudioFormat( p_sys->p_context->sample_fmt );
&p_dec->fmt_out.audio.i_bitspersample, p_dec->fmt_out.audio.i_format = p_dec->fmt_out.i_codec;
p_sys->p_context->sample_fmt );
p_dec->fmt_out.audio.i_rate = p_sys->p_context->sample_rate; p_dec->fmt_out.audio.i_rate = p_sys->p_context->sample_rate;
/* */ /* */
...@@ -518,6 +502,6 @@ static void SetupOutputFormat( decoder_t *p_dec, bool b_trust ) ...@@ -518,6 +502,6 @@ static void SetupOutputFormat( decoder_t *p_dec, bool b_trust )
p_dec->fmt_out.audio.i_physical_channels = p_dec->fmt_out.audio.i_physical_channels =
p_dec->fmt_out.audio.i_original_channels = i_layout_dst; p_dec->fmt_out.audio.i_original_channels = i_layout_dst;
p_dec->fmt_out.audio.i_channels = i_channels_dst; aout_FormatPrepare( &p_dec->fmt_out.audio );
} }
...@@ -27,7 +27,7 @@ int GetFfmpegCodec( vlc_fourcc_t i_fourcc, int *pi_cat, ...@@ -27,7 +27,7 @@ int GetFfmpegCodec( vlc_fourcc_t i_fourcc, int *pi_cat,
int *pi_ffmpeg_codec, const char **ppsz_name ); int *pi_ffmpeg_codec, const char **ppsz_name );
int GetVlcFourcc( int i_ffmpeg_codec, int *pi_cat, int GetVlcFourcc( int i_ffmpeg_codec, int *pi_cat,
vlc_fourcc_t *pi_fourcc, const char **ppsz_name ); vlc_fourcc_t *pi_fourcc, const char **ppsz_name );
void GetVlcAudioFormat( vlc_fourcc_t *, unsigned *pi_bits, int i_sample_fmt ); vlc_fourcc_t GetVlcAudioFormat( int i_sample_fmt );
picture_t * DecodeVideo( decoder_t *, block_t ** ); picture_t * DecodeVideo( decoder_t *, block_t ** );
block_t * DecodeAudio( decoder_t *, block_t ** ); block_t * DecodeAudio( decoder_t *, block_t ** );
......
...@@ -807,9 +807,9 @@ int OpenEncoder( vlc_object_t *p_this ) ...@@ -807,9 +807,9 @@ int OpenEncoder( vlc_object_t *p_this )
if( p_enc->fmt_in.i_cat == AUDIO_ES ) if( p_enc->fmt_in.i_cat == AUDIO_ES )
{ {
GetVlcAudioFormat( &p_enc->fmt_in.i_codec, p_enc->fmt_in.i_codec = GetVlcAudioFormat( p_sys->p_context->sample_fmt );
&p_enc->fmt_in.audio.i_bitspersample, p_enc->fmt_in.audio.i_bitspersample = aout_BitsPerSample( p_enc->fmt_in.i_codec );
p_sys->p_context->sample_fmt );
p_sys->i_sample_bytes = (p_enc->fmt_in.audio.i_bitspersample / 8) * p_sys->i_sample_bytes = (p_enc->fmt_in.audio.i_bitspersample / 8) *
p_context->channels; p_context->channels;
p_sys->i_frame_size = p_context->frame_size > 1 ? p_sys->i_frame_size = p_context->frame_size > 1 ?
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment