43     0x0200020002000200LL,};
 
   47     0x0004000400040004LL,};
 
   68 #define COMPILE_TEMPLATE_MMXEXT 0 
   69 #define RENAME(a) a ## _mmx 
   74 #if HAVE_MMXEXT_INLINE 
   76 #undef COMPILE_TEMPLATE_MMXEXT 
   77 #define COMPILE_TEMPLATE_MMXEXT 1 
   78 #define RENAME(a) a ## _mmxext 
  103     const int firstLumSrcY= vLumFilterPos[
dstY]; 
 
  104     const int firstChrSrcY= vChrFilterPos[chrDstY]; 
 
  112     if (dstY < dstH - 2) {
 
  113         const int16_t **lumSrcPtr  = (
const int16_t **)(
void*) lumPlane->
line + firstLumSrcY - lumPlane->
sliceY;
 
  114         const int16_t **chrUSrcPtr = (
const int16_t **)(
void*) chrUPlane->
line + firstChrSrcY - chrUPlane->
sliceY;
 
  115         const int16_t **alpSrcPtr  = (CONFIG_SWSCALE_ALPHA && hasAlpha) ? (
const int16_t **)(
void*) alpPlane->
line + firstLumSrcY - alpPlane->
sliceY : 
NULL;
 
  118         if (firstLumSrcY < 0 || firstLumSrcY + vLumFilterSize > c->
srcH) {
 
  119             const int16_t **tmpY = (
const int16_t **) lumPlane->
tmp;
 
  121             int neg = -firstLumSrcY, i, 
end = 
FFMIN(c->
srcH - firstLumSrcY, vLumFilterSize);
 
  122             for (i = 0; i < neg;            i++)
 
  123                 tmpY[i] = lumSrcPtr[neg];
 
  124             for (     ; i < 
end;            i++)
 
  125                 tmpY[i] = lumSrcPtr[i];
 
  131                 const int16_t **tmpA = (
const int16_t **) alpPlane->
tmp;
 
  132                 for (i = 0; i < neg;            i++)
 
  133                     tmpA[i] = alpSrcPtr[neg];
 
  134                 for (     ; i < 
end;            i++)
 
  135                     tmpA[i] = alpSrcPtr[i];
 
  137                     tmpA[i] = tmpA[i - 1];
 
  141         if (firstChrSrcY < 0 || firstChrSrcY + vChrFilterSize > c->
chrSrcH) {
 
  142             const int16_t **tmpU = (
const int16_t **) chrUPlane->
tmp;
 
  143             int neg = -firstChrSrcY, i, end = 
FFMIN(c->
chrSrcH - firstChrSrcY, vChrFilterSize);
 
  144             for (i = 0; i < neg;            i++) {
 
  145                 tmpU[i] = chrUSrcPtr[neg];
 
  147             for (     ; i < 
end;            i++) {
 
  148                 tmpU[i] = chrUSrcPtr[i];
 
  151                 tmpU[i] = tmpU[i - 1];
 
  159                 *(
const void**)&lumMmxFilter[s*i              ]= lumSrcPtr[i  ];
 
  160                 *(
const void**)&lumMmxFilter[s*i+
APCK_PTR2/4  ]= lumSrcPtr[i+(vLumFilterSize>1)];
 
  162                 lumMmxFilter[s*i+
APCK_COEF/4+1]= vLumFilter[dstY*vLumFilterSize + i    ]
 
  163                 + (vLumFilterSize>1 ? vLumFilter[dstY*vLumFilterSize + i + 1]<<16 : 0);
 
  164                 if (CONFIG_SWSCALE_ALPHA && hasAlpha) {
 
  165                     *(
const void**)&alpMmxFilter[s*i              ]= alpSrcPtr[i  ];
 
  166                     *(
const void**)&alpMmxFilter[s*i+
APCK_PTR2/4  ]= alpSrcPtr[i+(vLumFilterSize>1)];
 
  172                 *(
const void**)&chrMmxFilter[s*i              ]= chrUSrcPtr[i  ];
 
  173                 *(
const void**)&chrMmxFilter[s*i+
APCK_PTR2/4  ]= chrUSrcPtr[i+(vChrFilterSize>1)];
 
  175                 chrMmxFilter[s*i+
APCK_COEF/4+1]= vChrFilter[chrDstY*vChrFilterSize + i    ]
 
  176                 + (vChrFilterSize>1 ? vChrFilter[chrDstY*vChrFilterSize + i + 1]<<16 : 0);
 
  180                 *(
const void**)&lumMmxFilter[4*i+0]= lumSrcPtr[i];
 
  183                 ((uint16_t)vLumFilter[dstY*vLumFilterSize + i])*0x10001
U;
 
  184                 if (CONFIG_SWSCALE_ALPHA && hasAlpha) {
 
  185                     *(
const void**)&alpMmxFilter[4*i+0]= alpSrcPtr[i];
 
  187                     alpMmxFilter[4*i+3]= lumMmxFilter[4*i+2];
 
  191                 *(
const void**)&chrMmxFilter[4*i+0]= chrUSrcPtr[i];
 
  194                 ((uint16_t)vChrFilter[chrDstY*vChrFilterSize + i])*0x10001
U;
 
  201 static void yuv2yuvX_sse3(
const int16_t *
filter, 
int filterSize,
 
  205     if(((uintptr_t)dest) & 15){
 
  206         yuv2yuvX_mmxext(filter, filterSize, src, dest, dstW, dither, offset);
 
  210 #define MAIN_FUNCTION \ 
  211         "pxor       %%xmm0, %%xmm0 \n\t" \ 
  212         "punpcklbw  %%xmm0, %%xmm3 \n\t" \ 
  213         "movd           %4, %%xmm1 \n\t" \ 
  214         "punpcklwd  %%xmm1, %%xmm1 \n\t" \ 
  215         "punpckldq  %%xmm1, %%xmm1 \n\t" \ 
  216         "punpcklqdq %%xmm1, %%xmm1 \n\t" \ 
  217         "psllw          $3, %%xmm1 \n\t" \ 
  218         "paddw      %%xmm1, %%xmm3 \n\t" \ 
  219         "psraw          $4, %%xmm3 \n\t" \ 
  220         "movdqa     %%xmm3, %%xmm4 \n\t" \ 
  221         "movdqa     %%xmm3, %%xmm7 \n\t" \ 
  222         "movl           %3, %%ecx  \n\t" \ 
  223         "mov                                 %0, %%"FF_REG_d"        \n\t"\ 
  224         "mov                        (%%"FF_REG_d"), %%"FF_REG_S"     \n\t"\ 
  227         "movddup                  8(%%"FF_REG_d"), %%xmm0   \n\t" \ 
  228         "movdqa              (%%"FF_REG_S", %%"FF_REG_c", 2), %%xmm2 \n\t" \ 
  229         "movdqa            16(%%"FF_REG_S", %%"FF_REG_c", 2), %%xmm5 \n\t" \ 
  230         "add                                $16, %%"FF_REG_d"        \n\t"\ 
  231         "mov                        (%%"FF_REG_d"), %%"FF_REG_S"     \n\t"\ 
  232         "test                         %%"FF_REG_S", %%"FF_REG_S"     \n\t"\ 
  233         "pmulhw                           %%xmm0, %%xmm2      \n\t"\ 
  234         "pmulhw                           %%xmm0, %%xmm5      \n\t"\ 
  235         "paddw                            %%xmm2, %%xmm3      \n\t"\ 
  236         "paddw                            %%xmm5, %%xmm4      \n\t"\ 
  238         "psraw                               $3, %%xmm3      \n\t"\ 
  239         "psraw                               $3, %%xmm4      \n\t"\ 
  240         "packuswb                         %%xmm4, %%xmm3      \n\t"\ 
  241         "movntdq                          %%xmm3, (%1, %%"FF_REG_c") \n\t"\ 
  242         "add                         $16, %%"FF_REG_c"        \n\t"\ 
  243         "cmp                          %2, %%"FF_REG_c"        \n\t"\ 
  244         "movdqa                   %%xmm7, %%xmm3            \n\t" \ 
  245         "movdqa                   %%xmm7, %%xmm4            \n\t" \ 
  246         "mov                                 %0, %%"FF_REG_d"        \n\t"\ 
  247         "mov                        (%%"FF_REG_d"), %%"FF_REG_S"     \n\t"\ 
  252             "movq          %5, %%xmm3  \n\t" 
  253             "movdqa    %%xmm3, %%xmm4  \n\t" 
  254             "psrlq        $24, %%xmm3  \n\t" 
  255             "psllq        $40, %%xmm4  \n\t" 
  256             "por       %%xmm4, %%xmm3  \n\t" 
  259               "r" (dest-offset), 
"g" ((
x86_reg)(dstW+offset)), 
"m" (offset),
 
  260               "m"(filterSize), 
"m"(((uint64_t *) 
dither)[0])
 
  261               : 
XMM_CLOBBERS(
"%xmm0" , 
"%xmm1" , 
"%xmm2" , 
"%xmm3" , 
"%xmm4" , 
"%xmm5" , 
"%xmm7" ,)
 
  262                 "%"FF_REG_d, 
"%"FF_REG_S, 
"%"FF_REG_c
 
  266             "movq          %5, %%xmm3   \n\t" 
  269               "r" (dest-offset), 
"g" ((
x86_reg)(dstW+offset)), 
"m" (offset),
 
  270               "m"(filterSize), 
"m"(((uint64_t *) 
dither)[0])
 
  271               : 
XMM_CLOBBERS(
"%xmm0" , 
"%xmm1" , 
"%xmm2" , 
"%xmm3" , 
"%xmm4" , 
"%xmm5" , 
"%xmm7" ,)
 
  272                 "%"FF_REG_d, 
"%"FF_REG_S, 
"%"FF_REG_c
 
  280 #define SCALE_FUNC(filter_n, from_bpc, to_bpc, opt) \ 
  281 void ff_hscale ## from_bpc ## to ## to_bpc ## _ ## filter_n ## _ ## opt( \ 
  282                                                 SwsContext *c, int16_t *data, \ 
  283                                                 int dstW, const uint8_t *src, \ 
  284                                                 const int16_t *filter, \ 
  285                                                 const int32_t *filterPos, int filterSize) 
  287 #define SCALE_FUNCS(filter_n, opt) \ 
  288     SCALE_FUNC(filter_n,  8, 15, opt); \ 
  289     SCALE_FUNC(filter_n,  9, 15, opt); \ 
  290     SCALE_FUNC(filter_n, 10, 15, opt); \ 
  291     SCALE_FUNC(filter_n, 12, 15, opt); \ 
  292     SCALE_FUNC(filter_n, 14, 15, opt); \ 
  293     SCALE_FUNC(filter_n, 16, 15, opt); \ 
  294     SCALE_FUNC(filter_n,  8, 19, opt); \ 
  295     SCALE_FUNC(filter_n,  9, 19, opt); \ 
  296     SCALE_FUNC(filter_n, 10, 19, opt); \ 
  297     SCALE_FUNC(filter_n, 12, 19, opt); \ 
  298     SCALE_FUNC(filter_n, 14, 19, opt); \ 
  299     SCALE_FUNC(filter_n, 16, 19, opt) 
  301 #define SCALE_FUNCS_MMX(opt) \ 
  302     SCALE_FUNCS(4, opt); \ 
  303     SCALE_FUNCS(8, opt); \ 
  306 #define SCALE_FUNCS_SSE(opt) \ 
  307     SCALE_FUNCS(4, opt); \ 
  308     SCALE_FUNCS(8, opt); \ 
  309     SCALE_FUNCS(X4, opt); \ 
  319 #define VSCALEX_FUNC(size, opt) \ 
  320 void ff_yuv2planeX_ ## size ## _ ## opt(const int16_t *filter, int filterSize, \ 
  321                                         const int16_t **src, uint8_t *dest, int dstW, \ 
  322                                         const uint8_t *dither, int offset) 
  323 #define VSCALEX_FUNCS(opt) \ 
  324     VSCALEX_FUNC(8,  opt); \ 
  325     VSCALEX_FUNC(9,  opt); \ 
  326     VSCALEX_FUNC(10, opt) 
  336 #define VSCALE_FUNC(size, opt) \ 
  337 void ff_yuv2plane1_ ## size ## _ ## opt(const int16_t *src, uint8_t *dst, int dstW, \ 
  338                                         const uint8_t *dither, int offset) 
  339 #define VSCALE_FUNCS(opt1, opt2) \ 
  340     VSCALE_FUNC(8,  opt1); \ 
  341     VSCALE_FUNC(9,  opt2); \ 
  342     VSCALE_FUNC(10, opt2); \ 
  343     VSCALE_FUNC(16, opt1) 
  352 #define INPUT_Y_FUNC(fmt, opt) \ 
  353 void ff_ ## fmt ## ToY_  ## opt(uint8_t *dst, const uint8_t *src, \ 
  354                                 const uint8_t *unused1, const uint8_t *unused2, \ 
  355                                 int w, uint32_t *unused) 
  356 #define INPUT_UV_FUNC(fmt, opt) \ 
  357 void ff_ ## fmt ## ToUV_ ## opt(uint8_t *dstU, uint8_t *dstV, \ 
  358                                 const uint8_t *unused0, \ 
  359                                 const uint8_t *src1, \ 
  360                                 const uint8_t *src2, \ 
  361                                 int w, uint32_t *unused) 
  362 #define INPUT_FUNC(fmt, opt) \ 
  363     INPUT_Y_FUNC(fmt, opt); \ 
  364     INPUT_UV_FUNC(fmt, opt) 
  365 #define INPUT_FUNCS(opt) \ 
  366     INPUT_FUNC(uyvy, opt); \ 
  367     INPUT_FUNC(yuyv, opt); \ 
  368     INPUT_UV_FUNC(nv12, opt); \ 
  369     INPUT_UV_FUNC(nv21, opt); \ 
  370     INPUT_FUNC(rgba, opt); \ 
  371     INPUT_FUNC(bgra, opt); \ 
  372     INPUT_FUNC(argb, opt); \ 
  373     INPUT_FUNC(abgr, opt); \ 
  374     INPUT_FUNC(rgb24, opt); \ 
  375     INPUT_FUNC(bgr24, opt) 
  390         sws_init_swscale_mmx(c);
 
  392 #if HAVE_MMXEXT_INLINE 
  394         sws_init_swscale_mmxext(c);
 
  401 #define ASSIGN_SCALE_FUNC2(hscalefn, filtersize, opt1, opt2) do { \ 
  402     if (c->srcBpc == 8) { \ 
  403         hscalefn = c->dstBpc <= 14 ? ff_hscale8to15_ ## filtersize ## _ ## opt2 : \ 
  404                                      ff_hscale8to19_ ## filtersize ## _ ## opt1; \ 
  405     } else if (c->srcBpc == 9) { \ 
  406         hscalefn = c->dstBpc <= 14 ? ff_hscale9to15_ ## filtersize ## _ ## opt2 : \ 
  407                                      ff_hscale9to19_ ## filtersize ## _ ## opt1; \ 
  408     } else if (c->srcBpc == 10) { \ 
  409         hscalefn = c->dstBpc <= 14 ? ff_hscale10to15_ ## filtersize ## _ ## opt2 : \ 
  410                                      ff_hscale10to19_ ## filtersize ## _ ## opt1; \ 
  411     } else if (c->srcBpc == 12) { \ 
  412         hscalefn = c->dstBpc <= 14 ? ff_hscale12to15_ ## filtersize ## _ ## opt2 : \ 
  413                                      ff_hscale12to19_ ## filtersize ## _ ## opt1; \ 
  414     } else if (c->srcBpc == 14 || ((c->srcFormat==AV_PIX_FMT_PAL8||isAnyRGB(c->srcFormat)) && av_pix_fmt_desc_get(c->srcFormat)->comp[0].depth<16)) { \ 
  415         hscalefn = c->dstBpc <= 14 ? ff_hscale14to15_ ## filtersize ## _ ## opt2 : \ 
  416                                      ff_hscale14to19_ ## filtersize ## _ ## opt1; \ 
  418         av_assert0(c->srcBpc == 16);\ 
  419         hscalefn = c->dstBpc <= 14 ? ff_hscale16to15_ ## filtersize ## _ ## opt2 : \ 
  420                                      ff_hscale16to19_ ## filtersize ## _ ## opt1; \ 
  423 #define ASSIGN_MMX_SCALE_FUNC(hscalefn, filtersize, opt1, opt2) \ 
  424     switch (filtersize) { \ 
  425     case 4:  ASSIGN_SCALE_FUNC2(hscalefn, 4, opt1, opt2); break; \ 
  426     case 8:  ASSIGN_SCALE_FUNC2(hscalefn, 8, opt1, opt2); break; \ 
  427     default: ASSIGN_SCALE_FUNC2(hscalefn, X, opt1, opt2); break; \ 
  429 #define ASSIGN_VSCALEX_FUNC(vscalefn, opt, do_16_case, condition_8bit) \ 
  431     case 16:                          do_16_case;                          break; \ 
  432     case 10: if (!isBE(c->dstFormat) && c->dstFormat != AV_PIX_FMT_P010LE) vscalefn = ff_yuv2planeX_10_ ## opt; break; \ 
  433     case 9:  if (!isBE(c->dstFormat)) vscalefn = ff_yuv2planeX_9_  ## opt; break; \ 
  434     case 8: if ((condition_8bit) && !c->use_mmx_vfilter) vscalefn = ff_yuv2planeX_8_  ## opt; break; \ 
  436 #define ASSIGN_VSCALE_FUNC(vscalefn, opt1, opt2, opt2chk) \ 
  438     case 16: if (!isBE(c->dstFormat))            vscalefn = ff_yuv2plane1_16_ ## opt1; break; \ 
  439     case 10: if (!isBE(c->dstFormat) && c->dstFormat != AV_PIX_FMT_P010LE && opt2chk) vscalefn = ff_yuv2plane1_10_ ## opt2; break; \ 
  440     case 9:  if (!isBE(c->dstFormat) && opt2chk) vscalefn = ff_yuv2plane1_9_  ## opt2;  break; \ 
  441     case 8:                                      vscalefn = ff_yuv2plane1_8_  ## opt1;  break; \ 
  442     default: av_assert0(c->dstBpc>8); \ 
  444 #define case_rgb(x, X, opt) \ 
  445         case AV_PIX_FMT_ ## X: \ 
  446             c->lumToYV12 = ff_ ## x ## ToY_ ## opt; \ 
  447             if (!c->chrSrcHSubSample) \ 
  448                 c->chrToYV12 = ff_ ## x ## ToUV_ ## opt; \ 
  490 #define ASSIGN_SSE_SCALE_FUNC(hscalefn, filtersize, opt1, opt2) \ 
  491     switch (filtersize) { \ 
  492     case 4:  ASSIGN_SCALE_FUNC2(hscalefn, 4, opt1, opt2); break; \ 
  493     case 8:  ASSIGN_SCALE_FUNC2(hscalefn, 8, opt1, opt2); break; \ 
  494     default: if (filtersize & 4) ASSIGN_SCALE_FUNC2(hscalefn, X4, opt1, opt2); \ 
  495              else                ASSIGN_SCALE_FUNC2(hscalefn, X8, opt1, opt2); \ 
  502                             HAVE_ALIGNED_STACK || ARCH_X86_64);
 
  551                             HAVE_ALIGNED_STACK || ARCH_X86_64);
 
  558                             HAVE_ALIGNED_STACK || ARCH_X86_64);
 
#define EXTERNAL_MMX(flags)
packed YUV 4:2:2, 16bpp, Cb Y0 Cr Y1 
const uint64_t ff_dither8[2]
int chrBufIndex
Index in ring buffer of the last scaled horizontal chroma line from source. 
int chrSrcH
Height of source chroma planes. 
8 bits gray, 8 bits alpha 
#define VSCALE_FUNC(size, opt)
#define SCALE_FUNCS_MMX(opt)
static atomic_int cpu_flags
int dstY
Last destination vertical line output from last slice. 
#define case_rgb(x, X, opt)
Macro definitions for various function/variable attributes. 
#define ASSIGN_SSE_SCALE_FUNC(hscalefn, filtersize, opt1, opt2)
int srcH
Height of source luma/alpha planes. 
#define VSCALE_FUNCS(opt1, opt2)
#define EXTERNAL_SSE4(flags)
static void filter(int16_t *output, ptrdiff_t out_stride, int16_t *low, ptrdiff_t low_stride, int16_t *high, ptrdiff_t high_stride, int len, int clip)
int chrDstVSubSample
Binary logarithm of vertical subsampling factor between luma/alpha and chroma planes in destination i...
uint8_t ** line
line buffer 
int vChrFilterSize
Vertical filter size for chroma pixels. 
static av_cold int end(AVCodecContext *avctx)
#define AV_CPU_FLAG_MMXEXT
SSE integer functions or AMD MMX ext. 
void(* lumToYV12)(uint8_t *dst, const uint8_t *src, const uint8_t *src2, const uint8_t *src3, int width, uint32_t *pal)
Unscaled conversion of luma plane to YV12 for horizontal scaler. 
av_cold void ff_sws_init_swscale_x86(SwsContext *c)
#define DECLARE_ALIGNED(n, t, v)
Declare a variable that is aligned in memory. 
int lastInLumBuf
Last scaled horizontal luma/alpha line from source in the ring buffer. 
enum AVPixelFormat dstFormat
Destination pixel format. 
#define EXTERNAL_SSE2(flags)
#define VSCALEX_FUNCS(opt)
int32_t * vChrFilterPos
Array of vertical filter starting positions for each dst[i] for chroma planes. 
int dstH
Height of destination luma/alpha planes. 
#define INLINE_MMX(flags)
const uint64_t ff_dither4[2]
int hLumFilterSize
Horizontal filter size for luma/alpha pixels. 
static const uint8_t dither[8][8]
planar YUV 4:2:0, 12bpp, 1 plane for Y and 1 plane for the UV components, which are interleaved (firs...
simple assert() macros that are a bit more flexible than ISO C assert(). 
static const uint8_t offset[127][2]
SwsPlane plane[MAX_SLICE_PLANES]
color planes 
int32_t alpMmxFilter[4 *MAX_FILTER_SIZE]
int hChrFilterSize
Horizontal filter size for chroma pixels. 
#define DECLARE_ASM_CONST(n, t, v)
Declare a static constant aligned variable appropriate for use in inline assembly code...
as above, but U and V bytes are swapped 
#define AV_CPU_FLAG_SSE3
Prescott SSE3 functions. 
yuv2planar1_fn yuv2plane1
#define SCALE_FUNCS_SSE(opt)
void(* hcScale)(struct SwsContext *c, int16_t *dst, int dstW, const uint8_t *src, const int16_t *filter, const int32_t *filterPos, int filterSize)
#define XMM_CLOBBERS(...)
int dstW
Width of destination luma/alpha planes. 
int32_t * vLumFilterPos
Array of vertical filter starting positions for each dst[i] for luma/alpha planes. 
#define AV_PIX_FMT_BGR555
static av_always_inline int isBE(enum AVPixelFormat pix_fmt)
int32_t lumMmxFilter[4 *MAX_FILTER_SIZE]
#define ASSIGN_MMX_SCALE_FUNC(hscalefn, filtersize, opt1, opt2)
yuv2planarX_fn yuv2planeX
#define DECLARE_ASM_ALIGNED(n, t, v)
Declare an aligned variable appropriate for use in inline assembly code. 
packed YUV 4:2:2, 16bpp, Y0 Cb Y1 Cr 
#define EXTERNAL_SSSE3(flags)
int vLumFilterSize
Vertical filter size for luma/alpha pixels. 
int16_t * vChrFilter
Array of vertical filter coefficients for chroma planes. 
int av_get_cpu_flags(void)
Return the flags which specify extensions supported by the CPU. 
#define flags(name, subs,...)
#define EXTERNAL_MMXEXT(flags)
int lumBufIndex
Index in ring buffer of the last scaled horizontal luma/alpha line from source. 
#define VSCALEX_FUNC(size, opt)
#define INLINE_MMXEXT(flags)
int lastInChrBuf
Last scaled horizontal chroma line from source in the ring buffer. 
enum AVPixelFormat srcFormat
Source pixel format. 
int32_t chrMmxFilter[4 *MAX_FILTER_SIZE]
#define AV_PIX_FMT_RGB555
#define ASSIGN_VSCALEX_FUNC(vscalefn, opt, do_16_case, condition_8bit)
#define ASSIGN_VSCALE_FUNC(vscalefn, opt1, opt2, opt2chk)
uint8_t ** tmp
Tmp line buffer used by mmx code. 
void(* alpToYV12)(uint8_t *dst, const uint8_t *src, const uint8_t *src2, const uint8_t *src3, int width, uint32_t *pal)
Unscaled conversion of alpha plane to YV12 for horizontal scaler. 
void ff_updateMMXDitherTables(SwsContext *c, int dstY, int lumBufIndex, int chrBufIndex, int lastInLumBuf, int lastInChrBuf)
void(* chrToYV12)(uint8_t *dstU, uint8_t *dstV, const uint8_t *src1, const uint8_t *src2, const uint8_t *src3, int width, uint32_t *pal)
Unscaled conversion of chroma planes to YV12 for horizontal scaler. 
int16_t * vLumFilter
Array of vertical filter coefficients for luma/alpha planes. 
int sliceY
index of first line 
int flags
Flags passed by the user to select scaler algorithm, optimizations, subsampling, etc... 
#define EXTERNAL_AVX(flags)
void(* hyScale)(struct SwsContext *c, int16_t *dst, int dstW, const uint8_t *src, const int16_t *filter, const int32_t *filterPos, int filterSize)
Scale one horizontal line of input data using a filter over the input lines, to produce one (differen...