[FFmpeg-devel] [PATCH]lavc/dds: Fix GRAY8A decoding

Paul B Mahol onemda at gmail.com
Thu Apr 14 22:45:40 CEST 2016


On 4/14/16, Carl Eugen Hoyos <cehoyos at ag.or.at> wrote:
> Hi!
>
> Attached patch fixes the original sample of ticket #4667 for me.
>
> Please comment, Carl Eugen
>

> diff --git a/libavcodec/dds.c b/libavcodec/dds.c
> index 9577b67..f364de7 100644
> --- a/libavcodec/dds.c
> +++ b/libavcodec/dds.c
> @@ -356,6 +356,10 @@ static int parse_pixel_format(AVCodecContext *avctx)
>          /* 16 bpp */
>          else if (bpp == 16 && r == 0xff && g == 0 && b == 0 && a == 0xff00)
>              avctx->pix_fmt = AV_PIX_FMT_YA8;
> +        else if (bpp == 16 && r == 0xff00 && g == 0 && b == 0 && a == 0xff) {
> +            avctx->pix_fmt = AV_PIX_FMT_YA8;
> +            ctx->postproc = DDS_SWAP_ALPHA;

Why? You disabled postproc lines bellow.

> +        }
>          else if (bpp == 16 && r == 0xffff && g == 0 && b == 0 && a == 0)
>              avctx->pix_fmt = AV_PIX_FMT_GRAY16LE;
>          else if (bpp == 16 && r == 0xf800 && g == 0x7e0 && b == 0x1f && a == 0)
> @@ -387,8 +391,6 @@ static int parse_pixel_format(AVCodecContext *avctx)
>          ctx->postproc = DDS_NORMAL_MAP;
>      else if (ycocg_classic && !ctx->compressed)
>          ctx->postproc = DDS_RAW_YCOCG;
> -    else if (avctx->pix_fmt == AV_PIX_FMT_YA8)
> -        ctx->postproc = DDS_SWAP_ALPHA;
>
>      /* ATI/NVidia variants sometimes add swizzling in bpp. */
>      switch (bpp) {
> @@ -697,8 +699,7 @@ static int dds_decode(AVCodecContext *avctx, void *data,
>      if (avctx->pix_fmt == AV_PIX_FMT_BGRA ||
>          avctx->pix_fmt == AV_PIX_FMT_RGBA ||
>          avctx->pix_fmt == AV_PIX_FMT_RGB0 ||
> -        avctx->pix_fmt == AV_PIX_FMT_BGR0 ||
> -        avctx->pix_fmt == AV_PIX_FMT_YA8)
> +        avctx->pix_fmt == AV_PIX_FMT_BGR0)
>          run_postproc(avctx, frame);
>
>      /* Frame is ready to be output. */
> diff --git a/tests/ref/fate/dds-ya b/tests/ref/fate/dds-ya
> index d6527c6..01f7894 100644
> --- a/tests/ref/fate/dds-ya
> +++ b/tests/ref/fate/dds-ya
> @@ -1,2 +1,2 @@
>  #tb 0: 1/25
> -0,          0,          0,        1,    28160, 0xd3981fcb
> +0,          0,          0,        1,    28160, 0x5aa41fcb

I believe this shouldn't change, do you have explanation why it should change?


More information about the ffmpeg-devel mailing list