Skip to content
Snippets Groups Projects
dsputil.c 167 KiB
Newer Older
  • Learn to ignore specific revisions
  •     int i;\
        for(i=0; i<h; i++){\
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
            uint32_t a, b, c, d, l0, l1, h0, h1;\
    
            a= AV_RN32(&src1[i*src_stride1]);\
            b= AV_RN32(&src2[i*src_stride2]);\
            c= AV_RN32(&src3[i*src_stride3]);\
            d= AV_RN32(&src4[i*src_stride4]);\
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
            l0=  (a&0x03030303UL)\
               + (b&0x03030303UL)\
               + 0x02020202UL;\
            h0= ((a&0xFCFCFCFCUL)>>2)\
              + ((b&0xFCFCFCFCUL)>>2);\
            l1=  (c&0x03030303UL)\
               + (d&0x03030303UL);\
            h1= ((c&0xFCFCFCFCUL)>>2)\
              + ((d&0xFCFCFCFCUL)>>2);\
            OP(*((uint32_t*)&dst[i*dst_stride]), h0+h1+(((l0+l1)>>2)&0x0F0F0F0FUL));\
    
            a= AV_RN32(&src1[i*src_stride1+4]);\
            b= AV_RN32(&src2[i*src_stride2+4]);\
            c= AV_RN32(&src3[i*src_stride3+4]);\
            d= AV_RN32(&src4[i*src_stride4+4]);\
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
            l0=  (a&0x03030303UL)\
               + (b&0x03030303UL)\
               + 0x02020202UL;\
            h0= ((a&0xFCFCFCFCUL)>>2)\
              + ((b&0xFCFCFCFCUL)>>2);\
            l1=  (c&0x03030303UL)\
               + (d&0x03030303UL);\
            h1= ((c&0xFCFCFCFCUL)>>2)\
              + ((d&0xFCFCFCFCUL)>>2);\
            OP(*((uint32_t*)&dst[i*dst_stride+4]), h0+h1+(((l0+l1)>>2)&0x0F0F0F0FUL));\
    
    \
    static inline void OPNAME ## _pixels4_x2_c(uint8_t *block, const uint8_t *pixels, int line_size, int h){\
        OPNAME ## _pixels4_l2(block, pixels, pixels+1, line_size, line_size, line_size, h);\
    }\
    \
    static inline void OPNAME ## _pixels4_y2_c(uint8_t *block, const uint8_t *pixels, int line_size, int h){\
        OPNAME ## _pixels4_l2(block, pixels, pixels+line_size, line_size, line_size, line_size, h);\
    }\
    \
    static inline void OPNAME ## _pixels2_x2_c(uint8_t *block, const uint8_t *pixels, int line_size, int h){\
        OPNAME ## _pixels2_l2(block, pixels, pixels+1, line_size, line_size, line_size, h);\
    }\
    \
    static inline void OPNAME ## _pixels2_y2_c(uint8_t *block, const uint8_t *pixels, int line_size, int h){\
        OPNAME ## _pixels2_l2(block, pixels, pixels+line_size, line_size, line_size, line_size, h);\
    }\
    \
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
    static inline void OPNAME ## _no_rnd_pixels8_l4(uint8_t *dst, const uint8_t *src1, uint8_t *src2, uint8_t *src3, uint8_t *src4,\
                     int dst_stride, int src_stride1, int src_stride2,int src_stride3,int src_stride4, int h){\
    
        int i;\
        for(i=0; i<h; i++){\
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
            uint32_t a, b, c, d, l0, l1, h0, h1;\
    
            a= AV_RN32(&src1[i*src_stride1]);\
            b= AV_RN32(&src2[i*src_stride2]);\
            c= AV_RN32(&src3[i*src_stride3]);\
            d= AV_RN32(&src4[i*src_stride4]);\
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
            l0=  (a&0x03030303UL)\
               + (b&0x03030303UL)\
               + 0x01010101UL;\
            h0= ((a&0xFCFCFCFCUL)>>2)\
              + ((b&0xFCFCFCFCUL)>>2);\
            l1=  (c&0x03030303UL)\
               + (d&0x03030303UL);\
            h1= ((c&0xFCFCFCFCUL)>>2)\
              + ((d&0xFCFCFCFCUL)>>2);\
            OP(*((uint32_t*)&dst[i*dst_stride]), h0+h1+(((l0+l1)>>2)&0x0F0F0F0FUL));\
    
            a= AV_RN32(&src1[i*src_stride1+4]);\
            b= AV_RN32(&src2[i*src_stride2+4]);\
            c= AV_RN32(&src3[i*src_stride3+4]);\
            d= AV_RN32(&src4[i*src_stride4+4]);\
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
            l0=  (a&0x03030303UL)\
               + (b&0x03030303UL)\
               + 0x01010101UL;\
            h0= ((a&0xFCFCFCFCUL)>>2)\
              + ((b&0xFCFCFCFCUL)>>2);\
            l1=  (c&0x03030303UL)\
               + (d&0x03030303UL);\
            h1= ((c&0xFCFCFCFCUL)>>2)\
              + ((d&0xFCFCFCFCUL)>>2);\
            OP(*((uint32_t*)&dst[i*dst_stride+4]), h0+h1+(((l0+l1)>>2)&0x0F0F0F0FUL));\
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
    static inline void OPNAME ## _pixels16_l4(uint8_t *dst, const uint8_t *src1, uint8_t *src2, uint8_t *src3, uint8_t *src4,\
                     int dst_stride, int src_stride1, int src_stride2,int src_stride3,int src_stride4, int h){\
        OPNAME ## _pixels8_l4(dst  , src1  , src2  , src3  , src4  , dst_stride, src_stride1, src_stride2, src_stride3, src_stride4, h);\
        OPNAME ## _pixels8_l4(dst+8, src1+8, src2+8, src3+8, src4+8, dst_stride, src_stride1, src_stride2, src_stride3, src_stride4, h);\
    }\
    static inline void OPNAME ## _no_rnd_pixels16_l4(uint8_t *dst, const uint8_t *src1, uint8_t *src2, uint8_t *src3, uint8_t *src4,\
                     int dst_stride, int src_stride1, int src_stride2,int src_stride3,int src_stride4, int h){\
        OPNAME ## _no_rnd_pixels8_l4(dst  , src1  , src2  , src3  , src4  , dst_stride, src_stride1, src_stride2, src_stride3, src_stride4, h);\
        OPNAME ## _no_rnd_pixels8_l4(dst+8, src1+8, src2+8, src3+8, src4+8, dst_stride, src_stride1, src_stride2, src_stride3, src_stride4, h);\
    }\
    
    static inline void OPNAME ## _pixels2_xy2_c(uint8_t *block, const uint8_t *pixels, int line_size, int h)\
    {\
            int i, a0, b0, a1, b1;\
            a0= pixels[0];\
            b0= pixels[1] + 2;\
            a0 += b0;\
            b0 += pixels[2];\
    \
            pixels+=line_size;\
            for(i=0; i<h; i+=2){\
                a1= pixels[0];\
                b1= pixels[1];\
                a1 += b1;\
                b1 += pixels[2];\
    \
                block[0]= (a1+a0)>>2; /* FIXME non put */\
                block[1]= (b1+b0)>>2;\
    \
                pixels+=line_size;\
                block +=line_size;\
    \
                a0= pixels[0];\
                b0= pixels[1] + 2;\
                a0 += b0;\
                b0 += pixels[2];\
    \
                block[0]= (a1+a0)>>2;\
                block[1]= (b1+b0)>>2;\
                pixels+=line_size;\
                block +=line_size;\
            }\
    }\
    \
    static inline void OPNAME ## _pixels4_xy2_c(uint8_t *block, const uint8_t *pixels, int line_size, int h)\
    {\
            int i;\
    
            const uint32_t a= AV_RN32(pixels  );\
            const uint32_t b= AV_RN32(pixels+1);\
    
            uint32_t l0=  (a&0x03030303UL)\
                        + (b&0x03030303UL)\
                        + 0x02020202UL;\
            uint32_t h0= ((a&0xFCFCFCFCUL)>>2)\
                       + ((b&0xFCFCFCFCUL)>>2);\
            uint32_t l1,h1;\
    \
            pixels+=line_size;\
            for(i=0; i<h; i+=2){\
    
                uint32_t a= AV_RN32(pixels  );\
                uint32_t b= AV_RN32(pixels+1);\
    
                l1=  (a&0x03030303UL)\
                   + (b&0x03030303UL);\
                h1= ((a&0xFCFCFCFCUL)>>2)\
                  + ((b&0xFCFCFCFCUL)>>2);\
                OP(*((uint32_t*)block), h0+h1+(((l0+l1)>>2)&0x0F0F0F0FUL));\
                pixels+=line_size;\
                block +=line_size;\
    
                a= AV_RN32(pixels  );\
                b= AV_RN32(pixels+1);\
    
                l0=  (a&0x03030303UL)\
                   + (b&0x03030303UL)\
                   + 0x02020202UL;\
                h0= ((a&0xFCFCFCFCUL)>>2)\
                  + ((b&0xFCFCFCFCUL)>>2);\
                OP(*((uint32_t*)block), h0+h1+(((l0+l1)>>2)&0x0F0F0F0FUL));\
                pixels+=line_size;\
                block +=line_size;\
            }\
    }\
    \
    
    static inline void OPNAME ## _pixels8_xy2_c(uint8_t *block, const uint8_t *pixels, int line_size, int h)\
    
    {\
        int j;\
        for(j=0; j<2; j++){\
            int i;\
    
            const uint32_t a= AV_RN32(pixels  );\
            const uint32_t b= AV_RN32(pixels+1);\
    
            uint32_t l0=  (a&0x03030303UL)\
                        + (b&0x03030303UL)\
                        + 0x02020202UL;\
            uint32_t h0= ((a&0xFCFCFCFCUL)>>2)\
                       + ((b&0xFCFCFCFCUL)>>2);\
            uint32_t l1,h1;\
    \
            pixels+=line_size;\
            for(i=0; i<h; i+=2){\
    
                uint32_t a= AV_RN32(pixels  );\
                uint32_t b= AV_RN32(pixels+1);\
    
                l1=  (a&0x03030303UL)\
                   + (b&0x03030303UL);\
                h1= ((a&0xFCFCFCFCUL)>>2)\
                  + ((b&0xFCFCFCFCUL)>>2);\
                OP(*((uint32_t*)block), h0+h1+(((l0+l1)>>2)&0x0F0F0F0FUL));\
                pixels+=line_size;\
                block +=line_size;\
    
                a= AV_RN32(pixels  );\
                b= AV_RN32(pixels+1);\
    
                l0=  (a&0x03030303UL)\
                   + (b&0x03030303UL)\
                   + 0x02020202UL;\
                h0= ((a&0xFCFCFCFCUL)>>2)\
                  + ((b&0xFCFCFCFCUL)>>2);\
                OP(*((uint32_t*)block), h0+h1+(((l0+l1)>>2)&0x0F0F0F0FUL));\
                pixels+=line_size;\
                block +=line_size;\
            }\
            pixels+=4-line_size*(h+1);\
            block +=4-line_size*h;\
        }\
    }\
    \
    
    static inline void OPNAME ## _no_rnd_pixels8_xy2_c(uint8_t *block, const uint8_t *pixels, int line_size, int h)\
    
    {\
        int j;\
        for(j=0; j<2; j++){\
            int i;\
    
            const uint32_t a= AV_RN32(pixels  );\
            const uint32_t b= AV_RN32(pixels+1);\
    
            uint32_t l0=  (a&0x03030303UL)\
                        + (b&0x03030303UL)\
                        + 0x01010101UL;\
            uint32_t h0= ((a&0xFCFCFCFCUL)>>2)\
                       + ((b&0xFCFCFCFCUL)>>2);\
            uint32_t l1,h1;\
    \
            pixels+=line_size;\
            for(i=0; i<h; i+=2){\
    
                uint32_t a= AV_RN32(pixels  );\
                uint32_t b= AV_RN32(pixels+1);\
    
                l1=  (a&0x03030303UL)\
                   + (b&0x03030303UL);\
                h1= ((a&0xFCFCFCFCUL)>>2)\
                  + ((b&0xFCFCFCFCUL)>>2);\
                OP(*((uint32_t*)block), h0+h1+(((l0+l1)>>2)&0x0F0F0F0FUL));\
                pixels+=line_size;\
                block +=line_size;\
    
                a= AV_RN32(pixels  );\
                b= AV_RN32(pixels+1);\
    
                l0=  (a&0x03030303UL)\
                   + (b&0x03030303UL)\
                   + 0x01010101UL;\
                h0= ((a&0xFCFCFCFCUL)>>2)\
                  + ((b&0xFCFCFCFCUL)>>2);\
                OP(*((uint32_t*)block), h0+h1+(((l0+l1)>>2)&0x0F0F0F0FUL));\
                pixels+=line_size;\
                block +=line_size;\
            }\
            pixels+=4-line_size*(h+1);\
            block +=4-line_size*h;\
        }\
    }\
    \
    
    CALL_2X_PIXELS(OPNAME ## _pixels16_c  , OPNAME ## _pixels8_c  , 8)\
    CALL_2X_PIXELS(OPNAME ## _pixels16_x2_c , OPNAME ## _pixels8_x2_c , 8)\
    CALL_2X_PIXELS(OPNAME ## _pixels16_y2_c , OPNAME ## _pixels8_y2_c , 8)\
    CALL_2X_PIXELS(OPNAME ## _pixels16_xy2_c, OPNAME ## _pixels8_xy2_c, 8)\
    CALL_2X_PIXELS(OPNAME ## _no_rnd_pixels16_c  , OPNAME ## _pixels8_c         , 8)\
    CALL_2X_PIXELS(OPNAME ## _no_rnd_pixels16_x2_c , OPNAME ## _no_rnd_pixels8_x2_c , 8)\
    CALL_2X_PIXELS(OPNAME ## _no_rnd_pixels16_y2_c , OPNAME ## _no_rnd_pixels8_y2_c , 8)\
    CALL_2X_PIXELS(OPNAME ## _no_rnd_pixels16_xy2_c, OPNAME ## _no_rnd_pixels8_xy2_c, 8)\
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
    #define op_avg(a, b) a = rnd_avg32(a, b)
    
    #endif
    #define op_put(a, b) a = b
    
    PIXOP2(avg, op_avg)
    PIXOP2(put, op_put)
    #undef op_avg
    #undef op_put
    
    
    Fabrice Bellard's avatar
    Fabrice Bellard committed
    #define avg2(a,b) ((a+b+1)>>1)
    #define avg4(a,b,c,d) ((a+b+c+d+2)>>2)
    
    
    static void put_no_rnd_pixels16_l2_c(uint8_t *dst, const uint8_t *a, const uint8_t *b, int stride, int h){
        put_no_rnd_pixels16_l2(dst, a, b, stride, stride, stride, h);
    }
    
    static void put_no_rnd_pixels8_l2_c(uint8_t *dst, const uint8_t *a, const uint8_t *b, int stride, int h){
        put_no_rnd_pixels8_l2(dst, a, b, stride, stride, stride, h);
    }
    
    static void gmc1_c(uint8_t *dst, uint8_t *src, int stride, int h, int x16, int y16, int rounder)
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
    {
        const int A=(16-x16)*(16-y16);
        const int B=(   x16)*(16-y16);
        const int C=(16-x16)*(   y16);
        const int D=(   x16)*(   y16);
        int i;
    
        for(i=0; i<h; i++)
        {
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
            dst[0]= (A*src[0] + B*src[1] + C*src[stride+0] + D*src[stride+1] + rounder)>>8;
            dst[1]= (A*src[1] + B*src[2] + C*src[stride+1] + D*src[stride+2] + rounder)>>8;
            dst[2]= (A*src[2] + B*src[3] + C*src[stride+2] + D*src[stride+3] + rounder)>>8;
            dst[3]= (A*src[3] + B*src[4] + C*src[stride+3] + D*src[stride+4] + rounder)>>8;
            dst[4]= (A*src[4] + B*src[5] + C*src[stride+4] + D*src[stride+5] + rounder)>>8;
            dst[5]= (A*src[5] + B*src[6] + C*src[stride+5] + D*src[stride+6] + rounder)>>8;
            dst[6]= (A*src[6] + B*src[7] + C*src[stride+6] + D*src[stride+7] + rounder)>>8;
            dst[7]= (A*src[7] + B*src[8] + C*src[stride+7] + D*src[stride+8] + rounder)>>8;
            dst+= stride;
            src+= stride;
    
    void ff_gmc_c(uint8_t *dst, uint8_t *src, int stride, int h, int ox, int oy,
    
                      int dxx, int dxy, int dyx, int dyy, int shift, int r, int width, int height)
    {
        int y, vx, vy;
        const int s= 1<<shift;
    
        width--;
        height--;
    
        for(y=0; y<h; y++){
            int x;
    
            vx= ox;
            vy= oy;
            for(x=0; x<8; x++){ //XXX FIXME optimize
                int src_x, src_y, frac_x, frac_y, index;
    
                src_x= vx>>16;
                src_y= vy>>16;
                frac_x= src_x&(s-1);
                frac_y= src_y&(s-1);
                src_x>>=shift;
                src_y>>=shift;
    
                if((unsigned)src_x < width){
                    if((unsigned)src_y < height){
                        index= src_x + src_y*stride;
                        dst[y*stride + x]= (  (  src[index         ]*(s-frac_x)
                                               + src[index       +1]*   frac_x )*(s-frac_y)
                                            + (  src[index+stride  ]*(s-frac_x)
                                               + src[index+stride+1]*   frac_x )*   frac_y
                                            + r)>>(shift*2);
                    }else{
    
                        index= src_x + av_clip(src_y, 0, height)*stride;
    
                        dst[y*stride + x]= ( (  src[index         ]*(s-frac_x)
    
                                              + src[index       +1]*   frac_x )*s
                                            + r)>>(shift*2);
                    }
                }else{
                    if((unsigned)src_y < height){
    
                        index= av_clip(src_x, 0, width) + src_y*stride;
    
                        dst[y*stride + x]= (  (  src[index         ]*(s-frac_y)
    
                                               + src[index+stride  ]*   frac_y )*s
                                            + r)>>(shift*2);
                    }else{
    
                        index= av_clip(src_x, 0, width) + av_clip(src_y, 0, height)*stride;
    
                        dst[y*stride + x]=    src[index         ];
                    }
                }
    
                vx+= dxx;
                vy+= dyx;
            }
            ox += dxy;
            oy += dyy;
        }
    }
    
    
    static inline void put_tpel_pixels_mc00_c(uint8_t *dst, const uint8_t *src, int stride, int width, int height){
        switch(width){
        case 2: put_pixels2_c (dst, src, stride, height); break;
        case 4: put_pixels4_c (dst, src, stride, height); break;
        case 8: put_pixels8_c (dst, src, stride, height); break;
        case 16:put_pixels16_c(dst, src, stride, height); break;
        }
    }
    
    static inline void put_tpel_pixels_mc10_c(uint8_t *dst, const uint8_t *src, int stride, int width, int height){
        int i,j;
        for (i=0; i < height; i++) {
          for (j=0; j < width; j++) {
    
            dst[j] = (683*(2*src[j] + src[j+1] + 1)) >> 11;
    
          }
          src += stride;
          dst += stride;
        }
    }
    
    static inline void put_tpel_pixels_mc20_c(uint8_t *dst, const uint8_t *src, int stride, int width, int height){
        int i,j;
        for (i=0; i < height; i++) {
          for (j=0; j < width; j++) {
    
            dst[j] = (683*(src[j] + 2*src[j+1] + 1)) >> 11;
    
    static inline void put_tpel_pixels_mc01_c(uint8_t *dst, const uint8_t *src, int stride, int width, int height){
        int i,j;
        for (i=0; i < height; i++) {
          for (j=0; j < width; j++) {
    
            dst[j] = (683*(2*src[j] + src[j+stride] + 1)) >> 11;
    
    static inline void put_tpel_pixels_mc11_c(uint8_t *dst, const uint8_t *src, int stride, int width, int height){
        int i,j;
        for (i=0; i < height; i++) {
          for (j=0; j < width; j++) {
    
            dst[j] = (2731*(4*src[j] + 3*src[j+1] + 3*src[j+stride] + 2*src[j+stride+1] + 6)) >> 15;
    
          }
          src += stride;
          dst += stride;
        }
    }
    
    static inline void put_tpel_pixels_mc12_c(uint8_t *dst, const uint8_t *src, int stride, int width, int height){
        int i,j;
        for (i=0; i < height; i++) {
          for (j=0; j < width; j++) {
    
            dst[j] = (2731*(3*src[j] + 2*src[j+1] + 4*src[j+stride] + 3*src[j+stride+1] + 6)) >> 15;
    
          }
          src += stride;
          dst += stride;
        }
    }
    
    static inline void put_tpel_pixels_mc02_c(uint8_t *dst, const uint8_t *src, int stride, int width, int height){
        int i,j;
        for (i=0; i < height; i++) {
          for (j=0; j < width; j++) {
    
            dst[j] = (683*(src[j] + 2*src[j+stride] + 1)) >> 11;
    
          }
          src += stride;
          dst += stride;
        }
    }
    
    static inline void put_tpel_pixels_mc21_c(uint8_t *dst, const uint8_t *src, int stride, int width, int height){
        int i,j;
        for (i=0; i < height; i++) {
          for (j=0; j < width; j++) {
    
            dst[j] = (2731*(3*src[j] + 4*src[j+1] + 2*src[j+stride] + 3*src[j+stride+1] + 6)) >> 15;
    
          }
          src += stride;
          dst += stride;
        }
    }
    
    static inline void put_tpel_pixels_mc22_c(uint8_t *dst, const uint8_t *src, int stride, int width, int height){
        int i,j;
        for (i=0; i < height; i++) {
          for (j=0; j < width; j++) {
    
            dst[j] = (2731*(2*src[j] + 3*src[j+1] + 3*src[j+stride] + 4*src[j+stride+1] + 6)) >> 15;
    
    
    static inline void avg_tpel_pixels_mc00_c(uint8_t *dst, const uint8_t *src, int stride, int width, int height){
        switch(width){
        case 2: avg_pixels2_c (dst, src, stride, height); break;
        case 4: avg_pixels4_c (dst, src, stride, height); break;
        case 8: avg_pixels8_c (dst, src, stride, height); break;
        case 16:avg_pixels16_c(dst, src, stride, height); break;
        }
    }
    
    static inline void avg_tpel_pixels_mc10_c(uint8_t *dst, const uint8_t *src, int stride, int width, int height){
        int i,j;
        for (i=0; i < height; i++) {
          for (j=0; j < width; j++) {
    
            dst[j] = (dst[j] + ((683*(2*src[j] + src[j+1] + 1)) >> 11) + 1) >> 1;
    
          }
          src += stride;
          dst += stride;
        }
    }
    
    static inline void avg_tpel_pixels_mc20_c(uint8_t *dst, const uint8_t *src, int stride, int width, int height){
        int i,j;
        for (i=0; i < height; i++) {
          for (j=0; j < width; j++) {
    
            dst[j] = (dst[j] + ((683*(src[j] + 2*src[j+1] + 1)) >> 11) + 1) >> 1;
    
    static inline void avg_tpel_pixels_mc01_c(uint8_t *dst, const uint8_t *src, int stride, int width, int height){
        int i,j;
        for (i=0; i < height; i++) {
          for (j=0; j < width; j++) {
    
            dst[j] = (dst[j] + ((683*(2*src[j] + src[j+stride] + 1)) >> 11) + 1) >> 1;
    
    static inline void avg_tpel_pixels_mc11_c(uint8_t *dst, const uint8_t *src, int stride, int width, int height){
        int i,j;
        for (i=0; i < height; i++) {
          for (j=0; j < width; j++) {
    
            dst[j] = (dst[j] + ((2731*(4*src[j] + 3*src[j+1] + 3*src[j+stride] + 2*src[j+stride+1] + 6)) >> 15) + 1) >> 1;
    
          }
          src += stride;
          dst += stride;
        }
    }
    
    static inline void avg_tpel_pixels_mc12_c(uint8_t *dst, const uint8_t *src, int stride, int width, int height){
        int i,j;
        for (i=0; i < height; i++) {
          for (j=0; j < width; j++) {
    
            dst[j] = (dst[j] + ((2731*(3*src[j] + 2*src[j+1] + 4*src[j+stride] + 3*src[j+stride+1] + 6)) >> 15) + 1) >> 1;
    
          }
          src += stride;
          dst += stride;
        }
    }
    
    static inline void avg_tpel_pixels_mc02_c(uint8_t *dst, const uint8_t *src, int stride, int width, int height){
        int i,j;
        for (i=0; i < height; i++) {
          for (j=0; j < width; j++) {
    
            dst[j] = (dst[j] + ((683*(src[j] + 2*src[j+stride] + 1)) >> 11) + 1) >> 1;
    
          }
          src += stride;
          dst += stride;
        }
    }
    
    static inline void avg_tpel_pixels_mc21_c(uint8_t *dst, const uint8_t *src, int stride, int width, int height){
        int i,j;
        for (i=0; i < height; i++) {
          for (j=0; j < width; j++) {
    
            dst[j] = (dst[j] + ((2731*(3*src[j] + 4*src[j+1] + 2*src[j+stride] + 3*src[j+stride+1] + 6)) >> 15) + 1) >> 1;
    
          }
          src += stride;
          dst += stride;
        }
    }
    
    static inline void avg_tpel_pixels_mc22_c(uint8_t *dst, const uint8_t *src, int stride, int width, int height){
        int i,j;
        for (i=0; i < height; i++) {
          for (j=0; j < width; j++) {
    
            dst[j] = (dst[j] + ((2731*(2*src[j] + 3*src[j+1] + 3*src[j+stride] + 4*src[j+stride+1] + 6)) >> 15) + 1) >> 1;
    
    #if 0
    #define TPEL_WIDTH(width)\
    static void put_tpel_pixels ## width ## _mc00_c(uint8_t *dst, const uint8_t *src, int stride, int height){\
        void put_tpel_pixels_mc00_c(dst, src, stride, width, height);}\
    static void put_tpel_pixels ## width ## _mc10_c(uint8_t *dst, const uint8_t *src, int stride, int height){\
        void put_tpel_pixels_mc10_c(dst, src, stride, width, height);}\
    static void put_tpel_pixels ## width ## _mc20_c(uint8_t *dst, const uint8_t *src, int stride, int height){\
        void put_tpel_pixels_mc20_c(dst, src, stride, width, height);}\
    static void put_tpel_pixels ## width ## _mc01_c(uint8_t *dst, const uint8_t *src, int stride, int height){\
        void put_tpel_pixels_mc01_c(dst, src, stride, width, height);}\
    static void put_tpel_pixels ## width ## _mc11_c(uint8_t *dst, const uint8_t *src, int stride, int height){\
        void put_tpel_pixels_mc11_c(dst, src, stride, width, height);}\
    static void put_tpel_pixels ## width ## _mc21_c(uint8_t *dst, const uint8_t *src, int stride, int height){\
        void put_tpel_pixels_mc21_c(dst, src, stride, width, height);}\
    static void put_tpel_pixels ## width ## _mc02_c(uint8_t *dst, const uint8_t *src, int stride, int height){\
        void put_tpel_pixels_mc02_c(dst, src, stride, width, height);}\
    static void put_tpel_pixels ## width ## _mc12_c(uint8_t *dst, const uint8_t *src, int stride, int height){\
        void put_tpel_pixels_mc12_c(dst, src, stride, width, height);}\
    static void put_tpel_pixels ## width ## _mc22_c(uint8_t *dst, const uint8_t *src, int stride, int height){\
        void put_tpel_pixels_mc22_c(dst, src, stride, width, height);}
    #endif
    
    
    #define H264_CHROMA_MC(OPNAME, OP)\
    static void OPNAME ## h264_chroma_mc2_c(uint8_t *dst/*align 8*/, uint8_t *src/*align 1*/, int stride, int h, int x, int y){\
        const int A=(8-x)*(8-y);\
        const int B=(  x)*(8-y);\
        const int C=(8-x)*(  y);\
        const int D=(  x)*(  y);\
        int i;\
        \
        assert(x<8 && y<8 && x>=0 && y>=0);\
    \
    
            for(i=0; i<h; i++){\
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
                OP(dst[0], (A*src[0] + B*src[1] + C*src[stride+0] + D*src[stride+1]));\
                OP(dst[1], (A*src[1] + B*src[2] + C*src[stride+1] + D*src[stride+2]));\
                dst+= stride;\
                src+= stride;\
            }\
    
        }else{\
            const int E= B+C;\
            const int step= C ? stride : 1;\
    
            for(i=0; i<h; i++){\
    
                OP(dst[0], (A*src[0] + E*src[step+0]));\
                OP(dst[1], (A*src[1] + E*src[step+1]));\
                dst+= stride;\
                src+= stride;\
            }\
        }\
    
    }\
    \
    static void OPNAME ## h264_chroma_mc4_c(uint8_t *dst/*align 8*/, uint8_t *src/*align 1*/, int stride, int h, int x, int y){\
        const int A=(8-x)*(8-y);\
        const int B=(  x)*(8-y);\
        const int C=(8-x)*(  y);\
        const int D=(  x)*(  y);\
        int i;\
        \
        assert(x<8 && y<8 && x>=0 && y>=0);\
    \
    
            for(i=0; i<h; i++){\
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
                OP(dst[0], (A*src[0] + B*src[1] + C*src[stride+0] + D*src[stride+1]));\
                OP(dst[1], (A*src[1] + B*src[2] + C*src[stride+1] + D*src[stride+2]));\
                OP(dst[2], (A*src[2] + B*src[3] + C*src[stride+2] + D*src[stride+3]));\
                OP(dst[3], (A*src[3] + B*src[4] + C*src[stride+3] + D*src[stride+4]));\
                dst+= stride;\
                src+= stride;\
            }\
    
        }else{\
            const int E= B+C;\
            const int step= C ? stride : 1;\
    
            for(i=0; i<h; i++){\
    
                OP(dst[0], (A*src[0] + E*src[step+0]));\
                OP(dst[1], (A*src[1] + E*src[step+1]));\
                OP(dst[2], (A*src[2] + E*src[step+2]));\
                OP(dst[3], (A*src[3] + E*src[step+3]));\
                dst+= stride;\
                src+= stride;\
            }\
        }\
    
    }\
    \
    static void OPNAME ## h264_chroma_mc8_c(uint8_t *dst/*align 8*/, uint8_t *src/*align 1*/, int stride, int h, int x, int y){\
        const int A=(8-x)*(8-y);\
        const int B=(  x)*(8-y);\
        const int C=(8-x)*(  y);\
        const int D=(  x)*(  y);\
        int i;\
        \
        assert(x<8 && y<8 && x>=0 && y>=0);\
    \
    
            for(i=0; i<h; i++){\
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
                OP(dst[0], (A*src[0] + B*src[1] + C*src[stride+0] + D*src[stride+1]));\
                OP(dst[1], (A*src[1] + B*src[2] + C*src[stride+1] + D*src[stride+2]));\
                OP(dst[2], (A*src[2] + B*src[3] + C*src[stride+2] + D*src[stride+3]));\
                OP(dst[3], (A*src[3] + B*src[4] + C*src[stride+3] + D*src[stride+4]));\
                OP(dst[4], (A*src[4] + B*src[5] + C*src[stride+4] + D*src[stride+5]));\
                OP(dst[5], (A*src[5] + B*src[6] + C*src[stride+5] + D*src[stride+6]));\
                OP(dst[6], (A*src[6] + B*src[7] + C*src[stride+6] + D*src[stride+7]));\
                OP(dst[7], (A*src[7] + B*src[8] + C*src[stride+7] + D*src[stride+8]));\
                dst+= stride;\
                src+= stride;\
            }\
    
        }else{\
            const int E= B+C;\
            const int step= C ? stride : 1;\
    
            for(i=0; i<h; i++){\
    
                OP(dst[0], (A*src[0] + E*src[step+0]));\
                OP(dst[1], (A*src[1] + E*src[step+1]));\
                OP(dst[2], (A*src[2] + E*src[step+2]));\
                OP(dst[3], (A*src[3] + E*src[step+3]));\
                OP(dst[4], (A*src[4] + E*src[step+4]));\
                OP(dst[5], (A*src[5] + E*src[step+5]));\
                OP(dst[6], (A*src[6] + E*src[step+6]));\
                OP(dst[7], (A*src[7] + E*src[step+7]));\
                dst+= stride;\
                src+= stride;\
            }\
        }\
    
    }
    
    #define op_avg(a, b) a = (((a)+(((b) + 32)>>6)+1)>>1)
    #define op_put(a, b) a = (((b) + 32)>>6)
    
    H264_CHROMA_MC(put_       , op_put)
    H264_CHROMA_MC(avg_       , op_avg)
    #undef op_avg
    #undef op_put
    
    
    static void put_no_rnd_h264_chroma_mc8_c(uint8_t *dst/*align 8*/, uint8_t *src/*align 1*/, int stride, int h, int x, int y){
        const int A=(8-x)*(8-y);
        const int B=(  x)*(8-y);
        const int C=(8-x)*(  y);
        const int D=(  x)*(  y);
        int i;
    
        assert(x<8 && y<8 && x>=0 && y>=0);
    
        for(i=0; i<h; i++)
        {
            dst[0] = (A*src[0] + B*src[1] + C*src[stride+0] + D*src[stride+1] + 32 - 4) >> 6;
            dst[1] = (A*src[1] + B*src[2] + C*src[stride+1] + D*src[stride+2] + 32 - 4) >> 6;
            dst[2] = (A*src[2] + B*src[3] + C*src[stride+2] + D*src[stride+3] + 32 - 4) >> 6;
            dst[3] = (A*src[3] + B*src[4] + C*src[stride+3] + D*src[stride+4] + 32 - 4) >> 6;
            dst[4] = (A*src[4] + B*src[5] + C*src[stride+4] + D*src[stride+5] + 32 - 4) >> 6;
            dst[5] = (A*src[5] + B*src[6] + C*src[stride+5] + D*src[stride+6] + 32 - 4) >> 6;
            dst[6] = (A*src[6] + B*src[7] + C*src[stride+6] + D*src[stride+7] + 32 - 4) >> 6;
            dst[7] = (A*src[7] + B*src[8] + C*src[stride+7] + D*src[stride+8] + 32 - 4) >> 6;
            dst+= stride;
            src+= stride;
        }
    }
    
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
    #define QPEL_MC(r, OPNAME, RND, OP) \
    
    static void OPNAME ## mpeg4_qpel8_h_lowpass(uint8_t *dst, uint8_t *src, int dstStride, int srcStride, int h){\
    
        uint8_t *cm = ff_cropTbl + MAX_NEG_CROP;\
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
        int i;\
        for(i=0; i<h; i++)\
        {\
            OP(dst[0], (src[0]+src[1])*20 - (src[0]+src[2])*6 + (src[1]+src[3])*3 - (src[2]+src[4]));\
            OP(dst[1], (src[1]+src[2])*20 - (src[0]+src[3])*6 + (src[0]+src[4])*3 - (src[1]+src[5]));\
            OP(dst[2], (src[2]+src[3])*20 - (src[1]+src[4])*6 + (src[0]+src[5])*3 - (src[0]+src[6]));\
            OP(dst[3], (src[3]+src[4])*20 - (src[2]+src[5])*6 + (src[1]+src[6])*3 - (src[0]+src[7]));\
            OP(dst[4], (src[4]+src[5])*20 - (src[3]+src[6])*6 + (src[2]+src[7])*3 - (src[1]+src[8]));\
            OP(dst[5], (src[5]+src[6])*20 - (src[4]+src[7])*6 + (src[3]+src[8])*3 - (src[2]+src[8]));\
            OP(dst[6], (src[6]+src[7])*20 - (src[5]+src[8])*6 + (src[4]+src[8])*3 - (src[3]+src[7]));\
            OP(dst[7], (src[7]+src[8])*20 - (src[6]+src[8])*6 + (src[5]+src[7])*3 - (src[4]+src[6]));\
            dst+=dstStride;\
            src+=srcStride;\
        }\
    
    static void OPNAME ## mpeg4_qpel8_v_lowpass(uint8_t *dst, uint8_t *src, int dstStride, int srcStride){\
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
        const int w=8;\
    
        uint8_t *cm = ff_cropTbl + MAX_NEG_CROP;\
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
        int i;\
        for(i=0; i<w; i++)\
        {\
            const int src0= src[0*srcStride];\
            const int src1= src[1*srcStride];\
            const int src2= src[2*srcStride];\
            const int src3= src[3*srcStride];\
            const int src4= src[4*srcStride];\
            const int src5= src[5*srcStride];\
            const int src6= src[6*srcStride];\
            const int src7= src[7*srcStride];\
            const int src8= src[8*srcStride];\
            OP(dst[0*dstStride], (src0+src1)*20 - (src0+src2)*6 + (src1+src3)*3 - (src2+src4));\
            OP(dst[1*dstStride], (src1+src2)*20 - (src0+src3)*6 + (src0+src4)*3 - (src1+src5));\
            OP(dst[2*dstStride], (src2+src3)*20 - (src1+src4)*6 + (src0+src5)*3 - (src0+src6));\
            OP(dst[3*dstStride], (src3+src4)*20 - (src2+src5)*6 + (src1+src6)*3 - (src0+src7));\
            OP(dst[4*dstStride], (src4+src5)*20 - (src3+src6)*6 + (src2+src7)*3 - (src1+src8));\
            OP(dst[5*dstStride], (src5+src6)*20 - (src4+src7)*6 + (src3+src8)*3 - (src2+src8));\
            OP(dst[6*dstStride], (src6+src7)*20 - (src5+src8)*6 + (src4+src8)*3 - (src3+src7));\
            OP(dst[7*dstStride], (src7+src8)*20 - (src6+src8)*6 + (src5+src7)*3 - (src4+src6));\
            dst++;\
            src++;\
        }\
    }\
    \
    
    static void OPNAME ## mpeg4_qpel16_h_lowpass(uint8_t *dst, uint8_t *src, int dstStride, int srcStride, int h){\
    
        uint8_t *cm = ff_cropTbl + MAX_NEG_CROP;\
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
        int i;\
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
        for(i=0; i<h; i++)\
        {\
            OP(dst[ 0], (src[ 0]+src[ 1])*20 - (src[ 0]+src[ 2])*6 + (src[ 1]+src[ 3])*3 - (src[ 2]+src[ 4]));\
            OP(dst[ 1], (src[ 1]+src[ 2])*20 - (src[ 0]+src[ 3])*6 + (src[ 0]+src[ 4])*3 - (src[ 1]+src[ 5]));\
            OP(dst[ 2], (src[ 2]+src[ 3])*20 - (src[ 1]+src[ 4])*6 + (src[ 0]+src[ 5])*3 - (src[ 0]+src[ 6]));\
            OP(dst[ 3], (src[ 3]+src[ 4])*20 - (src[ 2]+src[ 5])*6 + (src[ 1]+src[ 6])*3 - (src[ 0]+src[ 7]));\
            OP(dst[ 4], (src[ 4]+src[ 5])*20 - (src[ 3]+src[ 6])*6 + (src[ 2]+src[ 7])*3 - (src[ 1]+src[ 8]));\
            OP(dst[ 5], (src[ 5]+src[ 6])*20 - (src[ 4]+src[ 7])*6 + (src[ 3]+src[ 8])*3 - (src[ 2]+src[ 9]));\
            OP(dst[ 6], (src[ 6]+src[ 7])*20 - (src[ 5]+src[ 8])*6 + (src[ 4]+src[ 9])*3 - (src[ 3]+src[10]));\
            OP(dst[ 7], (src[ 7]+src[ 8])*20 - (src[ 6]+src[ 9])*6 + (src[ 5]+src[10])*3 - (src[ 4]+src[11]));\
            OP(dst[ 8], (src[ 8]+src[ 9])*20 - (src[ 7]+src[10])*6 + (src[ 6]+src[11])*3 - (src[ 5]+src[12]));\
            OP(dst[ 9], (src[ 9]+src[10])*20 - (src[ 8]+src[11])*6 + (src[ 7]+src[12])*3 - (src[ 6]+src[13]));\
            OP(dst[10], (src[10]+src[11])*20 - (src[ 9]+src[12])*6 + (src[ 8]+src[13])*3 - (src[ 7]+src[14]));\
            OP(dst[11], (src[11]+src[12])*20 - (src[10]+src[13])*6 + (src[ 9]+src[14])*3 - (src[ 8]+src[15]));\
            OP(dst[12], (src[12]+src[13])*20 - (src[11]+src[14])*6 + (src[10]+src[15])*3 - (src[ 9]+src[16]));\
            OP(dst[13], (src[13]+src[14])*20 - (src[12]+src[15])*6 + (src[11]+src[16])*3 - (src[10]+src[16]));\
            OP(dst[14], (src[14]+src[15])*20 - (src[13]+src[16])*6 + (src[12]+src[16])*3 - (src[11]+src[15]));\
            OP(dst[15], (src[15]+src[16])*20 - (src[14]+src[16])*6 + (src[13]+src[15])*3 - (src[12]+src[14]));\
            dst+=dstStride;\
            src+=srcStride;\
        }\
    }\
    \
    
    static void OPNAME ## mpeg4_qpel16_v_lowpass(uint8_t *dst, uint8_t *src, int dstStride, int srcStride){\
    
        uint8_t *cm = ff_cropTbl + MAX_NEG_CROP;\
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
        int i;\
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
        const int w=16;\
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
        for(i=0; i<w; i++)\
        {\
            const int src0= src[0*srcStride];\
            const int src1= src[1*srcStride];\
            const int src2= src[2*srcStride];\
            const int src3= src[3*srcStride];\
            const int src4= src[4*srcStride];\
            const int src5= src[5*srcStride];\
            const int src6= src[6*srcStride];\
            const int src7= src[7*srcStride];\
            const int src8= src[8*srcStride];\
            const int src9= src[9*srcStride];\
            const int src10= src[10*srcStride];\
            const int src11= src[11*srcStride];\
            const int src12= src[12*srcStride];\
            const int src13= src[13*srcStride];\
            const int src14= src[14*srcStride];\
            const int src15= src[15*srcStride];\
            const int src16= src[16*srcStride];\
            OP(dst[ 0*dstStride], (src0 +src1 )*20 - (src0 +src2 )*6 + (src1 +src3 )*3 - (src2 +src4 ));\
            OP(dst[ 1*dstStride], (src1 +src2 )*20 - (src0 +src3 )*6 + (src0 +src4 )*3 - (src1 +src5 ));\
            OP(dst[ 2*dstStride], (src2 +src3 )*20 - (src1 +src4 )*6 + (src0 +src5 )*3 - (src0 +src6 ));\
            OP(dst[ 3*dstStride], (src3 +src4 )*20 - (src2 +src5 )*6 + (src1 +src6 )*3 - (src0 +src7 ));\
            OP(dst[ 4*dstStride], (src4 +src5 )*20 - (src3 +src6 )*6 + (src2 +src7 )*3 - (src1 +src8 ));\
            OP(dst[ 5*dstStride], (src5 +src6 )*20 - (src4 +src7 )*6 + (src3 +src8 )*3 - (src2 +src9 ));\
            OP(dst[ 6*dstStride], (src6 +src7 )*20 - (src5 +src8 )*6 + (src4 +src9 )*3 - (src3 +src10));\
            OP(dst[ 7*dstStride], (src7 +src8 )*20 - (src6 +src9 )*6 + (src5 +src10)*3 - (src4 +src11));\
            OP(dst[ 8*dstStride], (src8 +src9 )*20 - (src7 +src10)*6 + (src6 +src11)*3 - (src5 +src12));\
            OP(dst[ 9*dstStride], (src9 +src10)*20 - (src8 +src11)*6 + (src7 +src12)*3 - (src6 +src13));\
            OP(dst[10*dstStride], (src10+src11)*20 - (src9 +src12)*6 + (src8 +src13)*3 - (src7 +src14));\
            OP(dst[11*dstStride], (src11+src12)*20 - (src10+src13)*6 + (src9 +src14)*3 - (src8 +src15));\
            OP(dst[12*dstStride], (src12+src13)*20 - (src11+src14)*6 + (src10+src15)*3 - (src9 +src16));\
            OP(dst[13*dstStride], (src13+src14)*20 - (src12+src15)*6 + (src11+src16)*3 - (src10+src16));\
            OP(dst[14*dstStride], (src14+src15)*20 - (src13+src16)*6 + (src12+src16)*3 - (src11+src15));\
            OP(dst[15*dstStride], (src15+src16)*20 - (src14+src16)*6 + (src13+src15)*3 - (src12+src14));\
            dst++;\
            src++;\
        }\
    }\
    \
    
    static void OPNAME ## qpel8_mc00_c (uint8_t *dst, uint8_t *src, int stride){\
    
        OPNAME ## pixels8_c(dst, src, stride, 8);\
    
    static void OPNAME ## qpel8_mc10_c(uint8_t *dst, uint8_t *src, int stride){\
        uint8_t half[64];\
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
        put ## RND ## mpeg4_qpel8_h_lowpass(half, src, 8, stride, 8);\
        OPNAME ## pixels8_l2(dst, src, half, stride, stride, 8, 8);\
    
    static void OPNAME ## qpel8_mc20_c(uint8_t *dst, uint8_t *src, int stride){\
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
        OPNAME ## mpeg4_qpel8_h_lowpass(dst, src, stride, stride, 8);\
    
    static void OPNAME ## qpel8_mc30_c(uint8_t *dst, uint8_t *src, int stride){\
        uint8_t half[64];\
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
        put ## RND ## mpeg4_qpel8_h_lowpass(half, src, 8, stride, 8);\
        OPNAME ## pixels8_l2(dst, src+1, half, stride, stride, 8, 8);\
    
    static void OPNAME ## qpel8_mc01_c(uint8_t *dst, uint8_t *src, int stride){\
        uint8_t full[16*9];\
        uint8_t half[64];\
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
        copy_block9(full, src, 16, stride, 9);\
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
        put ## RND ## mpeg4_qpel8_v_lowpass(half, full, 8, 16);\
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
        OPNAME ## pixels8_l2(dst, full, half, stride, 16, 8, 8);\
    
    static void OPNAME ## qpel8_mc02_c(uint8_t *dst, uint8_t *src, int stride){\
        uint8_t full[16*9];\
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
        copy_block9(full, src, 16, stride, 9);\
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
        OPNAME ## mpeg4_qpel8_v_lowpass(dst, full, stride, 16);\
    
    static void OPNAME ## qpel8_mc03_c(uint8_t *dst, uint8_t *src, int stride){\
        uint8_t full[16*9];\
        uint8_t half[64];\
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
        copy_block9(full, src, 16, stride, 9);\
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
        put ## RND ## mpeg4_qpel8_v_lowpass(half, full, 8, 16);\
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
        OPNAME ## pixels8_l2(dst, full+16, half, stride, 16, 8, 8);\
    
    void ff_ ## OPNAME ## qpel8_mc11_old_c(uint8_t *dst, uint8_t *src, int stride){\
        uint8_t full[16*9];\
        uint8_t halfH[72];\
        uint8_t halfV[64];\
        uint8_t halfHV[64];\
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
        copy_block9(full, src, 16, stride, 9);\
        put ## RND ## mpeg4_qpel8_h_lowpass(halfH, full, 8, 16, 9);\
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
        put ## RND ## mpeg4_qpel8_v_lowpass(halfV, full, 8, 16);\
        put ## RND ## mpeg4_qpel8_v_lowpass(halfHV, halfH, 8, 8);\
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
        OPNAME ## pixels8_l4(dst, full, halfH, halfV, halfHV, stride, 16, 8, 8, 8, 8);\
    
    static void OPNAME ## qpel8_mc11_c(uint8_t *dst, uint8_t *src, int stride){\
        uint8_t full[16*9];\
        uint8_t halfH[72];\
        uint8_t halfHV[64];\
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
        copy_block9(full, src, 16, stride, 9);\
        put ## RND ## mpeg4_qpel8_h_lowpass(halfH, full, 8, 16, 9);\
        put ## RND ## pixels8_l2(halfH, halfH, full, 8, 8, 16, 9);\
        put ## RND ## mpeg4_qpel8_v_lowpass(halfHV, halfH, 8, 8);\
        OPNAME ## pixels8_l2(dst, halfH, halfHV, stride, 8, 8, 8);\
    }\
    
    void ff_ ## OPNAME ## qpel8_mc31_old_c(uint8_t *dst, uint8_t *src, int stride){\
        uint8_t full[16*9];\
        uint8_t halfH[72];\
        uint8_t halfV[64];\
        uint8_t halfHV[64];\
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
        copy_block9(full, src, 16, stride, 9);\
        put ## RND ## mpeg4_qpel8_h_lowpass(halfH, full, 8, 16, 9);\
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
        put ## RND ## mpeg4_qpel8_v_lowpass(halfV, full+1, 8, 16);\
        put ## RND ## mpeg4_qpel8_v_lowpass(halfHV, halfH, 8, 8);\
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
        OPNAME ## pixels8_l4(dst, full+1, halfH, halfV, halfHV, stride, 16, 8, 8, 8, 8);\
    
    static void OPNAME ## qpel8_mc31_c(uint8_t *dst, uint8_t *src, int stride){\
        uint8_t full[16*9];\
        uint8_t halfH[72];\
        uint8_t halfHV[64];\
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
        copy_block9(full, src, 16, stride, 9);\
        put ## RND ## mpeg4_qpel8_h_lowpass(halfH, full, 8, 16, 9);\
        put ## RND ## pixels8_l2(halfH, halfH, full+1, 8, 8, 16, 9);\
        put ## RND ## mpeg4_qpel8_v_lowpass(halfHV, halfH, 8, 8);\
        OPNAME ## pixels8_l2(dst, halfH, halfHV, stride, 8, 8, 8);\
    }\
    
    void ff_ ## OPNAME ## qpel8_mc13_old_c(uint8_t *dst, uint8_t *src, int stride){\
        uint8_t full[16*9];\
        uint8_t halfH[72];\
        uint8_t halfV[64];\
        uint8_t halfHV[64];\
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
        copy_block9(full, src, 16, stride, 9);\
        put ## RND ## mpeg4_qpel8_h_lowpass(halfH, full, 8, 16, 9);\
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
        put ## RND ## mpeg4_qpel8_v_lowpass(halfV, full, 8, 16);\
        put ## RND ## mpeg4_qpel8_v_lowpass(halfHV, halfH, 8, 8);\
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
        OPNAME ## pixels8_l4(dst, full+16, halfH+8, halfV, halfHV, stride, 16, 8, 8, 8, 8);\
    
    static void OPNAME ## qpel8_mc13_c(uint8_t *dst, uint8_t *src, int stride){\
        uint8_t full[16*9];\
        uint8_t halfH[72];\
        uint8_t halfHV[64];\
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
        copy_block9(full, src, 16, stride, 9);\
        put ## RND ## mpeg4_qpel8_h_lowpass(halfH, full, 8, 16, 9);\
        put ## RND ## pixels8_l2(halfH, halfH, full, 8, 8, 16, 9);\
        put ## RND ## mpeg4_qpel8_v_lowpass(halfHV, halfH, 8, 8);\
        OPNAME ## pixels8_l2(dst, halfH+8, halfHV, stride, 8, 8, 8);\
    }\
    
    void ff_ ## OPNAME ## qpel8_mc33_old_c(uint8_t *dst, uint8_t *src, int stride){\
        uint8_t full[16*9];\
        uint8_t halfH[72];\
        uint8_t halfV[64];\
        uint8_t halfHV[64];\
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
        copy_block9(full, src, 16, stride, 9);\
        put ## RND ## mpeg4_qpel8_h_lowpass(halfH, full  , 8, 16, 9);\
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
        put ## RND ## mpeg4_qpel8_v_lowpass(halfV, full+1, 8, 16);\
        put ## RND ## mpeg4_qpel8_v_lowpass(halfHV, halfH, 8, 8);\
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
        OPNAME ## pixels8_l4(dst, full+17, halfH+8, halfV, halfHV, stride, 16, 8, 8, 8, 8);\
    
    static void OPNAME ## qpel8_mc33_c(uint8_t *dst, uint8_t *src, int stride){\
        uint8_t full[16*9];\
        uint8_t halfH[72];\
        uint8_t halfHV[64];\
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
        copy_block9(full, src, 16, stride, 9);\
        put ## RND ## mpeg4_qpel8_h_lowpass(halfH, full, 8, 16, 9);\
        put ## RND ## pixels8_l2(halfH, halfH, full+1, 8, 8, 16, 9);\
        put ## RND ## mpeg4_qpel8_v_lowpass(halfHV, halfH, 8, 8);\
        OPNAME ## pixels8_l2(dst, halfH+8, halfHV, stride, 8, 8, 8);\
    }\
    
    static void OPNAME ## qpel8_mc21_c(uint8_t *dst, uint8_t *src, int stride){\
        uint8_t halfH[72];\
        uint8_t halfHV[64];\
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
        put ## RND ## mpeg4_qpel8_h_lowpass(halfH, src, 8, stride, 9);\
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
        put ## RND ## mpeg4_qpel8_v_lowpass(halfHV, halfH, 8, 8);\
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
        OPNAME ## pixels8_l2(dst, halfH, halfHV, stride, 8, 8, 8);\
    
    static void OPNAME ## qpel8_mc23_c(uint8_t *dst, uint8_t *src, int stride){\
        uint8_t halfH[72];\
        uint8_t halfHV[64];\
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
        put ## RND ## mpeg4_qpel8_h_lowpass(halfH, src, 8, stride, 9);\
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
        put ## RND ## mpeg4_qpel8_v_lowpass(halfHV, halfH, 8, 8);\
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
        OPNAME ## pixels8_l2(dst, halfH+8, halfHV, stride, 8, 8, 8);\
    
    void ff_ ## OPNAME ## qpel8_mc12_old_c(uint8_t *dst, uint8_t *src, int stride){\
        uint8_t full[16*9];\
        uint8_t halfH[72];\
        uint8_t halfV[64];\
        uint8_t halfHV[64];\
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
        copy_block9(full, src, 16, stride, 9);\
        put ## RND ## mpeg4_qpel8_h_lowpass(halfH, full, 8, 16, 9);\
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
        put ## RND ## mpeg4_qpel8_v_lowpass(halfV, full, 8, 16);\
        put ## RND ## mpeg4_qpel8_v_lowpass(halfHV, halfH, 8, 8);\
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
        OPNAME ## pixels8_l2(dst, halfV, halfHV, stride, 8, 8, 8);\
    
    static void OPNAME ## qpel8_mc12_c(uint8_t *dst, uint8_t *src, int stride){\
        uint8_t full[16*9];\
        uint8_t halfH[72];\
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
        copy_block9(full, src, 16, stride, 9);\
        put ## RND ## mpeg4_qpel8_h_lowpass(halfH, full, 8, 16, 9);\
        put ## RND ## pixels8_l2(halfH, halfH, full, 8, 8, 16, 9);\
        OPNAME ## mpeg4_qpel8_v_lowpass(dst, halfH, stride, 8);\
    }\
    
    void ff_ ## OPNAME ## qpel8_mc32_old_c(uint8_t *dst, uint8_t *src, int stride){\
        uint8_t full[16*9];\
        uint8_t halfH[72];\
        uint8_t halfV[64];\
        uint8_t halfHV[64];\
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
        copy_block9(full, src, 16, stride, 9);\
        put ## RND ## mpeg4_qpel8_h_lowpass(halfH, full, 8, 16, 9);\
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
        put ## RND ## mpeg4_qpel8_v_lowpass(halfV, full+1, 8, 16);\
        put ## RND ## mpeg4_qpel8_v_lowpass(halfHV, halfH, 8, 8);\
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
        OPNAME ## pixels8_l2(dst, halfV, halfHV, stride, 8, 8, 8);\
    
    static void OPNAME ## qpel8_mc32_c(uint8_t *dst, uint8_t *src, int stride){\
        uint8_t full[16*9];\
        uint8_t halfH[72];\
    
    Michael Niedermayer's avatar
    Michael Niedermayer committed
        copy_block9(full, src, 16, stride, 9);\
        put ## RND ## mpeg4_qpel8_h_lowpass(halfH, full, 8, 16, 9);\
        put ## RND ## pixels8_l2(halfH, halfH, full+1, 8, 8, 16, 9);\
        OPNAME ## mpeg4_qpel8_v_lowpass(dst, halfH, stride, 8);\
    }\