24                           int srcStride[], 
int srcSliceY, 
int srcSliceH,
 
   25                           uint8_t *dst[], 
int dstStride[])
 
   28     int nb_components = 
desc->nb_components;
 
   30     int plane_count = 
isGray(
c->srcFormat) ? 1 : 3;
 
   31     int sixteen_bits = 
desc->comp[0].depth >= 9;
 
   32     unsigned off    = 1<<(
desc->comp[0].depth - 1);
 
   35     int target_table[2][3];
 
   37     for (plane = 0; plane < plane_count; plane++) {
 
   40             a = (1<<(
desc->comp[0].depth - 1))/2;
 
   41             b = 3*(1<<(
desc->comp[0].depth-1))/2;
 
   49         for (plane = 0; plane < plane_count; plane++) {
 
   50             int w = plane ? 
c->chrSrcW : 
c->srcW;
 
   51             int x_subsample = plane ? 
desc->log2_chroma_w: 0;
 
   52             int y_subsample = plane ? 
desc->log2_chroma_h: 0;
 
   54                 int y = ysrc + (srcSliceY >> y_subsample);
 
   55                 if (x_subsample || y_subsample) {
 
   59                         ptrdiff_t alpha_step = srcStride[plane_count] >> 1;
 
   60                         const uint16_t *
s = (
const uint16_t *)(
src[plane      ] +  srcStride[plane      ] * ysrc);
 
   61                         const uint16_t *
a = (
const uint16_t *)(
src[plane_count] + (srcStride[plane_count] * ysrc << y_subsample));
 
   62                               uint16_t *
d = (      uint16_t *)(dst[plane      ] +  dstStride[plane      ] * y);
 
   63                         if ((!
isBE(
c->srcFormat)) == !HAVE_BIGENDIAN) {
 
   64                             for (x = 0; x < 
w; x++) {
 
   66                                     alpha = (
a[2*x]              + 
a[2*x + 1] + 2 +
 
   67                                              a[2*x + alpha_step] + 
a[2*x + alpha_step + 1]) >> 2;
 
   69                                     alpha = (
a[2*x] + 
a[2*x + 1]) >> 1;
 
   74                             for (x = 0; x < 
w; x++) {
 
   85                         ptrdiff_t alpha_step = srcStride[plane_count];
 
   86                         const uint8_t *
s = 
src[plane      ] + srcStride[plane] * ysrc;
 
   87                         const uint8_t *
a = 
src[plane_count] + (srcStride[plane_count] * ysrc << y_subsample);
 
   88                               uint8_t *
d = dst[plane      ] + dstStride[plane] * y;
 
   89                         for (x = 0; x < 
w; x++) {
 
   91                                 alpha = (
a[2*x]              + 
a[2*x + 1] + 2 +
 
   92                                          a[2*x + alpha_step] + 
a[2*x + alpha_step + 1]) >> 2;
 
   94                                 alpha = (
a[2*x] + 
a[2*x + 1]) >> 1;
 
   95                             u = 
s[x]*
alpha + target_table[((x^y)>>5)&1][plane]*(255-
alpha) + 128;
 
  101                     const uint16_t *
s = (
const uint16_t *)(
src[plane      ] + srcStride[plane      ] * ysrc);
 
  102                     const uint16_t *
a = (
const uint16_t *)(
src[plane_count] + srcStride[plane_count] * ysrc);
 
  103                           uint16_t *
d = (      uint16_t *)(dst[plane      ] + dstStride[plane      ] * y);
 
  104                     if ((!
isBE(
c->srcFormat)) == !HAVE_BIGENDIAN) {
 
  105                         for (x = 0; x < 
w; x++) {
 
  106                             unsigned u = 
s[x]*
a[x] + target_table[((x^y)>>5)&1][plane]*(
max-
a[x]) + off;
 
  110                         for (x = 0; x < 
w; x++) {
 
  112                             unsigned u = 
av_bswap16(
s[x])*aswap + target_table[((x^y)>>5)&1][plane]*(
max-aswap) + off;
 
  117                     const uint8_t *
s = 
src[plane      ] + srcStride[plane] * ysrc;
 
  118                     const uint8_t *
a = 
src[plane_count] + srcStride[plane_count] * ysrc;
 
  119                           uint8_t *
d = dst[plane      ] + dstStride[plane] * y;
 
  120                     for (x = 0; x < 
w; x++) {
 
  121                         unsigned u = 
s[x]*
a[x] + target_table[((x^y)>>5)&1][plane]*(255-
a[x]) + 128;
 
  122                         d[x] = (257*
u) >> 16;
 
  129         int alpha_pos = 
desc->comp[plane_count].offset;
 
  131         for (ysrc = 0; ysrc < 
srcSliceH; ysrc++) {
 
  132             int y = ysrc + srcSliceY;
 
  134                 const uint16_t *
s = (
const uint16_t *)(
src[0] + srcStride[0] * ysrc + 2*!alpha_pos);
 
  135                 const uint16_t *
a = (
const uint16_t *)(
src[0] + srcStride[0] * ysrc +    alpha_pos);
 
  136                       uint16_t *
d = (      uint16_t *)(dst[0] + dstStride[0] * y);
 
  137                 if ((!
isBE(
c->srcFormat)) == !HAVE_BIGENDIAN) {
 
  138                     for (x = 0; x < 
w; x++) {
 
  139                         for (plane = 0; plane < plane_count; plane++) {
 
  140                             int x_index = (plane_count + 1) * x;
 
  141                             unsigned u = 
s[x_index + plane]*
a[x_index] + target_table[((x^y)>>5)&1][plane]*(
max-
a[x_index]) + off;
 
  146                     for (x = 0; x < 
w; x++) {
 
  147                         for (plane = 0; plane < plane_count; plane++) {
 
  148                             int x_index = (plane_count + 1) * x;
 
  150                             unsigned u = 
av_bswap16(
s[x_index + plane])*aswap + target_table[((x^y)>>5)&1][plane]*(
max-aswap) + off;
 
  156                 const uint8_t *
s = 
src[0] + srcStride[0] * ysrc + !alpha_pos;
 
  157                 const uint8_t *
a = 
src[0] + srcStride[0] * ysrc + alpha_pos;
 
  158                       uint8_t *
d = dst[0] + dstStride[0] * y;
 
  159                 for (x = 0; x < 
w; x++) {
 
  160                     for (plane = 0; plane < plane_count; plane++) {
 
  161                         int x_index = (plane_count + 1) * x;
 
  162                         unsigned u = 
s[x_index + plane]*
a[x_index] + target_table[((x^y)>>5)&1][plane]*(255-
a[x_index]) + 128;
 
  163                         d[plane_count*x + plane] = (257*
u) >> 16;