[FFmpeg-soc] [soc]: r5782 - libavfilter/vf_overlay.c

Baptiste Coudurier baptiste.coudurier at gmail.com
Wed May 12 00:55:11 CEST 2010


On 05/01/2010 03:44 PM, stefano wrote:
> Author: stefano
> Date: Sun May  2 00:44:49 2010
> New Revision: 5782
>
> Log:
> Make config_input_main() use pixdesc.h for computing chroma offsets
> and bits per pixel, simplify.
>
> Modified:
>     libavfilter/vf_overlay.c
>
> Modified: libavfilter/vf_overlay.c
> ==============================================================================
> --- libavfilter/vf_overlay.c	Sun May  2 00:17:55 2010	(r5781)
> +++ libavfilter/vf_overlay.c	Sun May  2 00:44:49 2010	(r5782)
> @@ -26,6 +26,7 @@
>   #include<stdio.h>
>
>   #include "avfilter.h"
> +#include "libavutil/pixdesc.h"
>   #include "libavcodec/eval.h"
>   #include "libavutil/avstring.h"
>
> @@ -108,28 +109,9 @@ static int config_input_main(AVFilterLin
>   {
>       OverlayContext *over = link->dst->priv;
>
> -    switch(link->format) {
> -    case PIX_FMT_RGB32:
> -    case PIX_FMT_BGR32:
> -        over->bpp = 4;
> -        break;
> -    case PIX_FMT_RGB24:
> -    case PIX_FMT_BGR24:
> -        over->bpp = 3;
> -        break;
> -    case PIX_FMT_RGB565:
> -    case PIX_FMT_RGB555:
> -    case PIX_FMT_BGR565:
> -    case PIX_FMT_BGR555:
> -    case PIX_FMT_GRAY16BE:
> -    case PIX_FMT_GRAY16LE:
> -        over->bpp = 2;
> -        break;
> -    default:
> -        over->bpp = 1;
> -    }
> -
> -    avcodec_get_chroma_sub_sample(link->format,&over->hsub,&over->vsub);
> +    over->bpp = (av_get_bits_per_pixel(&av_pix_fmt_descriptors[link->format]) + 7)>>  3;
> +    over->hsub = av_pix_fmt_descriptors[link->format].log2_chroma_w;
> +    over->vsub = av_pix_fmt_descriptors[link->format].log2_chroma_h;
>

Humm this seems to break the filter.
bpp was 1 for yuv before this change, now it is 2.
bpp is used to offset x from pic->data per component, which seems not 
related to the value av_get_bits_per_pixel returns.

-- 
Baptiste COUDURIER
Key fingerprint                 8D77134D20CC9220201FC5DB0AC9325C5C1ABAAA
FFmpeg maintainer                                  http://www.ffmpeg.org


More information about the FFmpeg-soc mailing list