On Mon, Jan 09, 2012 at 11:37:24PM +0000, Paul B Mahol wrote:
> Do not display garbage for invalid/unsupported bitfields values.
> ---
>  libavcodec/bmp.c |   14 ++++++++++++--
>  1 files changed, 12 insertions(+), 2 deletions(-)
> 
> diff --git a/libavcodec/bmp.c b/libavcodec/bmp.c
> index f438d106..1f725f5 100644
> --- a/libavcodec/bmp.c
> +++ b/libavcodec/bmp.c
> @@ -162,8 +162,18 @@ static int bmp_decode_frame(AVCodecContext *avctx,
>      case 16:
>          if(comp == BMP_RGB)
>              avctx->pix_fmt = PIX_FMT_RGB555;
> -        if(comp == BMP_BITFIELDS)
> -            avctx->pix_fmt = rgb[1] == 0x07E0 ? PIX_FMT_RGB565 : 
> PIX_FMT_RGB555;
> +        else if (comp == BMP_BITFIELDS) {
> +            if (rgb[0] == 0xF800 && rgb[1] == 0x07E0 && rgb[2] == 0x001F)
> +               avctx->pix_fmt = PIX_FMT_RGB565;
> +            else if (rgb[0] == 0x7C00 && rgb[1] == 0x03E0 && rgb[2] == 
> 0x001F)
> +               avctx->pix_fmt = PIX_FMT_RGB555;
> +            else if (rgb[0] == 0x0F00 && rgb[1] == 0x00F0 && rgb[2] == 
> 0x000F)
> +               avctx->pix_fmt = PIX_FMT_RGB444;
> +            else {
> +               av_log(avctx, AV_LOG_ERROR, "Unknown bitfields %0X %0X 
> %0X\n", rgb[0], rgb[1], rgb[2]);
> +               return AVERROR(EINVAL);
> +            }
> +        }
>          break;
>      case 8:
>          if(hsize - ihsize - 14 > 0)
> -- 

LGTM
_______________________________________________
libav-devel mailing list
[email protected]
https://lists.libav.org/mailman/listinfo/libav-devel

Reply via email to