[FFmpeg-devel] [PATCH] avisynth: fix audio on big endian

Andreas Rheinhardt andreas.rheinhardt at gmail.com
Thu Feb 18 01:14:11 EET 2021


Stephen Hutchinson:
> ---
> Open for bikeshedding, as I'm not too sure of
> the names, but I didn't want to use anything
> too close to regular AV_CODEC_ID* defines.
>  libavformat/avisynth.c | 21 +++++++++++++++++----
>  1 file changed, 17 insertions(+), 4 deletions(-)
> 
> diff --git a/libavformat/avisynth.c b/libavformat/avisynth.c
> index f029a0e842..fbebb6707c 100644
> --- a/libavformat/avisynth.c
> +++ b/libavformat/avisynth.c
> @@ -42,6 +42,19 @@
>    #define AVISYNTH_LIB AVISYNTH_NAME SLIBSUF
>  #endif
>  
> +/* Endianness guards for audio */
> +#if HAVE_BIGENDIAN
> +    #define AVISYNTH_PCM_OUT_S16 AV_CODEC_ID_PCM_S16BE
> +    #define AVISYNTH_PCM_OUT_S24 AV_CODEC_ID_PCM_S24BE
> +    #define AVISYNTH_PCM_OUT_S32 AV_CODEC_ID_PCM_S32BE
> +    #define AVISYNTH_PCM_OUT_F32 AV_CODEC_ID_PCM_F32BE
> +#else
> +    #define AVISYNTH_PCM_OUT_S16 AV_CODEC_ID_PCM_S16LE
> +    #define AVISYNTH_PCM_OUT_S24 AV_CODEC_ID_PCM_S24LE
> +    #define AVISYNTH_PCM_OUT_S32 AV_CODEC_ID_PCM_S32LE
> +    #define AVISYNTH_PCM_OUT_F32 AV_CODEC_ID_PCM_F32LE
> +#endif
#if HAVE_BIGENDION
#define PCM(format) (AV_CODEC_ID_PCM_ ## format ## BE)
#else
#define PCM(format) (AV_CODEC_ID_PCM_ ## format ## LE)
#endif

With this the above lines would become
st->codecpar->codec_id = PCM(S16) etc.

Alternatively one could also use AV_NE directly.


> +
>  #include <avisynth/avisynth_c.h>
>  
>  typedef struct AviSynthLibrary {
> @@ -496,16 +509,16 @@ static int avisynth_create_stream_audio(AVFormatContext *s, AVStream *st)
>          st->codecpar->codec_id = AV_CODEC_ID_PCM_U8;
>          break;
>      case AVS_SAMPLE_INT16:
> -        st->codecpar->codec_id = AV_CODEC_ID_PCM_S16LE;
> +        st->codecpar->codec_id = AVISYNTH_PCM_OUT_S16;
>          break;
>      case AVS_SAMPLE_INT24:
> -        st->codecpar->codec_id = AV_CODEC_ID_PCM_S24LE;
> +        st->codecpar->codec_id = AVISYNTH_PCM_OUT_S24;
>          break;
>      case AVS_SAMPLE_INT32:
> -        st->codecpar->codec_id = AV_CODEC_ID_PCM_S32LE;
> +        st->codecpar->codec_id = AVISYNTH_PCM_OUT_S32;
>          break;
>      case AVS_SAMPLE_FLOAT:
> -        st->codecpar->codec_id = AV_CODEC_ID_PCM_F32LE;
> +        st->codecpar->codec_id = AVISYNTH_PCM_OUT_F32;
>          break;
>      default:
>          av_log(s, AV_LOG_ERROR,
> 



More information about the ffmpeg-devel mailing list