Added gst-plugins-base-subtitles0.10-0.10.34 for Meego Harmattan 1.2
[mafwsubrenderer] / gst-plugins-base-subtitles0.10 / gst / ffmpegcolorspace / imgconvert_template.h
diff --git a/gst-plugins-base-subtitles0.10/gst/ffmpegcolorspace/imgconvert_template.h b/gst-plugins-base-subtitles0.10/gst/ffmpegcolorspace/imgconvert_template.h
new file mode 100644 (file)
index 0000000..3b287e7
--- /dev/null
@@ -0,0 +1,2188 @@
+/*
+ * Templates for image convertion routines
+ * Copyright (c) 2001, 2002, 2003 Fabrice Bellard.
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2 of the License, or (at your option) any later version.
+ *
+ * This library is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with this library; if not, write to the Free Software
+ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
+ */
+
+#ifndef RGB_OUT
+#define RGB_OUT(d, r, g, b) RGBA_OUT(d, r, g, b, 0xffU)
+#endif
+
+static void glue (uyvy422_to_, RGB_NAME)(AVPicture *dst, const AVPicture *src,
+                                        int width, int height)
+{
+    uint8_t *s, *d, *d1, *s1;
+    int w, y, cb, cr, r_add, g_add, b_add;
+    uint8_t *cm = cropTbl + MAX_NEG_CROP;
+    unsigned int r, g, b;
+
+    d = dst->data[0];
+    s = src->data[0];
+    for(;height > 0; height --) {
+        d1 = d;
+        s1 = s;
+        for(w = width; w >= 2; w -= 2) {
+            YUV_TO_RGB1_CCIR(s1[0], s1[2]);
+
+            YUV_TO_RGB2_CCIR(r, g, b, s1[1]);
+            RGB_OUT(d1, r, g, b);
+            d1 += BPP;
+
+            YUV_TO_RGB2_CCIR(r, g, b, s1[3]);
+            RGB_OUT(d1, r, g, b);
+            d1 += BPP;
+
+            s1 += 4;
+        }
+
+        if (w) {
+            YUV_TO_RGB1_CCIR(s1[0], s1[2]);
+
+            YUV_TO_RGB2_CCIR(r, g, b, s1[1]);
+            RGB_OUT(d1, r, g, b);
+        }
+
+        d += dst->linesize[0];
+        s += src->linesize[0];
+    }
+}
+
+static void glue (yuv422_to_, RGB_NAME)(AVPicture *dst, const AVPicture *src,
+                                        int width, int height)
+{
+    uint8_t *s, *d, *d1, *s1;
+    int w, y, cb, cr, r_add, g_add, b_add;
+    uint8_t *cm = cropTbl + MAX_NEG_CROP;
+    unsigned int r, g, b;
+
+    d = dst->data[0];
+    s = src->data[0];
+    for(;height > 0; height --) {
+        d1 = d;
+        s1 = s;
+        for(w = width; w >= 2; w -= 2) {
+            YUV_TO_RGB1_CCIR(s1[1], s1[3]);
+
+            YUV_TO_RGB2_CCIR(r, g, b, s1[0]);
+            RGB_OUT(d1, r, g, b);
+            d1 += BPP;
+
+            YUV_TO_RGB2_CCIR(r, g, b, s1[2]);
+            RGB_OUT(d1, r, g, b);
+            d1 += BPP;
+
+            s1 += 4;
+        }
+
+        if (w) {
+            YUV_TO_RGB1_CCIR(s1[1], s1[3]);
+
+            YUV_TO_RGB2_CCIR(r, g, b, s1[0]);
+            RGB_OUT(d1, r, g, b);
+        }
+
+        d += dst->linesize[0];
+        s += src->linesize[0];
+    }
+}
+
+static void glue (yvyu422_to_, RGB_NAME)(AVPicture *dst, const AVPicture *src,
+                                        int width, int height)
+{
+    uint8_t *s, *d, *d1, *s1;
+    int w, y, cb, cr, r_add, g_add, b_add;
+    uint8_t *cm = cropTbl + MAX_NEG_CROP;
+    unsigned int r, g, b;
+
+    d = dst->data[0];
+    s = src->data[0];
+    for(;height > 0; height --) {
+        d1 = d;
+        s1 = s;
+        for(w = width; w >= 2; w -= 2) {
+            YUV_TO_RGB1_CCIR(s1[3], s1[1]);
+
+            YUV_TO_RGB2_CCIR(r, g, b, s1[0]);
+            RGB_OUT(d1, r, g, b);
+            d1 += BPP;
+
+            YUV_TO_RGB2_CCIR(r, g, b, s1[2]);
+            RGB_OUT(d1, r, g, b);
+            d1 += BPP;
+
+            s1 += 4;
+        }
+
+        if (w) {
+            YUV_TO_RGB1_CCIR(s1[3], s1[1]);
+
+            YUV_TO_RGB2_CCIR(r, g, b, s1[0]);
+            RGB_OUT(d1, r, g, b);
+        }
+
+        d += dst->linesize[0];
+        s += src->linesize[0];
+    }
+}
+
+static void glue (yuv420p_to_, RGB_NAME)(AVPicture *dst, const AVPicture *src,
+                                        int width, int height)
+{
+  const uint8_t *y1_ptr, *y2_ptr, *cb_ptr, *cr_ptr;
+  uint8_t *d, *d1, *d2;
+  int w, y, cb, cr, r_add, g_add, b_add, width2;
+  uint8_t *cm = cropTbl + MAX_NEG_CROP;
+  unsigned int r, g, b;
+
+  d = dst->data[0];
+  y1_ptr = src->data[0];
+  cb_ptr = src->data[1];
+  cr_ptr = src->data[2];
+  width2 = (width + 1) >> 1;
+  for (; height >= 2; height -= 2) {
+    d1 = d;
+    d2 = d + dst->linesize[0];
+    y2_ptr = y1_ptr + src->linesize[0];
+    for (w = width; w >= 2; w -= 2) {
+      YUV_TO_RGB1_CCIR (cb_ptr[0], cr_ptr[0]);
+      /* output 4 pixels */
+      YUV_TO_RGB2_CCIR (r, g, b, y1_ptr[0]);
+      RGB_OUT (d1, r, g, b);
+
+      YUV_TO_RGB2_CCIR (r, g, b, y1_ptr[1]);
+      RGB_OUT (d1 + BPP, r, g, b);
+
+      YUV_TO_RGB2_CCIR (r, g, b, y2_ptr[0]);
+      RGB_OUT (d2, r, g, b);
+
+      YUV_TO_RGB2_CCIR (r, g, b, y2_ptr[1]);
+      RGB_OUT (d2 + BPP, r, g, b);
+
+      d1 += 2 * BPP;
+      d2 += 2 * BPP;
+
+      y1_ptr += 2;
+      y2_ptr += 2;
+      cb_ptr++;
+      cr_ptr++;
+    }
+    /* handle odd width */
+    if (w) {
+      YUV_TO_RGB1_CCIR (cb_ptr[0], cr_ptr[0]);
+      YUV_TO_RGB2_CCIR (r, g, b, y1_ptr[0]);
+      RGB_OUT (d1, r, g, b);
+
+      YUV_TO_RGB2_CCIR (r, g, b, y2_ptr[0]);
+      RGB_OUT (d2, r, g, b);
+      d1 += BPP;
+      d2 += BPP;
+      y1_ptr++;
+      y2_ptr++;
+      cb_ptr++;
+      cr_ptr++;
+    }
+    d += 2 * dst->linesize[0];
+    y1_ptr += 2 * src->linesize[0] - width;
+    cb_ptr += src->linesize[1] - width2;
+    cr_ptr += src->linesize[2] - width2;
+  }
+  /* handle odd height */
+  if (height) {
+    d1 = d;
+    for (w = width; w >= 2; w -= 2) {
+      YUV_TO_RGB1_CCIR (cb_ptr[0], cr_ptr[0]);
+      /* output 2 pixels */
+      YUV_TO_RGB2_CCIR (r, g, b, y1_ptr[0]);
+      RGB_OUT (d1, r, g, b);
+
+      YUV_TO_RGB2_CCIR (r, g, b, y1_ptr[1]);
+      RGB_OUT (d1 + BPP, r, g, b);
+
+      d1 += 2 * BPP;
+
+      y1_ptr += 2;
+      cb_ptr++;
+      cr_ptr++;
+    }
+    /* handle width */
+    if (w) {
+      YUV_TO_RGB1_CCIR (cb_ptr[0], cr_ptr[0]);
+      /* output 2 pixel */
+      YUV_TO_RGB2_CCIR (r, g, b, y1_ptr[0]);
+      RGB_OUT (d1, r, g, b);
+      d1 += BPP;
+
+      y1_ptr++;
+      cb_ptr++;
+      cr_ptr++;
+    }
+  }
+}
+
+#ifndef RGBA_OUT
+#define RGBA_OUT_(d, r, g, b, a) RGB_OUT(d, r, g, b)
+#define YUVA_TO_A(d, a)
+#else
+#define RGBA_OUT_(d, r, g, b, a) RGBA_OUT(d, r, g, b, a)
+#define YUVA_TO_A(d, a) do { d = a; } while (0);
+#endif
+
+static void glue (yuva420p_to_, RGB_NAME)(AVPicture *dst, const AVPicture *src,
+                                        int width, int height)
+{
+  const uint8_t *y1_ptr, *y2_ptr, *cb_ptr, *cr_ptr, *a1_ptr, *a2_ptr;
+  uint8_t *d, *d1, *d2;
+  int w, y, cb, cr, r_add, g_add, b_add, width2;
+  uint8_t *cm = cropTbl + MAX_NEG_CROP;
+  unsigned int r, g, b;
+#ifdef RGBA_OUT
+  unsigned int a = 0;
+#endif
+
+  d = dst->data[0];
+  y1_ptr = src->data[0];
+  cb_ptr = src->data[1];
+  cr_ptr = src->data[2];
+  a1_ptr = src->data[3];
+  width2 = (width + 1) >> 1;
+  for (; height >= 2; height -= 2) {
+    d1 = d;
+    d2 = d + dst->linesize[0];
+    y2_ptr = y1_ptr + src->linesize[0];
+    a2_ptr = a1_ptr + src->linesize[3];
+    for (w = width; w >= 2; w -= 2) {
+      YUVA_TO_A (a, a1_ptr[0]);
+      YUV_TO_RGB1_CCIR (cb_ptr[0], cr_ptr[0]);
+      /* output 4 pixels */
+      YUV_TO_RGB2_CCIR (r, g, b, y1_ptr[0]);
+      RGBA_OUT_ (d1, r, g, b, a);
+
+      YUVA_TO_A (a, a1_ptr[1]);
+      YUV_TO_RGB2_CCIR (r, g, b, y1_ptr[1]);
+      RGBA_OUT_ (d1 + BPP, r, g, b, a);
+
+      YUVA_TO_A (a, a2_ptr[0]);
+      YUV_TO_RGB2_CCIR (r, g, b, y2_ptr[0]);
+      RGBA_OUT_ (d2, r, g, b, a);
+
+      YUVA_TO_A (a, a2_ptr[1]);
+      YUV_TO_RGB2_CCIR (r, g, b, y2_ptr[1]);
+      RGBA_OUT_ (d2 + BPP, r, g, b, a);
+
+      d1 += 2 * BPP;
+      d2 += 2 * BPP;
+
+      y1_ptr += 2;
+      y2_ptr += 2;
+      cb_ptr++;
+      cr_ptr++;
+      a1_ptr += 2;
+      a2_ptr += 2;
+    }
+    /* handle odd width */
+    if (w) {
+      YUVA_TO_A (a, a1_ptr[0]);
+      YUV_TO_RGB1_CCIR (cb_ptr[0], cr_ptr[0]);
+      YUV_TO_RGB2_CCIR (r, g, b, y1_ptr[0]);
+      RGBA_OUT_ (d1, r, g, b, a);
+
+      YUVA_TO_A (a, a2_ptr[0]);
+      YUV_TO_RGB2_CCIR (r, g, b, y2_ptr[0]);
+      RGBA_OUT_ (d2, r, g, b, a);
+      d1 += BPP;
+      d2 += BPP;
+      y1_ptr++;
+      y2_ptr++;
+      cb_ptr++;
+      cr_ptr++;
+      a1_ptr++;
+      a2_ptr++;
+    }
+    d += 2 * dst->linesize[0];
+    y1_ptr += 2 * src->linesize[0] - width;
+    cb_ptr += src->linesize[1] - width2;
+    cr_ptr += src->linesize[2] - width2;
+    a1_ptr += 2 * src->linesize[3] - width;
+  }
+  /* handle odd height */
+  if (height) {
+    d1 = d;
+    for (w = width; w >= 2; w -= 2) {
+      YUVA_TO_A (a, a1_ptr[0]);
+      YUV_TO_RGB1_CCIR (cb_ptr[0], cr_ptr[0]);
+      /* output 2 pixels */
+      YUV_TO_RGB2_CCIR (r, g, b, y1_ptr[0]);
+      RGBA_OUT_ (d1, r, g, b, a);
+
+      YUVA_TO_A (a, a1_ptr[1]);
+      YUV_TO_RGB2_CCIR (r, g, b, y1_ptr[1]);
+      RGBA_OUT_ (d1 + BPP, r, g, b, a);
+
+      d1 += 2 * BPP;
+
+      y1_ptr += 2;
+      cb_ptr++;
+      cr_ptr++;
+      a1_ptr += 2;
+    }
+    /* handle width */
+    if (w) {
+      YUVA_TO_A (a, a1_ptr[0]);
+      YUV_TO_RGB1_CCIR (cb_ptr[0], cr_ptr[0]);
+      /* output 2 pixel */
+      YUV_TO_RGB2_CCIR (r, g, b, y1_ptr[0]);
+      RGBA_OUT_ (d1, r, g, b, a);
+      d1 += BPP;
+
+      y1_ptr++;
+      cb_ptr++;
+      cr_ptr++;
+      a1_ptr++;
+    }
+  }
+}
+
+static void glue (nv12_to_, RGB_NAME) (AVPicture * dst, const AVPicture * src,
+    int width, int height)
+{
+  const uint8_t *y1_ptr, *y2_ptr, *c_ptr;
+  uint8_t *d, *d1, *d2;
+  int w, y, cb, cr, r_add, g_add, b_add;
+  uint8_t *cm = cropTbl + MAX_NEG_CROP;
+  unsigned int r, g, b;
+  int c_wrap = src->linesize[1] - ((width + 1) & ~0x01);
+
+  d = dst->data[0];
+  y1_ptr = src->data[0];
+  c_ptr = src->data[1];
+  for (; height >= 2; height -= 2) {
+    d1 = d;
+    d2 = d + dst->linesize[0];
+    y2_ptr = y1_ptr + src->linesize[0];
+    for (w = width; w >= 2; w -= 2) {
+      YUV_TO_RGB1_CCIR (c_ptr[0], c_ptr[1]);
+      /* output 4 pixels */
+      YUV_TO_RGB2_CCIR (r, g, b, y1_ptr[0]);
+      RGB_OUT (d1, r, g, b);
+
+      YUV_TO_RGB2_CCIR (r, g, b, y1_ptr[1]);
+      RGB_OUT (d1 + BPP, r, g, b);
+
+      YUV_TO_RGB2_CCIR (r, g, b, y2_ptr[0]);
+      RGB_OUT (d2, r, g, b);
+
+      YUV_TO_RGB2_CCIR (r, g, b, y2_ptr[1]);
+      RGB_OUT (d2 + BPP, r, g, b);
+
+      d1 += 2 * BPP;
+      d2 += 2 * BPP;
+
+      y1_ptr += 2;
+      y2_ptr += 2;
+      c_ptr += 2;
+    }
+    /* handle odd width */
+    if (w) {
+      YUV_TO_RGB1_CCIR (c_ptr[0], c_ptr[1]);
+      YUV_TO_RGB2_CCIR (r, g, b, y1_ptr[0]);
+      RGB_OUT (d1, r, g, b);
+
+      YUV_TO_RGB2_CCIR (r, g, b, y2_ptr[0]);
+      RGB_OUT (d2, r, g, b);
+      d1 += BPP;
+      d2 += BPP;
+      y1_ptr++;
+      y2_ptr++;
+      c_ptr += 2;
+    }
+    d += 2 * dst->linesize[0];
+    y1_ptr += 2 * src->linesize[0] - width;
+    c_ptr += c_wrap;
+  }
+  /* handle odd height */
+  if (height) {
+    d1 = d;
+    for (w = width; w >= 2; w -= 2) {
+      YUV_TO_RGB1_CCIR (c_ptr[0], c_ptr[1]);
+      /* output 2 pixels */
+      YUV_TO_RGB2_CCIR (r, g, b, y1_ptr[0]);
+      RGB_OUT (d1, r, g, b);
+
+      YUV_TO_RGB2_CCIR (r, g, b, y1_ptr[1]);
+      RGB_OUT (d1 + BPP, r, g, b);
+
+      d1 += 2 * BPP;
+
+      y1_ptr += 2;
+      c_ptr += 2;
+    }
+    /* handle odd width */
+    if (w) {
+      YUV_TO_RGB1_CCIR (c_ptr[0], c_ptr[1]);
+      /* output 1 pixel */
+      YUV_TO_RGB2_CCIR (r, g, b, y1_ptr[0]);
+      RGB_OUT (d1, r, g, b);
+      d1 += BPP;
+
+      y1_ptr++;
+      c_ptr += 2;
+    }
+  }
+}
+
+static void glue (nv21_to_, RGB_NAME) (AVPicture * dst, const AVPicture * src,
+    int width, int height)
+{
+  const uint8_t *y1_ptr, *y2_ptr, *c_ptr;
+  uint8_t *d, *d1, *d2;
+  int w, y, cb, cr, r_add, g_add, b_add;
+  uint8_t *cm = cropTbl + MAX_NEG_CROP;
+  unsigned int r, g, b;
+  int c_wrap = src->linesize[1] - ((width + 1) & ~0x01);
+
+  d = dst->data[0];
+  y1_ptr = src->data[0];
+  c_ptr = src->data[1];
+  for (; height >= 2; height -= 2) {
+    d1 = d;
+    d2 = d + dst->linesize[0];
+    y2_ptr = y1_ptr + src->linesize[0];
+    for (w = width; w >= 2; w -= 2) {
+      YUV_TO_RGB1_CCIR (c_ptr[1], c_ptr[0]);
+      /* output 4 pixels */
+      YUV_TO_RGB2_CCIR (r, g, b, y1_ptr[0]);
+      RGB_OUT (d1, r, g, b);
+
+      YUV_TO_RGB2_CCIR (r, g, b, y1_ptr[1]);
+      RGB_OUT (d1 + BPP, r, g, b);
+
+      YUV_TO_RGB2_CCIR (r, g, b, y2_ptr[0]);
+      RGB_OUT (d2, r, g, b);
+
+      YUV_TO_RGB2_CCIR (r, g, b, y2_ptr[1]);
+      RGB_OUT (d2 + BPP, r, g, b);
+
+      d1 += 2 * BPP;
+      d2 += 2 * BPP;
+
+      y1_ptr += 2;
+      y2_ptr += 2;
+      c_ptr += 2;
+    }
+    /* handle odd width */
+    if (w) {
+      YUV_TO_RGB1_CCIR (c_ptr[1], c_ptr[0]);
+      YUV_TO_RGB2_CCIR (r, g, b, y1_ptr[0]);
+      RGB_OUT (d1, r, g, b);
+
+      YUV_TO_RGB2_CCIR (r, g, b, y2_ptr[0]);
+      RGB_OUT (d2, r, g, b);
+      d1 += BPP;
+      d2 += BPP;
+      y1_ptr++;
+      y2_ptr++;
+      c_ptr += 2;
+    }
+    d += 2 * dst->linesize[0];
+    y1_ptr += 2 * src->linesize[0] - width;
+    c_ptr += c_wrap;
+  }
+  /* handle odd height */
+  if (height) {
+    d1 = d;
+    for (w = width; w >= 2; w -= 2) {
+      YUV_TO_RGB1_CCIR (c_ptr[1], c_ptr[0]);
+      /* output 2 pixels */
+      YUV_TO_RGB2_CCIR (r, g, b, y1_ptr[0]);
+      RGB_OUT (d1, r, g, b);
+
+      YUV_TO_RGB2_CCIR (r, g, b, y1_ptr[1]);
+      RGB_OUT (d1 + BPP, r, g, b);
+
+      d1 += 2 * BPP;
+
+      y1_ptr += 2;
+      c_ptr += 2;
+    }
+    /* handle odd width */
+    if (w) {
+      YUV_TO_RGB1_CCIR (c_ptr[1], c_ptr[0]);
+      /* output 1 pixel */
+      YUV_TO_RGB2_CCIR (r, g, b, y1_ptr[0]);
+      RGB_OUT (d1, r, g, b);
+      d1 += BPP;
+
+      y1_ptr++;
+      c_ptr += 2;
+    }
+  }
+}
+
+static void glue (yuvj420p_to_, RGB_NAME) (AVPicture * dst,
+    const AVPicture * src, int width, int height)
+{
+  const uint8_t *y1_ptr, *y2_ptr, *cb_ptr, *cr_ptr;
+  uint8_t *d, *d1, *d2;
+  int w, y, cb, cr, r_add, g_add, b_add, width2;
+  uint8_t *cm = cropTbl + MAX_NEG_CROP;
+  unsigned int r, g, b;
+
+  d = dst->data[0];
+  y1_ptr = src->data[0];
+  cb_ptr = src->data[1];
+  cr_ptr = src->data[2];
+  width2 = (width + 1) >> 1;
+  for (; height >= 2; height -= 2) {
+    d1 = d;
+    d2 = d + dst->linesize[0];
+    y2_ptr = y1_ptr + src->linesize[0];
+    for (w = width; w >= 2; w -= 2) {
+      YUV_TO_RGB1 (cb_ptr[0], cr_ptr[0]);
+      /* output 4 pixels */
+      YUV_TO_RGB2 (r, g, b, y1_ptr[0]);
+      RGB_OUT (d1, r, g, b);
+
+      YUV_TO_RGB2 (r, g, b, y1_ptr[1]);
+      RGB_OUT (d1 + BPP, r, g, b);
+
+      YUV_TO_RGB2 (r, g, b, y2_ptr[0]);
+      RGB_OUT (d2, r, g, b);
+
+      YUV_TO_RGB2 (r, g, b, y2_ptr[1]);
+      RGB_OUT (d2 + BPP, r, g, b);
+
+      d1 += 2 * BPP;
+      d2 += 2 * BPP;
+
+      y1_ptr += 2;
+      y2_ptr += 2;
+      cb_ptr++;
+      cr_ptr++;
+    }
+    /* handle odd width */
+    if (w) {
+      YUV_TO_RGB1 (cb_ptr[0], cr_ptr[0]);
+      YUV_TO_RGB2 (r, g, b, y1_ptr[0]);
+      RGB_OUT (d1, r, g, b);
+
+      YUV_TO_RGB2 (r, g, b, y2_ptr[0]);
+      RGB_OUT (d2, r, g, b);
+      d1 += BPP;
+      d2 += BPP;
+      y1_ptr++;
+      y2_ptr++;
+      cb_ptr++;
+      cr_ptr++;
+    }
+    d += 2 * dst->linesize[0];
+    y1_ptr += 2 * src->linesize[0] - width;
+    cb_ptr += src->linesize[1] - width2;
+    cr_ptr += src->linesize[2] - width2;
+  }
+  /* handle odd height */
+  if (height) {
+    d1 = d;
+    for (w = width; w >= 2; w -= 2) {
+      YUV_TO_RGB1 (cb_ptr[0], cr_ptr[0]);
+      /* output 2 pixels */
+      YUV_TO_RGB2 (r, g, b, y1_ptr[0]);
+      RGB_OUT (d1, r, g, b);
+
+      YUV_TO_RGB2 (r, g, b, y1_ptr[1]);
+      RGB_OUT (d1 + BPP, r, g, b);
+
+      d1 += 2 * BPP;
+
+      y1_ptr += 2;
+      cb_ptr++;
+      cr_ptr++;
+    }
+    /* handle width */
+    if (w) {
+      YUV_TO_RGB1 (cb_ptr[0], cr_ptr[0]);
+      /* output 2 pixels */
+      YUV_TO_RGB2 (r, g, b, y1_ptr[0]);
+      RGB_OUT (d1, r, g, b);
+      d1 += BPP;
+
+      y1_ptr++;
+      cb_ptr++;
+      cr_ptr++;
+    }
+  }
+}
+
+static void glue (y800_to_, RGB_NAME) (AVPicture * dst, const AVPicture * src,
+    int width, int height)
+{
+  const unsigned char *p;
+  unsigned char *q;
+  uint8_t *cm = cropTbl + MAX_NEG_CROP;
+  int r, dst_wrap, src_wrap;
+  int x, y;
+
+  p = src->data[0];
+  src_wrap = src->linesize[0] - width;
+
+  q = dst->data[0];
+  dst_wrap = dst->linesize[0] - BPP * width;
+
+  for (y = 0; y < height; y++) {
+    for (x = 0; x < width; x++) {
+      r = Y_CCIR_TO_JPEG (p[0]);
+      RGB_OUT (q, r, r, r);
+      q += BPP;
+      p++;
+    }
+    p += src_wrap;
+    q += dst_wrap;
+  }
+}
+
+static void glue (y16_to_, RGB_NAME) (AVPicture * dst,
+    const AVPicture * src, int width, int height)
+{
+  const unsigned char *p;
+  unsigned char *q;
+  uint8_t *cm = cropTbl + MAX_NEG_CROP;
+  int r, dst_wrap, src_wrap;
+  int x, y;
+
+  p = src->data[0];
+  src_wrap = src->linesize[0] - 2 * width;
+
+  q = dst->data[0];
+  dst_wrap = dst->linesize[0] - BPP * width;
+
+  for (y = 0; y < height; y++) {
+    for (x = 0; x < width; x++) {
+      r = Y_CCIR_TO_JPEG (GST_READ_UINT16_LE (p) >> 8);
+      RGB_OUT (q, r, r, r);
+      q += BPP;
+      p += 2;
+    }
+    p += src_wrap;
+    q += dst_wrap;
+  }
+}
+
+static void glue (RGB_NAME, _to_yuv420p) (AVPicture * dst,
+    const AVPicture * src, int width, int height)
+{
+  int wrap, wrap3, width2;
+  int r, g, b, r1, g1, b1, w;
+  uint8_t *lum, *cb, *cr;
+  const uint8_t *p;
+
+  lum = dst->data[0];
+  cb = dst->data[1];
+  cr = dst->data[2];
+
+  width2 = (width + 1) >> 1;
+  wrap = dst->linesize[0];
+  wrap3 = src->linesize[0];
+  p = src->data[0];
+  for (; height >= 2; height -= 2) {
+    for (w = width; w >= 2; w -= 2) {
+      RGB_IN (r, g, b, p);
+      r1 = r;
+      g1 = g;
+      b1 = b;
+      lum[0] = RGB_TO_Y_CCIR (r, g, b);
+
+      RGB_IN (r, g, b, p + BPP);
+      r1 += r;
+      g1 += g;
+      b1 += b;
+      lum[1] = RGB_TO_Y_CCIR (r, g, b);
+      p += wrap3;
+      lum += wrap;
+
+      RGB_IN (r, g, b, p);
+      r1 += r;
+      g1 += g;
+      b1 += b;
+      lum[0] = RGB_TO_Y_CCIR (r, g, b);
+
+      RGB_IN (r, g, b, p + BPP);
+      r1 += r;
+      g1 += g;
+      b1 += b;
+      lum[1] = RGB_TO_Y_CCIR (r, g, b);
+
+      cb[0] = RGB_TO_U_CCIR (r1, g1, b1, 2);
+      cr[0] = RGB_TO_V_CCIR (r1, g1, b1, 2);
+
+
+      cb++;
+      cr++;
+      p += -wrap3 + 2 * BPP;
+      lum += -wrap + 2;
+    }
+    if (w) {
+      RGB_IN (r, g, b, p);
+      r1 = r;
+      g1 = g;
+      b1 = b;
+      lum[0] = RGB_TO_Y_CCIR (r, g, b);
+      p += wrap3;
+      lum += wrap;
+      RGB_IN (r, g, b, p);
+      r1 += r;
+      g1 += g;
+      b1 += b;
+      lum[0] = RGB_TO_Y_CCIR (r, g, b);
+      cb[0] = RGB_TO_U_CCIR (r1, g1, b1, 1);
+      cr[0] = RGB_TO_V_CCIR (r1, g1, b1, 1);
+      cb++;
+      cr++;
+      p += -wrap3 + BPP;
+      lum += -wrap + 1;
+    }
+    p += wrap3 + (wrap3 - width * BPP);
+    lum += wrap + (wrap - width);
+    cb += dst->linesize[1] - width2;
+    cr += dst->linesize[2] - width2;
+  }
+  /* handle odd height */
+  if (height) {
+    for (w = width; w >= 2; w -= 2) {
+      RGB_IN (r, g, b, p);
+      r1 = r;
+      g1 = g;
+      b1 = b;
+      lum[0] = RGB_TO_Y_CCIR (r, g, b);
+
+      RGB_IN (r, g, b, p + BPP);
+      r1 += r;
+      g1 += g;
+      b1 += b;
+      lum[1] = RGB_TO_Y_CCIR (r, g, b);
+      cb[0] = RGB_TO_U_CCIR (r1, g1, b1, 1);
+      cr[0] = RGB_TO_V_CCIR (r1, g1, b1, 1);
+      cb++;
+      cr++;
+      p += 2 * BPP;
+      lum += 2;
+    }
+    if (w) {
+      RGB_IN (r, g, b, p);
+      lum[0] = RGB_TO_Y_CCIR (r, g, b);
+      cb[0] = RGB_TO_U_CCIR (r, g, b, 0);
+      cr[0] = RGB_TO_V_CCIR (r, g, b, 0);
+    }
+  }
+}
+
+#ifndef RGBA_IN
+#define RGBA_IN_(r, g, b, a, p) RGB_IN(r, g, b, p)
+#else
+#define RGBA_IN_(r, g, b, a, p) RGBA_IN(r, g, b, a, p)
+#endif
+
+static void glue (RGB_NAME, _to_yuva420p) (AVPicture * dst,
+    const AVPicture * src, int width, int height)
+{
+  int wrap, wrap3, width2;
+  int r, g, b, r1, g1, b1, w, ra = 255;
+  uint8_t *lum, *cb, *cr, *a;
+  const uint8_t *p;
+
+  lum = dst->data[0];
+  cb = dst->data[1];
+  cr = dst->data[2];
+  a = dst->data[3];
+
+  width2 = (width + 1) >> 1;
+  wrap = dst->linesize[0];
+  wrap3 = src->linesize[0];
+  p = src->data[0];
+  for (; height >= 2; height -= 2) {
+    for (w = width; w >= 2; w -= 2) {
+      RGBA_IN_ (r, g, b, ra, p);
+      r1 = r;
+      g1 = g;
+      b1 = b;
+      lum[0] = RGB_TO_Y_CCIR (r, g, b);
+      a[0] = ra;
+
+      RGBA_IN_ (r, g, b, ra, p + BPP);
+      r1 += r;
+      g1 += g;
+      b1 += b;
+      lum[1] = RGB_TO_Y_CCIR (r, g, b);
+      a[1] = ra;
+      p += wrap3;
+      lum += wrap;
+      a += wrap;
+
+      RGBA_IN_ (r, g, b, ra, p);
+      r1 += r;
+      g1 += g;
+      b1 += b;
+      lum[0] = RGB_TO_Y_CCIR (r, g, b);
+      a[0] = ra;
+
+      RGBA_IN_ (r, g, b, ra, p + BPP);
+      r1 += r;
+      g1 += g;
+      b1 += b;
+      lum[1] = RGB_TO_Y_CCIR (r, g, b);
+      a[1] = ra;
+
+      cb[0] = RGB_TO_U_CCIR (r1, g1, b1, 2);
+      cr[0] = RGB_TO_V_CCIR (r1, g1, b1, 2);
+
+      cb++;
+      cr++;
+      p += -wrap3 + 2 * BPP;
+      lum += -wrap + 2;
+      a += -wrap + 2;
+    }
+    if (w) {
+      RGBA_IN_ (r, g, b, ra, p);
+      r1 = r;
+      g1 = g;
+      b1 = b;
+      lum[0] = RGB_TO_Y_CCIR (r, g, b);
+      a[0] = ra;
+      p += wrap3;
+      lum += wrap;
+      a += wrap;
+      RGBA_IN_ (r, g, b, ra, p);
+      r1 += r;
+      g1 += g;
+      b1 += b;
+      lum[0] = RGB_TO_Y_CCIR (r, g, b);
+      a[0] = ra;
+      cb[0] = RGB_TO_U_CCIR (r1, g1, b1, 1);
+      cr[0] = RGB_TO_V_CCIR (r1, g1, b1, 1);
+      cb++;
+      cr++;
+      p += -wrap3 + BPP;
+      lum += -wrap + 1;
+      a += -wrap + 1;
+    }
+    p += wrap3 + (wrap3 - width * BPP);
+    lum += wrap + (wrap - width);
+    a += wrap + (wrap - width);
+    cb += dst->linesize[1] - width2;
+    cr += dst->linesize[2] - width2;
+  }
+  /* handle odd height */
+  if (height) {
+    for (w = width; w >= 2; w -= 2) {
+      RGBA_IN_ (r, g, b, ra, p);
+      r1 = r;
+      g1 = g;
+      b1 = b;
+      lum[0] = RGB_TO_Y_CCIR (r, g, b);
+      a[0] = ra;
+
+      RGBA_IN_ (r, g, b, ra, p + BPP);
+      r1 += r;
+      g1 += g;
+      b1 += b;
+      lum[1] = RGB_TO_Y_CCIR (r, g, b);
+      a[1] = ra;
+      cb[0] = RGB_TO_U_CCIR (r1, g1, b1, 1);
+      cr[0] = RGB_TO_V_CCIR (r1, g1, b1, 1);
+      cb++;
+      cr++;
+      p += 2 * BPP;
+      lum += 2;
+      a += 2;
+    }
+    if (w) {
+      RGBA_IN_ (r, g, b, ra, p);
+      lum[0] = RGB_TO_Y_CCIR (r, g, b);
+      a[0] = ra;
+      cb[0] = RGB_TO_U_CCIR (r, g, b, 0);
+      cr[0] = RGB_TO_V_CCIR (r, g, b, 0);
+    }
+  }
+}
+
+static void glue (RGB_NAME, _to_nv12) (AVPicture * dst, const AVPicture * src,
+    int width, int height)
+{
+  int wrap, wrap3;
+  int r, g, b, r1, g1, b1, w;
+  uint8_t *lum, *c;
+  const uint8_t *p;
+
+  lum = dst->data[0];
+  c = dst->data[1];
+
+  wrap = dst->linesize[0];
+  wrap3 = src->linesize[0];
+  p = src->data[0];
+  for (; height >= 2; height -= 2) {
+    for (w = width; w >= 2; w -= 2) {
+      RGB_IN (r, g, b, p);
+      r1 = r;
+      g1 = g;
+      b1 = b;
+      lum[0] = RGB_TO_Y_CCIR (r, g, b);
+
+      RGB_IN (r, g, b, p + BPP);
+      r1 += r;
+      g1 += g;
+      b1 += b;
+      lum[1] = RGB_TO_Y_CCIR (r, g, b);
+      p += wrap3;
+      lum += wrap;
+
+      RGB_IN (r, g, b, p);
+      r1 += r;
+      g1 += g;
+      b1 += b;
+      lum[0] = RGB_TO_Y_CCIR (r, g, b);
+
+      RGB_IN (r, g, b, p + BPP);
+      r1 += r;
+      g1 += g;
+      b1 += b;
+      lum[1] = RGB_TO_Y_CCIR (r, g, b);
+
+      c[0] = RGB_TO_U_CCIR (r1, g1, b1, 2);
+      c[1] = RGB_TO_V_CCIR (r1, g1, b1, 2);
+
+
+      c += 2;
+      p += -wrap3 + 2 * BPP;
+      lum += -wrap + 2;
+    }
+    /* handle odd width */
+    if (w) {
+      RGB_IN (r, g, b, p);
+      r1 = r;
+      g1 = g;
+      b1 = b;
+      lum[0] = RGB_TO_Y_CCIR (r, g, b);
+      p += wrap3;
+      lum += wrap;
+      RGB_IN (r, g, b, p);
+      r1 += r;
+      g1 += g;
+      b1 += b;
+      lum[0] = RGB_TO_Y_CCIR (r, g, b);
+      c[0] = RGB_TO_U_CCIR (r1, g1, b1, 1);
+      c[1] = RGB_TO_V_CCIR (r1, g1, b1, 1);
+      p += -wrap3 + BPP;
+      lum += -wrap + 1;
+    }
+    p += wrap3 + (wrap3 - width * BPP);
+    lum += wrap + (wrap - width);
+    c += dst->linesize[1] - (width & ~1);
+  }
+  /* handle odd height */
+  if (height) {
+    for (w = width; w >= 2; w -= 2) {
+      RGB_IN (r, g, b, p);
+      r1 = r;
+      g1 = g;
+      b1 = b;
+      lum[0] = RGB_TO_Y_CCIR (r, g, b);
+
+      RGB_IN (r, g, b, p + BPP);
+      r1 += r;
+      g1 += g;
+      b1 += b;
+      lum[1] = RGB_TO_Y_CCIR (r, g, b);
+      c[0] = RGB_TO_U_CCIR (r1, g1, b1, 1);
+      c[1] = RGB_TO_V_CCIR (r1, g1, b1, 1);
+      c += 2;
+      p += 2 * BPP;
+      lum += 2;
+    }
+    /* handle odd width */
+    if (w) {
+      RGB_IN (r, g, b, p);
+      lum[0] = RGB_TO_Y_CCIR (r, g, b);
+      c[0] = RGB_TO_U_CCIR (r, g, b, 0);
+      c[1] = RGB_TO_V_CCIR (r, g, b, 0);
+    }
+  }
+}
+
+static void glue (RGB_NAME, _to_nv21) (AVPicture * dst, const AVPicture * src,
+    int width, int height)
+{
+  int wrap, wrap3;
+  int r, g, b, r1, g1, b1, w;
+  uint8_t *lum, *c;
+  const uint8_t *p;
+
+  lum = dst->data[0];
+  c = dst->data[1];
+
+  wrap = dst->linesize[0];
+  wrap3 = src->linesize[0];
+  p = src->data[0];
+  for (; height >= 2; height -= 2) {
+    for (w = width; w >= 2; w -= 2) {
+      RGB_IN (r, g, b, p);
+      r1 = r;
+      g1 = g;
+      b1 = b;
+      lum[0] = RGB_TO_Y_CCIR (r, g, b);
+
+      RGB_IN (r, g, b, p + BPP);
+      r1 += r;
+      g1 += g;
+      b1 += b;
+      lum[1] = RGB_TO_Y_CCIR (r, g, b);
+      p += wrap3;
+      lum += wrap;
+
+      RGB_IN (r, g, b, p);
+      r1 += r;
+      g1 += g;
+      b1 += b;
+      lum[0] = RGB_TO_Y_CCIR (r, g, b);
+
+      RGB_IN (r, g, b, p + BPP);
+      r1 += r;
+      g1 += g;
+      b1 += b;
+      lum[1] = RGB_TO_Y_CCIR (r, g, b);
+
+      c[1] = RGB_TO_U_CCIR (r1, g1, b1, 2);
+      c[0] = RGB_TO_V_CCIR (r1, g1, b1, 2);
+
+
+      c += 2;
+      p += -wrap3 + 2 * BPP;
+      lum += -wrap + 2;
+    }
+    /* handle odd width */
+    if (w) {
+      RGB_IN (r, g, b, p);
+      r1 = r;
+      g1 = g;
+      b1 = b;
+      lum[0] = RGB_TO_Y_CCIR (r, g, b);
+      p += wrap3;
+      lum += wrap;
+      RGB_IN (r, g, b, p);
+      r1 += r;
+      g1 += g;
+      b1 += b;
+      lum[0] = RGB_TO_Y_CCIR (r, g, b);
+      c[1] = RGB_TO_U_CCIR (r1, g1, b1, 1);
+      c[0] = RGB_TO_V_CCIR (r1, g1, b1, 1);
+      p += -wrap3 + BPP;
+      lum += -wrap + 1;
+    }
+    p += wrap3 + (wrap3 - width * BPP);
+    lum += wrap + (wrap - width);
+    c += dst->linesize[1] - (width & ~1);
+  }
+  /* handle odd height */
+  if (height) {
+    for (w = width; w >= 2; w -= 2) {
+      RGB_IN (r, g, b, p);
+      r1 = r;
+      g1 = g;
+      b1 = b;
+      lum[0] = RGB_TO_Y_CCIR (r, g, b);
+
+      RGB_IN (r, g, b, p + BPP);
+      r1 += r;
+      g1 += g;
+      b1 += b;
+      lum[1] = RGB_TO_Y_CCIR (r, g, b);
+      c[1] = RGB_TO_U_CCIR (r1, g1, b1, 1);
+      c[0] = RGB_TO_V_CCIR (r1, g1, b1, 1);
+      c += 2;
+      p += 2 * BPP;
+      lum += 2;
+    }
+    /* handle odd width */
+    if (w) {
+      RGB_IN (r, g, b, p);
+      lum[0] = RGB_TO_Y_CCIR (r, g, b);
+      c[1] = RGB_TO_U_CCIR (r, g, b, 0);
+      c[0] = RGB_TO_V_CCIR (r, g, b, 0);
+    }
+  }
+}
+
+static void glue (RGB_NAME, _to_gray) (AVPicture * dst, const AVPicture * src,
+    int width, int height)
+{
+  const unsigned char *p;
+  unsigned char *q;
+  int r, g, b, dst_wrap, src_wrap;
+  int x, y;
+
+  p = src->data[0];
+  src_wrap = src->linesize[0] - BPP * width;
+
+  q = dst->data[0];
+  dst_wrap = dst->linesize[0] - width;
+
+  for (y = 0; y < height; y++) {
+    for (x = 0; x < width; x++) {
+      RGB_IN (r, g, b, p);
+      q[0] = RGB_TO_Y (r, g, b);
+      q++;
+      p += BPP;
+    }
+    p += src_wrap;
+    q += dst_wrap;
+  }
+}
+
+static void glue (RGB_NAME, _to_y800) (AVPicture * dst, const AVPicture * src,
+    int width, int height)
+{
+  const unsigned char *p;
+  unsigned char *q;
+  int r, g, b, dst_wrap, src_wrap;
+  int x, y;
+
+  p = src->data[0];
+  src_wrap = src->linesize[0] - BPP * width;
+
+  q = dst->data[0];
+  dst_wrap = dst->linesize[0] - width;
+
+  for (y = 0; y < height; y++) {
+    for (x = 0; x < width; x++) {
+      RGB_IN (r, g, b, p);
+      q[0] = RGB_TO_Y_CCIR (r, g, b);
+      q++;
+      p += BPP;
+    }
+    p += src_wrap;
+    q += dst_wrap;
+  }
+}
+
+static void glue (RGB_NAME, _to_y16) (AVPicture * dst,
+    const AVPicture * src, int width, int height)
+{
+  const unsigned char *p;
+  unsigned char *q;
+  int r, g, b, dst_wrap, src_wrap;
+  int x, y;
+
+  p = src->data[0];
+  src_wrap = src->linesize[0] - BPP * width;
+
+  q = dst->data[0];
+  dst_wrap = dst->linesize[0] - 2 * width;
+
+  for (y = 0; y < height; y++) {
+    for (x = 0; x < width; x++) {
+      RGB_IN (r, g, b, p);
+      GST_WRITE_UINT16_LE (q, RGB_TO_Y_CCIR (r, g, b) << 8);
+      q += 2;
+      p += BPP;
+    }
+    p += src_wrap;
+    q += dst_wrap;
+  }
+}
+
+static void glue (gray_to_, RGB_NAME) (AVPicture * dst, const AVPicture * src,
+    int width, int height)
+{
+  const unsigned char *p;
+  unsigned char *q;
+  int r, dst_wrap, src_wrap;
+  int x, y;
+
+  p = src->data[0];
+  src_wrap = src->linesize[0] - width;
+
+  q = dst->data[0];
+  dst_wrap = dst->linesize[0] - BPP * width;
+
+  for (y = 0; y < height; y++) {
+    for (x = 0; x < width; x++) {
+      r = p[0];
+      RGB_OUT (q, r, r, r);
+      q += BPP;
+      p++;
+    }
+    p += src_wrap;
+    q += dst_wrap;
+  }
+}
+
+static void glue (RGB_NAME, _to_gray16_l) (AVPicture * dst,
+    const AVPicture * src, int width, int height)
+{
+  const unsigned char *p;
+  unsigned char *q;
+  int r, g, b, dst_wrap, src_wrap;
+  int x, y;
+
+  p = src->data[0];
+  src_wrap = src->linesize[0] - BPP * width;
+
+  q = dst->data[0];
+  dst_wrap = dst->linesize[0] - 2 * width;
+
+  for (y = 0; y < height; y++) {
+    for (x = 0; x < width; x++) {
+      RGB_IN (r, g, b, p);
+      GST_WRITE_UINT16_LE (q, RGB_TO_Y (r, g, b) << 8);
+      q += 2;
+      p += BPP;
+    }
+    p += src_wrap;
+    q += dst_wrap;
+  }
+}
+
+static void glue (gray16_l_to_, RGB_NAME) (AVPicture * dst,
+    const AVPicture * src, int width, int height)
+{
+  const unsigned char *p;
+  unsigned char *q;
+  int r, dst_wrap, src_wrap;
+  int x, y;
+
+  p = src->data[0];
+  src_wrap = src->linesize[0] - 2 * width;
+
+  q = dst->data[0];
+  dst_wrap = dst->linesize[0] - BPP * width;
+
+  for (y = 0; y < height; y++) {
+    for (x = 0; x < width; x++) {
+      r = GST_READ_UINT16_LE (p) >> 8;
+      RGB_OUT (q, r, r, r);
+      q += BPP;
+      p += 2;
+    }
+    p += src_wrap;
+    q += dst_wrap;
+  }
+}
+
+static void glue (RGB_NAME, _to_gray16_b) (AVPicture * dst,
+    const AVPicture * src, int width, int height)
+{
+  const unsigned char *p;
+  unsigned char *q;
+  int r, g, b, dst_wrap, src_wrap;
+  int x, y;
+
+  p = src->data[0];
+  src_wrap = src->linesize[0] - BPP * width;
+
+  q = dst->data[0];
+  dst_wrap = dst->linesize[0] - 2 * width;
+
+  for (y = 0; y < height; y++) {
+    for (x = 0; x < width; x++) {
+      RGB_IN (r, g, b, p);
+      GST_WRITE_UINT16_BE (q, RGB_TO_Y (r, g, b) << 8);
+      q += 2;
+      p += BPP;
+    }
+    p += src_wrap;
+    q += dst_wrap;
+  }
+}
+
+static void glue (gray16_b_to_, RGB_NAME) (AVPicture * dst,
+    const AVPicture * src, int width, int height)
+{
+  const unsigned char *p;
+  unsigned char *q;
+  int r, dst_wrap, src_wrap;
+  int x, y;
+
+  p = src->data[0];
+  src_wrap = src->linesize[0] - 2 * width;
+
+  q = dst->data[0];
+  dst_wrap = dst->linesize[0] - BPP * width;
+
+  for (y = 0; y < height; y++) {
+    for (x = 0; x < width; x++) {
+      r = GST_READ_UINT16_BE (p) >> 8;
+      RGB_OUT (q, r, r, r);
+      q += BPP;
+      p += 2;
+    }
+    p += src_wrap;
+    q += dst_wrap;
+  }
+}
+
+static void glue (pal8_to_, RGB_NAME) (AVPicture * dst, const AVPicture * src,
+    int width, int height)
+{
+  const unsigned char *p;
+  unsigned char *q;
+  int r, g, b, dst_wrap, src_wrap;
+  int x, y;
+  uint32_t v;
+  const uint32_t *palette;
+
+  p = src->data[0];
+  src_wrap = src->linesize[0] - width;
+  palette = (uint32_t *) src->data[1];
+
+  q = dst->data[0];
+  dst_wrap = dst->linesize[0] - BPP * width;
+
+  for (y = 0; y < height; y++) {
+    for (x = 0; x < width; x++) {
+      v = palette[p[0]];
+      r = (v >> 16) & 0xff;
+      g = (v >> 8) & 0xff;
+      b = (v) & 0xff;
+#ifdef RGBA_OUT
+      {
+        int a;
+        a = (v >> 24) & 0xff;
+        RGBA_OUT (q, r, g, b, a);
+      }
+#else
+      RGB_OUT (q, r, g, b);
+#endif
+      q += BPP;
+      p++;
+    }
+    p += src_wrap;
+    q += dst_wrap;
+  }
+}
+
+#if !defined(FMT_RGBA32) && defined(RGBA_OUT)
+/* alpha support */
+
+static void glue (rgba32_to_, RGB_NAME) (AVPicture * dst, const AVPicture * src,
+    int width, int height)
+{
+  const uint8_t *s;
+  uint8_t *d;
+  int src_wrap, dst_wrap, j, y;
+  unsigned int v, r, g, b, a;
+
+  s = src->data[0];
+  src_wrap = src->linesize[0] - width * 4;
+
+  d = dst->data[0];
+  dst_wrap = dst->linesize[0] - width * BPP;
+
+  for (y = 0; y < height; y++) {
+    for (j = 0; j < width; j++) {
+      v = ((const uint32_t *) (s))[0];
+      a = (v >> 24) & 0xff;
+      r = (v >> 16) & 0xff;
+      g = (v >> 8) & 0xff;
+      b = v & 0xff;
+      RGBA_OUT (d, r, g, b, a);
+      s += 4;
+      d += BPP;
+    }
+    s += src_wrap;
+    d += dst_wrap;
+  }
+}
+
+static void glue (RGB_NAME, _to_rgba32) (AVPicture * dst, const AVPicture * src,
+    int width, int height)
+{
+  const uint8_t *s;
+  uint8_t *d;
+  int src_wrap, dst_wrap, j, y;
+  unsigned int r, g, b, a;
+
+  s = src->data[0];
+  src_wrap = src->linesize[0] - width * BPP;
+
+  d = dst->data[0];
+  dst_wrap = dst->linesize[0] - width * 4;
+
+  for (y = 0; y < height; y++) {
+    for (j = 0; j < width; j++) {
+      RGBA_IN (r, g, b, a, s);
+      ((uint32_t *) (d))[0] = (a << 24) | (r << 16) | (g << 8) | b;
+      d += 4;
+      s += BPP;
+    }
+    s += src_wrap;
+    d += dst_wrap;
+  }
+}
+#endif /* !defined(FMT_RGBA32) && defined(RGBA_OUT) */
+
+#if defined(FMT_RGBA32)
+
+#if !defined(rgba32_fcts_done)
+#define rgba32_fcts_done
+
+static void
+ayuv4444_to_rgba32 (AVPicture * dst, const AVPicture * src,
+    int width, int height)
+{
+  uint8_t *s, *d, *d1, *s1;
+  int w, y, cb, cr, r_add, g_add, b_add;
+  uint8_t *cm = cropTbl + MAX_NEG_CROP;
+  unsigned int r, g, b, a;
+
+  d = dst->data[0];
+  s = src->data[0];
+  for (; height > 0; height--) {
+    d1 = d;
+    s1 = s;
+    for (w = width; w > 0; w--) {
+      a = s1[0];
+      YUV_TO_RGB1_CCIR (s1[2], s1[3]);
+
+      YUV_TO_RGB2_CCIR (r, g, b, s1[1]);
+      RGBA_OUT (d1, r, g, b, a);
+      d1 += BPP;
+      s1 += 4;
+    }
+    d += dst->linesize[0];
+    s += src->linesize[0];
+  }
+}
+
+static void
+rgba32_to_ayuv4444 (AVPicture * dst, const AVPicture * src,
+    int width, int height)
+{
+  int src_wrap, dst_wrap, x, y;
+  int r, g, b, a;
+  uint8_t *d;
+  const uint8_t *p;
+
+  src_wrap = src->linesize[0] - width * BPP;
+  dst_wrap = dst->linesize[0] - width * 4;
+  d = dst->data[0];
+  p = src->data[0];
+  for (y = 0; y < height; y++) {
+    for (x = 0; x < width; x++) {
+      RGBA_IN (r, g, b, a, p);
+      d[0] = a;
+      d[1] = RGB_TO_Y_CCIR (r, g, b);
+      d[2] = RGB_TO_U_CCIR (r, g, b, 0);
+      d[3] = RGB_TO_V_CCIR (r, g, b, 0);
+      p += BPP;
+      d += 4;
+    }
+    p += src_wrap;
+    d += dst_wrap;
+  }
+}
+
+#endif /* !defined(rgba32_fcts_done) */
+
+#endif /* defined(FMT_RGBA32) */
+
+#if defined(FMT_BGRA32)
+#if !defined(bgra32_fcts_done)
+#define bgra32_fcts_done
+
+static void
+bgra32_to_ayuv4444 (AVPicture * dst, const AVPicture * src,
+    int width, int height)
+{
+  int src_wrap, dst_wrap, x, y;
+  int r, g, b, a;
+  uint8_t *d;
+  const uint8_t *p;
+
+  src_wrap = src->linesize[0] - width * BPP;
+  dst_wrap = dst->linesize[0] - width * 4;
+  d = dst->data[0];
+  p = src->data[0];
+  for (y = 0; y < height; y++) {
+    for (x = 0; x < width; x++) {
+      RGBA_IN (r, g, b, a, p);
+      d[0] = a;
+      d[1] = RGB_TO_Y_CCIR (r, g, b);
+      d[2] = RGB_TO_U_CCIR (r, g, b, 0);
+      d[3] = RGB_TO_V_CCIR (r, g, b, 0);
+      p += BPP;
+      d += 4;
+    }
+    p += src_wrap;
+    d += dst_wrap;
+  }
+}
+
+static void
+ayuv4444_to_bgra32 (AVPicture * dst, const AVPicture * src,
+    int width, int height)
+{
+  uint8_t *s, *d, *d1, *s1;
+  int w, y, cb, cr, r_add, g_add, b_add;
+  uint8_t *cm = cropTbl + MAX_NEG_CROP;
+  unsigned int r, g, b, a;
+
+  d = dst->data[0];
+  s = src->data[0];
+  for (; height > 0; height--) {
+    d1 = d;
+    s1 = s;
+    for (w = width; w > 0; w--) {
+      a = s1[0];
+      YUV_TO_RGB1_CCIR (s1[2], s1[3]);
+
+      YUV_TO_RGB2_CCIR (r, g, b, s1[1]);
+      RGBA_OUT (d1, r, g, b, a);
+      d1 += BPP;
+      s1 += 4;
+    }
+    d += dst->linesize[0];
+    s += src->linesize[0];
+  }
+}
+
+#endif /* !defined(bgra32_fcts_done) */
+
+#endif /* defined(FMT_BGRA32) */
+
+#if defined(FMT_ARGB32)
+
+#if !defined(argb32_fcts_done)
+#define argb32_fcts_done
+
+static void
+ayuv4444_to_argb32 (AVPicture * dst, const AVPicture * src,
+    int width, int height)
+{
+  uint8_t *s, *d, *d1, *s1;
+  int w, y, cb, cr, r_add, g_add, b_add;
+  uint8_t *cm = cropTbl + MAX_NEG_CROP;
+  unsigned int r, g, b, a;
+
+  d = dst->data[0];
+  s = src->data[0];
+  for (; height > 0; height--) {
+    d1 = d;
+    s1 = s;
+    for (w = width; w > 0; w--) {
+      a = s1[0];
+      YUV_TO_RGB1_CCIR (s1[2], s1[3]);
+
+      YUV_TO_RGB2_CCIR (r, g, b, s1[1]);
+      RGBA_OUT (d1, r, g, b, a);
+      d1 += BPP;
+      s1 += 4;
+    }
+    d += dst->linesize[0];
+    s += src->linesize[0];
+  }
+}
+
+static void
+argb32_to_ayuv4444 (AVPicture * dst, const AVPicture * src,
+    int width, int height)
+{
+  int src_wrap, dst_wrap, x, y;
+  int r, g, b, a;
+  uint8_t *d;
+  const uint8_t *p;
+
+  src_wrap = src->linesize[0] - width * BPP;
+  dst_wrap = dst->linesize[0] - width * 4;
+  d = dst->data[0];
+  p = src->data[0];
+  for (y = 0; y < height; y++) {
+    for (x = 0; x < width; x++) {
+      RGBA_IN (r, g, b, a, p);
+      d[0] = a;
+      d[1] = RGB_TO_Y_CCIR (r, g, b);
+      d[2] = RGB_TO_U_CCIR (r, g, b, 0);
+      d[3] = RGB_TO_V_CCIR (r, g, b, 0);
+      p += BPP;
+      d += 4;
+    }
+    p += src_wrap;
+    d += dst_wrap;
+  }
+}
+
+#endif /* !defined(argb32_fcts_done) */
+
+#endif /* defined(FMT_ARGB32) */
+
+#if defined(FMT_ABGR32)
+#if !defined(abgr32_fcts_done)
+#define abgr32_fcts_done
+
+static void
+abgr32_to_ayuv4444 (AVPicture * dst, const AVPicture * src,
+    int width, int height)
+{
+  int src_wrap, dst_wrap, x, y;
+  int r, g, b, a;
+  uint8_t *d;
+  const uint8_t *p;
+
+  src_wrap = src->linesize[0] - width * BPP;
+  dst_wrap = dst->linesize[0] - width * 4;
+  d = dst->data[0];
+  p = src->data[0];
+  for (y = 0; y < height; y++) {
+    for (x = 0; x < width; x++) {
+      RGBA_IN (r, g, b, a, p);
+      d[0] = a;
+      d[1] = RGB_TO_Y_CCIR (r, g, b);
+      d[2] = RGB_TO_U_CCIR (r, g, b, 0);
+      d[3] = RGB_TO_V_CCIR (r, g, b, 0);
+      p += BPP;
+      d += 4;
+    }
+    p += src_wrap;
+    d += dst_wrap;
+  }
+}
+
+static void
+ayuv4444_to_abgr32 (AVPicture * dst, const AVPicture * src,
+    int width, int height)
+{
+  uint8_t *s, *d, *d1, *s1;
+  int w, y, cb, cr, r_add, g_add, b_add;
+  uint8_t *cm = cropTbl + MAX_NEG_CROP;
+  unsigned int r, g, b, a;
+
+  d = dst->data[0];
+  s = src->data[0];
+  for (; height > 0; height--) {
+    d1 = d;
+    s1 = s;
+    for (w = width; w > 0; w--) {
+      a = s1[0];
+      YUV_TO_RGB1_CCIR (s1[2], s1[3]);
+
+      YUV_TO_RGB2_CCIR (r, g, b, s1[1]);
+      RGBA_OUT (d1, r, g, b, a);
+      d1 += BPP;
+      s1 += 4;
+    }
+    d += dst->linesize[0];
+    s += src->linesize[0];
+  }
+}
+
+#endif /* !defined(abgr32_fcts_done) */
+
+#endif /* defined(FMT_ABGR32) */
+
+#ifndef FMT_RGB24
+
+static void glue (rgb24_to_, RGB_NAME) (AVPicture * dst, const AVPicture * src,
+    int width, int height)
+{
+  const uint8_t *s;
+  uint8_t *d;
+  int src_wrap, dst_wrap, j, y;
+  unsigned int r, g, b;
+
+  s = src->data[0];
+  src_wrap = src->linesize[0] - width * 3;
+
+  d = dst->data[0];
+  dst_wrap = dst->linesize[0] - width * BPP;
+
+  for (y = 0; y < height; y++) {
+    for (j = 0; j < width; j++) {
+      r = s[0];
+      g = s[1];
+      b = s[2];
+      RGB_OUT (d, r, g, b);
+      s += 3;
+      d += BPP;
+    }
+    s += src_wrap;
+    d += dst_wrap;
+  }
+}
+
+static void glue (RGB_NAME, _to_rgb24) (AVPicture * dst, const AVPicture * src,
+    int width, int height)
+{
+  const uint8_t *s;
+  uint8_t *d;
+  int src_wrap, dst_wrap, j, y;
+  unsigned int r, g, b;
+
+  s = src->data[0];
+  src_wrap = src->linesize[0] - width * BPP;
+
+  d = dst->data[0];
+  dst_wrap = dst->linesize[0] - width * 3;
+
+  for (y = 0; y < height; y++) {
+    for (j = 0; j < width; j++) {
+      RGB_IN (r, g, b, s)
+          d[0] = r;
+      d[1] = g;
+      d[2] = b;
+      d += 3;
+      s += BPP;
+    }
+    s += src_wrap;
+    d += dst_wrap;
+  }
+}
+
+#endif /* !FMT_RGB24 */
+
+#ifdef FMT_RGB24
+
+static void
+yuv444p_to_rgb24 (AVPicture * dst, const AVPicture * src, int width, int height)
+{
+  const uint8_t *y1_ptr, *cb_ptr, *cr_ptr;
+  uint8_t *d, *d1;
+  int w, y, cb, cr, r_add, g_add, b_add;
+  uint8_t *cm = cropTbl + MAX_NEG_CROP;
+  unsigned int r, g, b;
+
+  d = dst->data[0];
+  y1_ptr = src->data[0];
+  cb_ptr = src->data[1];
+  cr_ptr = src->data[2];
+  for (; height > 0; height--) {
+    d1 = d;
+    for (w = width; w > 0; w--) {
+      YUV_TO_RGB1_CCIR (cb_ptr[0], cr_ptr[0]);
+
+      YUV_TO_RGB2_CCIR (r, g, b, y1_ptr[0]);
+      RGB_OUT (d1, r, g, b);
+      d1 += BPP;
+
+      y1_ptr++;
+      cb_ptr++;
+      cr_ptr++;
+    }
+    d += dst->linesize[0];
+    y1_ptr += src->linesize[0] - width;
+    cb_ptr += src->linesize[1] - width;
+    cr_ptr += src->linesize[2] - width;
+  }
+}
+
+static void
+yuvj444p_to_rgb24 (AVPicture * dst, const AVPicture * src,
+    int width, int height)
+{
+  const uint8_t *y1_ptr, *cb_ptr, *cr_ptr;
+  uint8_t *d, *d1;
+  int w, y, cb, cr, r_add, g_add, b_add;
+  uint8_t *cm = cropTbl + MAX_NEG_CROP;
+  unsigned int r, g, b;
+
+  d = dst->data[0];
+  y1_ptr = src->data[0];
+  cb_ptr = src->data[1];
+  cr_ptr = src->data[2];
+  for (; height > 0; height--) {
+    d1 = d;
+    for (w = width; w > 0; w--) {
+      YUV_TO_RGB1 (cb_ptr[0], cr_ptr[0]);
+
+      YUV_TO_RGB2 (r, g, b, y1_ptr[0]);
+      RGB_OUT (d1, r, g, b);
+      d1 += BPP;
+
+      y1_ptr++;
+      cb_ptr++;
+      cr_ptr++;
+    }
+    d += dst->linesize[0];
+    y1_ptr += src->linesize[0] - width;
+    cb_ptr += src->linesize[1] - width;
+    cr_ptr += src->linesize[2] - width;
+  }
+}
+
+static void
+rgb24_to_yuv444p (AVPicture * dst, const AVPicture * src, int width, int height)
+{
+  int src_wrap, x, y;
+  int r, g, b;
+  uint8_t *lum, *cb, *cr;
+  const uint8_t *p;
+
+  lum = dst->data[0];
+  cb = dst->data[1];
+  cr = dst->data[2];
+
+  src_wrap = src->linesize[0] - width * BPP;
+  p = src->data[0];
+  for (y = 0; y < height; y++) {
+    for (x = 0; x < width; x++) {
+      RGB_IN (r, g, b, p);
+      lum[0] = RGB_TO_Y_CCIR (r, g, b);
+      cb[0] = RGB_TO_U_CCIR (r, g, b, 0);
+      cr[0] = RGB_TO_V_CCIR (r, g, b, 0);
+      p += BPP;
+      cb++;
+      cr++;
+      lum++;
+    }
+    p += src_wrap;
+    lum += dst->linesize[0] - width;
+    cb += dst->linesize[1] - width;
+    cr += dst->linesize[2] - width;
+  }
+}
+
+static void
+rgb24_to_yuvj420p (AVPicture * dst, const AVPicture * src,
+    int width, int height)
+{
+  int wrap, wrap3, width2;
+  int r, g, b, r1, g1, b1, w;
+  uint8_t *lum, *cb, *cr;
+  const uint8_t *p;
+
+  lum = dst->data[0];
+  cb = dst->data[1];
+  cr = dst->data[2];
+
+  width2 = (width + 1) >> 1;
+  wrap = dst->linesize[0];
+  wrap3 = src->linesize[0];
+  p = src->data[0];
+  for (; height >= 2; height -= 2) {
+    for (w = width; w >= 2; w -= 2) {
+      RGB_IN (r, g, b, p);
+      r1 = r;
+      g1 = g;
+      b1 = b;
+      lum[0] = RGB_TO_Y (r, g, b);
+
+      RGB_IN (r, g, b, p + BPP);
+      r1 += r;
+      g1 += g;
+      b1 += b;
+      lum[1] = RGB_TO_Y (r, g, b);
+      p += wrap3;
+      lum += wrap;
+
+      RGB_IN (r, g, b, p);
+      r1 += r;
+      g1 += g;
+      b1 += b;
+      lum[0] = RGB_TO_Y (r, g, b);
+
+      RGB_IN (r, g, b, p + BPP);
+      r1 += r;
+      g1 += g;
+      b1 += b;
+      lum[1] = RGB_TO_Y (r, g, b);
+
+      cb[0] = RGB_TO_U (r1, g1, b1, 2);
+      cr[0] = RGB_TO_V (r1, g1, b1, 2);
+
+      cb++;
+      cr++;
+      p += -wrap3 + 2 * BPP;
+      lum += -wrap + 2;
+    }
+    if (w) {
+      RGB_IN (r, g, b, p);
+      r1 = r;
+      g1 = g;
+      b1 = b;
+      lum[0] = RGB_TO_Y (r, g, b);
+      p += wrap3;
+      lum += wrap;
+      RGB_IN (r, g, b, p);
+      r1 += r;
+      g1 += g;
+      b1 += b;
+      lum[0] = RGB_TO_Y (r, g, b);
+      cb[0] = RGB_TO_U (r1, g1, b1, 1);
+      cr[0] = RGB_TO_V (r1, g1, b1, 1);
+      cb++;
+      cr++;
+      p += -wrap3 + BPP;
+      lum += -wrap + 1;
+    }
+    p += wrap3 + (wrap3 - width * BPP);
+    lum += wrap + (wrap - width);
+    cb += dst->linesize[1] - width2;
+    cr += dst->linesize[2] - width2;
+  }
+  /* handle odd height */
+  if (height) {
+    for (w = width; w >= 2; w -= 2) {
+      RGB_IN (r, g, b, p);
+      r1 = r;
+      g1 = g;
+      b1 = b;
+      lum[0] = RGB_TO_Y (r, g, b);
+
+      RGB_IN (r, g, b, p + BPP);
+      r1 += r;
+      g1 += g;
+      b1 += b;
+      lum[1] = RGB_TO_Y (r, g, b);
+      cb[0] = RGB_TO_U (r1, g1, b1, 1);
+      cr[0] = RGB_TO_V (r1, g1, b1, 1);
+      cb++;
+      cr++;
+      p += 2 * BPP;
+      lum += 2;
+    }
+    if (w) {
+      RGB_IN (r, g, b, p);
+      lum[0] = RGB_TO_Y (r, g, b);
+      cb[0] = RGB_TO_U (r, g, b, 0);
+      cr[0] = RGB_TO_V (r, g, b, 0);
+    }
+  }
+}
+
+static void
+rgb24_to_yuvj444p (AVPicture * dst, const AVPicture * src,
+    int width, int height)
+{
+  int src_wrap, x, y;
+  int r, g, b;
+  uint8_t *lum, *cb, *cr;
+  const uint8_t *p;
+
+  lum = dst->data[0];
+  cb = dst->data[1];
+  cr = dst->data[2];
+
+  src_wrap = src->linesize[0] - width * BPP;
+  p = src->data[0];
+  for (y = 0; y < height; y++) {
+    for (x = 0; x < width; x++) {
+      RGB_IN (r, g, b, p);
+      lum[0] = RGB_TO_Y (r, g, b);
+      cb[0] = RGB_TO_U (r, g, b, 0);
+      cr[0] = RGB_TO_V (r, g, b, 0);
+      p += BPP;
+      cb++;
+      cr++;
+      lum++;
+    }
+    p += src_wrap;
+    lum += dst->linesize[0] - width;
+    cb += dst->linesize[1] - width;
+    cr += dst->linesize[2] - width;
+  }
+}
+
+static void
+ayuv4444_to_rgb24 (AVPicture * dst, const AVPicture * src,
+    int width, int height)
+{
+  uint8_t *s, *d, *d1, *s1;
+  int w, y, cb, cr, r_add, g_add, b_add;
+  uint8_t *cm = cropTbl + MAX_NEG_CROP;
+  unsigned int r, g, b;
+
+  d = dst->data[0];
+  s = src->data[0];
+  for (; height > 0; height--) {
+    d1 = d;
+    s1 = s;
+    for (w = width; w > 0; w--) {
+      YUV_TO_RGB1_CCIR (s1[2], s1[3]);
+
+      YUV_TO_RGB2_CCIR (r, g, b, s1[1]);
+      RGB_OUT (d1, r, g, b);
+      d1 += BPP;
+      s1 += 4;
+    }
+    d += dst->linesize[0];
+    s += src->linesize[0];
+  }
+}
+
+static void
+rgb24_to_ayuv4444 (AVPicture * dst, const AVPicture * src,
+    int width, int height)
+{
+  int src_wrap, dst_wrap, x, y;
+  int r, g, b;
+  uint8_t *d;
+  const uint8_t *p;
+
+  src_wrap = src->linesize[0] - width * BPP;
+  dst_wrap = dst->linesize[0] - width * 4;
+  d = dst->data[0];
+  p = src->data[0];
+  for (y = 0; y < height; y++) {
+    for (x = 0; x < width; x++) {
+      RGB_IN (r, g, b, p);
+      d[0] = 0xff;
+      d[1] = RGB_TO_Y_CCIR (r, g, b);
+      d[2] = RGB_TO_U_CCIR (r, g, b, 0);
+      d[3] = RGB_TO_V_CCIR (r, g, b, 0);
+      p += BPP;
+      d += 4;
+    }
+    p += src_wrap;
+    d += dst_wrap;
+  }
+}
+
+static void
+v308_to_rgb24 (AVPicture * dst, const AVPicture * src, int width, int height)
+{
+  uint8_t *s, *d, *d1, *s1;
+  int w, y, cb, cr, r_add, g_add, b_add;
+  uint8_t *cm = cropTbl + MAX_NEG_CROP;
+  unsigned int r, g, b;
+
+  d = dst->data[0];
+  s = src->data[0];
+  for (; height > 0; height--) {
+    d1 = d;
+    s1 = s;
+    for (w = width; w > 0; w--) {
+      YUV_TO_RGB1_CCIR (s1[1], s1[2]);
+
+      YUV_TO_RGB2_CCIR (r, g, b, s1[0]);
+      RGB_OUT (d1, r, g, b);
+      d1 += BPP;
+      s1 += 3;
+    }
+    d += dst->linesize[0];
+    s += src->linesize[0];
+  }
+}
+
+static void
+rgb24_to_v308 (AVPicture * dst, const AVPicture * src, int width, int height)
+{
+  int src_wrap, dst_wrap, x, y;
+  int r, g, b;
+  uint8_t *d;
+  const uint8_t *p;
+
+  src_wrap = src->linesize[0] - width * BPP;
+  dst_wrap = dst->linesize[0] - width * 3;
+  d = dst->data[0];
+  p = src->data[0];
+  for (y = 0; y < height; y++) {
+    for (x = 0; x < width; x++) {
+      RGB_IN (r, g, b, p);
+      d[0] = RGB_TO_Y_CCIR (r, g, b);
+      d[1] = RGB_TO_U_CCIR (r, g, b, 0);
+      d[2] = RGB_TO_V_CCIR (r, g, b, 0);
+      p += BPP;
+      d += 3;
+    }
+    p += src_wrap;
+    d += dst_wrap;
+  }
+}
+#endif /* FMT_RGB24 */
+
+#if defined(FMT_RGB24) || defined(FMT_RGBA32)
+
+static void glue (RGB_NAME, _to_pal8) (AVPicture * dst, const AVPicture * src,
+    int width, int height)
+{
+  const unsigned char *p;
+  unsigned char *q;
+  int dst_wrap, src_wrap;
+  int x, y, has_alpha;
+  unsigned int r, g, b;
+
+  p = src->data[0];
+  src_wrap = src->linesize[0] - BPP * width;
+
+  q = dst->data[0];
+  dst_wrap = dst->linesize[0] - width;
+  has_alpha = 0;
+
+  for (y = 0; y < height; y++) {
+    for (x = 0; x < width; x++) {
+#ifdef RGBA_IN
+      {
+        unsigned int a;
+        RGBA_IN (r, g, b, a, p);
+        /* crude approximation for alpha ! */
+        if (a < 0x80) {
+          has_alpha = 1;
+          q[0] = TRANSP_INDEX;
+        } else {
+          q[0] = gif_clut_index (r, g, b);
+        }
+      }
+#else
+      RGB_IN (r, g, b, p);
+      q[0] = gif_clut_index (r, g, b);
+#endif
+      q++;
+      p += BPP;
+    }
+    p += src_wrap;
+    q += dst_wrap;
+  }
+
+  build_rgb_palette (dst->data[1], has_alpha);
+}
+
+#endif /* defined(FMT_RGB24) || defined(FMT_RGBA32) */
+
+#ifdef RGBA_IN
+
+static int glue (get_alpha_info_, RGB_NAME) (const AVPicture * src,
+    int width, int height)
+{
+  const unsigned char *p;
+  int src_wrap, ret, x, y;
+  unsigned int G_GNUC_UNUSED r, G_GNUC_UNUSED g, G_GNUC_UNUSED b, a;
+
+  p = src->data[0];
+  src_wrap = src->linesize[0] - BPP * width;
+  ret = 0;
+  for (y = 0; y < height; y++) {
+    for (x = 0; x < width; x++) {
+      RGBA_IN (r, g, b, a, p);
+      if (a == 0x00) {
+        ret |= FF_ALPHA_TRANSP;
+      } else if (a != 0xff) {
+        ret |= FF_ALPHA_SEMI_TRANSP;
+      }
+      p += BPP;
+    }
+    p += src_wrap;
+  }
+  return ret;
+}
+
+#endif /* RGBA_IN */
+
+#undef RGB_IN
+#undef RGBA_IN
+#undef RGB_OUT
+#undef RGBA_OUT
+#undef BPP
+#undef RGB_NAME
+#undef FMT_RGB24
+#undef FMT_RGBA32
+#undef YUVA_TO_A
+#undef RGBA_OUT_
+#undef RGBA_IN_