mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2025-01-24 13:56:33 +02:00
cleanup
Originally committed as revision 9418 to svn://svn.mplayerhq.hu/mplayer/trunk/postproc
This commit is contained in:
parent
0481412aba
commit
e54d94ba4e
@ -345,44 +345,44 @@
|
||||
"packuswb %%mm3, %%mm4 \n\t"\
|
||||
"pxor %%mm7, %%mm7 \n\t"
|
||||
|
||||
#define YSCALEYUV2PACKED1 \
|
||||
"xorl %%eax, %%eax \n\t"\
|
||||
#define YSCALEYUV2PACKED1(index, c) \
|
||||
"xorl "#index", "#index" \n\t"\
|
||||
".balign 16 \n\t"\
|
||||
"1: \n\t"\
|
||||
"movq (%2, %%eax), %%mm3 \n\t" /* uvbuf0[eax]*/\
|
||||
"movq 4096(%2, %%eax), %%mm4 \n\t" /* uvbuf0[eax+2048]*/\
|
||||
"movq (%2, "#index"), %%mm3 \n\t" /* uvbuf0[eax]*/\
|
||||
"movq 4096(%2, "#index"), %%mm4 \n\t" /* uvbuf0[eax+2048]*/\
|
||||
"psraw $7, %%mm3 \n\t" \
|
||||
"psraw $7, %%mm4 \n\t" \
|
||||
"movq (%0, %%eax, 2), %%mm1 \n\t" /*buf0[eax]*/\
|
||||
"movq 8(%0, %%eax, 2), %%mm7 \n\t" /*buf0[eax]*/\
|
||||
"movq (%0, "#index", 2), %%mm1 \n\t" /*buf0[eax]*/\
|
||||
"movq 8(%0, "#index", 2), %%mm7 \n\t" /*buf0[eax]*/\
|
||||
"psraw $7, %%mm1 \n\t" \
|
||||
"psraw $7, %%mm7 \n\t" \
|
||||
|
||||
#define YSCALEYUV2RGB1 \
|
||||
"xorl %%eax, %%eax \n\t"\
|
||||
#define YSCALEYUV2RGB1(index, c) \
|
||||
"xorl "#index", "#index" \n\t"\
|
||||
".balign 16 \n\t"\
|
||||
"1: \n\t"\
|
||||
"movq (%2, %%eax), %%mm3 \n\t" /* uvbuf0[eax]*/\
|
||||
"movq 4096(%2, %%eax), %%mm4 \n\t" /* uvbuf0[eax+2048]*/\
|
||||
"movq (%2, "#index"), %%mm3 \n\t" /* uvbuf0[eax]*/\
|
||||
"movq 4096(%2, "#index"), %%mm4 \n\t" /* uvbuf0[eax+2048]*/\
|
||||
"psraw $4, %%mm3 \n\t" /* uvbuf0[eax] - uvbuf1[eax] >>4*/\
|
||||
"psraw $4, %%mm4 \n\t" /* uvbuf0[eax+2048] - uvbuf1[eax+2048] >>4*/\
|
||||
"psubw "MANGLE(w400)", %%mm3 \n\t" /* (U-128)8*/\
|
||||
"psubw "MANGLE(w400)", %%mm4 \n\t" /* (V-128)8*/\
|
||||
"psubw "U_OFFSET"("#c"), %%mm3 \n\t" /* (U-128)8*/\
|
||||
"psubw "V_OFFSET"("#c"), %%mm4 \n\t" /* (V-128)8*/\
|
||||
"movq %%mm3, %%mm2 \n\t" /* (U-128)8*/\
|
||||
"movq %%mm4, %%mm5 \n\t" /* (V-128)8*/\
|
||||
"pmulhw "MANGLE(ugCoeff)", %%mm3\n\t"\
|
||||
"pmulhw "MANGLE(vgCoeff)", %%mm4\n\t"\
|
||||
"pmulhw "UG_COEFF"("#c"), %%mm3\n\t"\
|
||||
"pmulhw "VG_COEFF"("#c"), %%mm4\n\t"\
|
||||
/* mm2=(U-128)8, mm3=ug, mm4=vg mm5=(V-128)8 */\
|
||||
"movq (%0, %%eax, 2), %%mm1 \n\t" /*buf0[eax]*/\
|
||||
"movq 8(%0, %%eax, 2), %%mm7 \n\t" /*buf0[eax]*/\
|
||||
"movq (%0, "#index", 2), %%mm1 \n\t" /*buf0[eax]*/\
|
||||
"movq 8(%0, "#index", 2), %%mm7 \n\t" /*buf0[eax]*/\
|
||||
"psraw $4, %%mm1 \n\t" /* buf0[eax] - buf1[eax] >>4*/\
|
||||
"psraw $4, %%mm7 \n\t" /* buf0[eax] - buf1[eax] >>4*/\
|
||||
"pmulhw "MANGLE(ubCoeff)", %%mm2\n\t"\
|
||||
"pmulhw "MANGLE(vrCoeff)", %%mm5\n\t"\
|
||||
"psubw "MANGLE(w80)", %%mm1 \n\t" /* 8(Y-16)*/\
|
||||
"psubw "MANGLE(w80)", %%mm7 \n\t" /* 8(Y-16)*/\
|
||||
"pmulhw "MANGLE(yCoeff)", %%mm1 \n\t"\
|
||||
"pmulhw "MANGLE(yCoeff)", %%mm7 \n\t"\
|
||||
"pmulhw "UB_COEFF"("#c"), %%mm2\n\t"\
|
||||
"pmulhw "VR_COEFF"("#c"), %%mm5\n\t"\
|
||||
"psubw "Y_OFFSET"("#c"), %%mm1 \n\t" /* 8(Y-16)*/\
|
||||
"psubw "Y_OFFSET"("#c"), %%mm7 \n\t" /* 8(Y-16)*/\
|
||||
"pmulhw "Y_COEFF"("#c"), %%mm1 \n\t"\
|
||||
"pmulhw "Y_COEFF"("#c"), %%mm7 \n\t"\
|
||||
/* mm1= Y1, mm2=ub, mm3=ug, mm4=vg mm5=vr, mm7=Y2 */\
|
||||
"paddw %%mm3, %%mm4 \n\t"\
|
||||
"movq %%mm2, %%mm0 \n\t"\
|
||||
@ -406,53 +406,53 @@
|
||||
"packuswb %%mm3, %%mm4 \n\t"\
|
||||
"pxor %%mm7, %%mm7 \n\t"
|
||||
|
||||
#define YSCALEYUV2PACKED1b \
|
||||
"xorl %%eax, %%eax \n\t"\
|
||||
#define YSCALEYUV2PACKED1b(index, c) \
|
||||
"xorl "#index", "#index" \n\t"\
|
||||
".balign 16 \n\t"\
|
||||
"1: \n\t"\
|
||||
"movq (%2, %%eax), %%mm2 \n\t" /* uvbuf0[eax]*/\
|
||||
"movq (%3, %%eax), %%mm3 \n\t" /* uvbuf1[eax]*/\
|
||||
"movq 4096(%2, %%eax), %%mm5 \n\t" /* uvbuf0[eax+2048]*/\
|
||||
"movq 4096(%3, %%eax), %%mm4 \n\t" /* uvbuf1[eax+2048]*/\
|
||||
"movq (%2, "#index"), %%mm2 \n\t" /* uvbuf0[eax]*/\
|
||||
"movq (%3, "#index"), %%mm3 \n\t" /* uvbuf1[eax]*/\
|
||||
"movq 4096(%2, "#index"), %%mm5 \n\t" /* uvbuf0[eax+2048]*/\
|
||||
"movq 4096(%3, "#index"), %%mm4 \n\t" /* uvbuf1[eax+2048]*/\
|
||||
"paddw %%mm2, %%mm3 \n\t" /* uvbuf0[eax] + uvbuf1[eax]*/\
|
||||
"paddw %%mm5, %%mm4 \n\t" /* uvbuf0[eax+2048] + uvbuf1[eax+2048]*/\
|
||||
"psrlw $8, %%mm3 \n\t" \
|
||||
"psrlw $8, %%mm4 \n\t" \
|
||||
"movq (%0, %%eax, 2), %%mm1 \n\t" /*buf0[eax]*/\
|
||||
"movq 8(%0, %%eax, 2), %%mm7 \n\t" /*buf0[eax]*/\
|
||||
"movq (%0, "#index", 2), %%mm1 \n\t" /*buf0[eax]*/\
|
||||
"movq 8(%0, "#index", 2), %%mm7 \n\t" /*buf0[eax]*/\
|
||||
"psraw $7, %%mm1 \n\t" \
|
||||
"psraw $7, %%mm7 \n\t"
|
||||
|
||||
// do vertical chrominance interpolation
|
||||
#define YSCALEYUV2RGB1b \
|
||||
"xorl %%eax, %%eax \n\t"\
|
||||
#define YSCALEYUV2RGB1b(index, c) \
|
||||
"xorl "#index", "#index" \n\t"\
|
||||
".balign 16 \n\t"\
|
||||
"1: \n\t"\
|
||||
"movq (%2, %%eax), %%mm2 \n\t" /* uvbuf0[eax]*/\
|
||||
"movq (%3, %%eax), %%mm3 \n\t" /* uvbuf1[eax]*/\
|
||||
"movq 4096(%2, %%eax), %%mm5 \n\t" /* uvbuf0[eax+2048]*/\
|
||||
"movq 4096(%3, %%eax), %%mm4 \n\t" /* uvbuf1[eax+2048]*/\
|
||||
"movq (%2, "#index"), %%mm2 \n\t" /* uvbuf0[eax]*/\
|
||||
"movq (%3, "#index"), %%mm3 \n\t" /* uvbuf1[eax]*/\
|
||||
"movq 4096(%2, "#index"), %%mm5 \n\t" /* uvbuf0[eax+2048]*/\
|
||||
"movq 4096(%3, "#index"), %%mm4 \n\t" /* uvbuf1[eax+2048]*/\
|
||||
"paddw %%mm2, %%mm3 \n\t" /* uvbuf0[eax] + uvbuf1[eax]*/\
|
||||
"paddw %%mm5, %%mm4 \n\t" /* uvbuf0[eax+2048] + uvbuf1[eax+2048]*/\
|
||||
"psrlw $5, %%mm3 \n\t" /*FIXME might overflow*/\
|
||||
"psrlw $5, %%mm4 \n\t" /*FIXME might overflow*/\
|
||||
"psubw "MANGLE(w400)", %%mm3 \n\t" /* (U-128)8*/\
|
||||
"psubw "MANGLE(w400)", %%mm4 \n\t" /* (V-128)8*/\
|
||||
"psubw "U_OFFSET"("#c"), %%mm3 \n\t" /* (U-128)8*/\
|
||||
"psubw "V_OFFSET"("#c"), %%mm4 \n\t" /* (V-128)8*/\
|
||||
"movq %%mm3, %%mm2 \n\t" /* (U-128)8*/\
|
||||
"movq %%mm4, %%mm5 \n\t" /* (V-128)8*/\
|
||||
"pmulhw "MANGLE(ugCoeff)", %%mm3\n\t"\
|
||||
"pmulhw "MANGLE(vgCoeff)", %%mm4\n\t"\
|
||||
"pmulhw "UG_COEFF"("#c"), %%mm3\n\t"\
|
||||
"pmulhw "VG_COEFF"("#c"), %%mm4\n\t"\
|
||||
/* mm2=(U-128)8, mm3=ug, mm4=vg mm5=(V-128)8 */\
|
||||
"movq (%0, %%eax, 2), %%mm1 \n\t" /*buf0[eax]*/\
|
||||
"movq 8(%0, %%eax, 2), %%mm7 \n\t" /*buf0[eax]*/\
|
||||
"movq (%0, "#index", 2), %%mm1 \n\t" /*buf0[eax]*/\
|
||||
"movq 8(%0, "#index", 2), %%mm7 \n\t" /*buf0[eax]*/\
|
||||
"psraw $4, %%mm1 \n\t" /* buf0[eax] - buf1[eax] >>4*/\
|
||||
"psraw $4, %%mm7 \n\t" /* buf0[eax] - buf1[eax] >>4*/\
|
||||
"pmulhw "MANGLE(ubCoeff)", %%mm2\n\t"\
|
||||
"pmulhw "MANGLE(vrCoeff)", %%mm5\n\t"\
|
||||
"psubw "MANGLE(w80)", %%mm1 \n\t" /* 8(Y-16)*/\
|
||||
"psubw "MANGLE(w80)", %%mm7 \n\t" /* 8(Y-16)*/\
|
||||
"pmulhw "MANGLE(yCoeff)", %%mm1 \n\t"\
|
||||
"pmulhw "MANGLE(yCoeff)", %%mm7 \n\t"\
|
||||
"pmulhw "UB_COEFF"("#c"), %%mm2\n\t"\
|
||||
"pmulhw "VR_COEFF"("#c"), %%mm5\n\t"\
|
||||
"psubw "Y_OFFSET"("#c"), %%mm1 \n\t" /* 8(Y-16)*/\
|
||||
"psubw "Y_OFFSET"("#c"), %%mm7 \n\t" /* 8(Y-16)*/\
|
||||
"pmulhw "Y_COEFF"("#c"), %%mm1 \n\t"\
|
||||
"pmulhw "Y_COEFF"("#c"), %%mm7 \n\t"\
|
||||
/* mm1= Y1, mm2=ub, mm3=ug, mm4=vg mm5=vr, mm7=Y2 */\
|
||||
"paddw %%mm3, %%mm4 \n\t"\
|
||||
"movq %%mm2, %%mm0 \n\t"\
|
||||
@ -1259,9 +1259,6 @@ YSCALE_YUV_2_ANYRGB_C(YSCALE_YUV_2_RGB2_C, YSCALE_YUV_2_PACKED2_C)
|
||||
static inline void RENAME(yuv2packed1)(SwsContext *c, uint16_t *buf0, uint16_t *uvbuf0, uint16_t *uvbuf1,
|
||||
uint8_t *dest, int dstW, int uvalpha, int dstFormat, int flags, int y)
|
||||
{
|
||||
#ifdef HAVE_MMX
|
||||
int uvalpha1=uvalpha^4095;
|
||||
#endif
|
||||
const int yalpha1=0;
|
||||
int i;
|
||||
|
||||
@ -1281,41 +1278,54 @@ static inline void RENAME(yuv2packed1)(SwsContext *c, uint16_t *buf0, uint16_t *
|
||||
{
|
||||
case IMGFMT_BGR32:
|
||||
asm volatile(
|
||||
YSCALEYUV2RGB1
|
||||
WRITEBGR32(%4, %5, %%eax)
|
||||
:: "r" (buf0), "r" (buf0), "r" (uvbuf0), "r" (uvbuf1), "r" (dest), "m" (dstW),
|
||||
"m" (yalpha1), "m" (uvalpha1)
|
||||
"movl %%esp, "ESP_OFFSET"(%5) \n\t"
|
||||
"movl %4, %%esp \n\t"
|
||||
YSCALEYUV2RGB1(%%eax, %5)
|
||||
WRITEBGR32(%%esp, 8280(%5), %%eax)
|
||||
"movl "ESP_OFFSET"(%5), %%esp \n\t"
|
||||
|
||||
:: "r" (buf0), "r" (buf1), "r" (uvbuf0), "r" (uvbuf1), "m" (dest),
|
||||
"r" (&c->redDither)
|
||||
: "%eax"
|
||||
);
|
||||
return;
|
||||
case IMGFMT_BGR24:
|
||||
asm volatile(
|
||||
"movl %4, %%ebx \n\t"
|
||||
YSCALEYUV2RGB1
|
||||
WRITEBGR24(%%ebx, %5, %%eax)
|
||||
:: "r" (buf0), "r" (buf0), "r" (uvbuf0), "r" (uvbuf1), "m" (dest), "m" (dstW),
|
||||
"m" (yalpha1), "m" (uvalpha1)
|
||||
: "%eax", "%ebx"
|
||||
"movl %%esp, "ESP_OFFSET"(%5) \n\t"
|
||||
"movl %4, %%esp \n\t"
|
||||
YSCALEYUV2RGB1(%%eax, %5)
|
||||
WRITEBGR24(%%esp, 8280(%5), %%eax)
|
||||
"movl "ESP_OFFSET"(%5), %%esp \n\t"
|
||||
|
||||
:: "r" (buf0), "r" (buf1), "r" (uvbuf0), "r" (uvbuf1), "m" (dest),
|
||||
"r" (&c->redDither)
|
||||
: "%eax"
|
||||
);
|
||||
return;
|
||||
case IMGFMT_BGR15:
|
||||
asm volatile(
|
||||
YSCALEYUV2RGB1
|
||||
"movl %%esp, "ESP_OFFSET"(%5) \n\t"
|
||||
"movl %4, %%esp \n\t"
|
||||
YSCALEYUV2RGB1(%%eax, %5)
|
||||
/* mm2=B, %%mm4=G, %%mm5=R, %%mm7=0 */
|
||||
#ifdef DITHER1XBPP
|
||||
"paddusb "MANGLE(b5Dither)", %%mm2\n\t"
|
||||
"paddusb "MANGLE(g5Dither)", %%mm4\n\t"
|
||||
"paddusb "MANGLE(r5Dither)", %%mm5\n\t"
|
||||
#endif
|
||||
WRITEBGR15(%4, %5, %%eax)
|
||||
:: "r" (buf0), "r" (buf0), "r" (uvbuf0), "r" (uvbuf1), "r" (dest), "m" (dstW),
|
||||
"m" (yalpha1), "m" (uvalpha1)
|
||||
WRITEBGR15(%%esp, 8280(%5), %%eax)
|
||||
"movl "ESP_OFFSET"(%5), %%esp \n\t"
|
||||
|
||||
:: "r" (buf0), "r" (buf1), "r" (uvbuf0), "r" (uvbuf1), "m" (dest),
|
||||
"r" (&c->redDither)
|
||||
: "%eax"
|
||||
);
|
||||
return;
|
||||
case IMGFMT_BGR16:
|
||||
asm volatile(
|
||||
YSCALEYUV2RGB1
|
||||
"movl %%esp, "ESP_OFFSET"(%5) \n\t"
|
||||
"movl %4, %%esp \n\t"
|
||||
YSCALEYUV2RGB1(%%eax, %5)
|
||||
/* mm2=B, %%mm4=G, %%mm5=R, %%mm7=0 */
|
||||
#ifdef DITHER1XBPP
|
||||
"paddusb "MANGLE(b5Dither)", %%mm2\n\t"
|
||||
@ -1323,18 +1333,24 @@ static inline void RENAME(yuv2packed1)(SwsContext *c, uint16_t *buf0, uint16_t *
|
||||
"paddusb "MANGLE(r5Dither)", %%mm5\n\t"
|
||||
#endif
|
||||
|
||||
WRITEBGR16(%4, %5, %%eax)
|
||||
:: "r" (buf0), "r" (buf0), "r" (uvbuf0), "r" (uvbuf1), "r" (dest), "m" (dstW),
|
||||
"m" (yalpha1), "m" (uvalpha1)
|
||||
WRITEBGR16(%%esp, 8280(%5), %%eax)
|
||||
"movl "ESP_OFFSET"(%5), %%esp \n\t"
|
||||
|
||||
:: "r" (buf0), "r" (buf1), "r" (uvbuf0), "r" (uvbuf1), "m" (dest),
|
||||
"r" (&c->redDither)
|
||||
: "%eax"
|
||||
);
|
||||
return;
|
||||
case IMGFMT_YUY2:
|
||||
asm volatile(
|
||||
YSCALEYUV2PACKED1
|
||||
WRITEYUY2(%4, %5, %%eax)
|
||||
:: "r" (buf0), "r" (buf0), "r" (uvbuf0), "r" (uvbuf1), "r" (dest), "m" (dstW),
|
||||
"m" (yalpha1), "m" (uvalpha1)
|
||||
"movl %%esp, "ESP_OFFSET"(%5) \n\t"
|
||||
"movl %4, %%esp \n\t"
|
||||
YSCALEYUV2PACKED1(%%eax, %5)
|
||||
WRITEYUY2(%%esp, 8280(%5), %%eax)
|
||||
"movl "ESP_OFFSET"(%5), %%esp \n\t"
|
||||
|
||||
:: "r" (buf0), "r" (buf1), "r" (uvbuf0), "r" (uvbuf1), "m" (dest),
|
||||
"r" (&c->redDither)
|
||||
: "%eax"
|
||||
);
|
||||
return;
|
||||
@ -1346,41 +1362,54 @@ static inline void RENAME(yuv2packed1)(SwsContext *c, uint16_t *buf0, uint16_t *
|
||||
{
|
||||
case IMGFMT_BGR32:
|
||||
asm volatile(
|
||||
YSCALEYUV2RGB1b
|
||||
WRITEBGR32(%4, %5, %%eax)
|
||||
:: "r" (buf0), "r" (buf0), "r" (uvbuf0), "r" (uvbuf1), "r" (dest), "m" (dstW),
|
||||
"m" (yalpha1), "m" (uvalpha1)
|
||||
"movl %%esp, "ESP_OFFSET"(%5) \n\t"
|
||||
"movl %4, %%esp \n\t"
|
||||
YSCALEYUV2RGB1b(%%eax, %5)
|
||||
WRITEBGR32(%%esp, 8280(%5), %%eax)
|
||||
"movl "ESP_OFFSET"(%5), %%esp \n\t"
|
||||
|
||||
:: "r" (buf0), "r" (buf1), "r" (uvbuf0), "r" (uvbuf1), "m" (dest),
|
||||
"r" (&c->redDither)
|
||||
: "%eax"
|
||||
);
|
||||
return;
|
||||
case IMGFMT_BGR24:
|
||||
asm volatile(
|
||||
"movl %4, %%ebx \n\t"
|
||||
YSCALEYUV2RGB1b
|
||||
WRITEBGR24(%%ebx, %5, %%eax)
|
||||
:: "r" (buf0), "r" (buf0), "r" (uvbuf0), "r" (uvbuf1), "m" (dest), "m" (dstW),
|
||||
"m" (yalpha1), "m" (uvalpha1)
|
||||
: "%eax", "%ebx"
|
||||
"movl %%esp, "ESP_OFFSET"(%5) \n\t"
|
||||
"movl %4, %%esp \n\t"
|
||||
YSCALEYUV2RGB1b(%%eax, %5)
|
||||
WRITEBGR24(%%esp, 8280(%5), %%eax)
|
||||
"movl "ESP_OFFSET"(%5), %%esp \n\t"
|
||||
|
||||
:: "r" (buf0), "r" (buf1), "r" (uvbuf0), "r" (uvbuf1), "m" (dest),
|
||||
"r" (&c->redDither)
|
||||
: "%eax"
|
||||
);
|
||||
return;
|
||||
case IMGFMT_BGR15:
|
||||
asm volatile(
|
||||
YSCALEYUV2RGB1b
|
||||
"movl %%esp, "ESP_OFFSET"(%5) \n\t"
|
||||
"movl %4, %%esp \n\t"
|
||||
YSCALEYUV2RGB1b(%%eax, %5)
|
||||
/* mm2=B, %%mm4=G, %%mm5=R, %%mm7=0 */
|
||||
#ifdef DITHER1XBPP
|
||||
"paddusb "MANGLE(b5Dither)", %%mm2\n\t"
|
||||
"paddusb "MANGLE(g5Dither)", %%mm4\n\t"
|
||||
"paddusb "MANGLE(r5Dither)", %%mm5\n\t"
|
||||
#endif
|
||||
WRITEBGR15(%4, %5, %%eax)
|
||||
:: "r" (buf0), "r" (buf0), "r" (uvbuf0), "r" (uvbuf1), "r" (dest), "m" (dstW),
|
||||
"m" (yalpha1), "m" (uvalpha1)
|
||||
WRITEBGR15(%%esp, 8280(%5), %%eax)
|
||||
"movl "ESP_OFFSET"(%5), %%esp \n\t"
|
||||
|
||||
:: "r" (buf0), "r" (buf1), "r" (uvbuf0), "r" (uvbuf1), "m" (dest),
|
||||
"r" (&c->redDither)
|
||||
: "%eax"
|
||||
);
|
||||
return;
|
||||
case IMGFMT_BGR16:
|
||||
asm volatile(
|
||||
YSCALEYUV2RGB1b
|
||||
"movl %%esp, "ESP_OFFSET"(%5) \n\t"
|
||||
"movl %4, %%esp \n\t"
|
||||
YSCALEYUV2RGB1b(%%eax, %5)
|
||||
/* mm2=B, %%mm4=G, %%mm5=R, %%mm7=0 */
|
||||
#ifdef DITHER1XBPP
|
||||
"paddusb "MANGLE(b5Dither)", %%mm2\n\t"
|
||||
@ -1388,18 +1417,24 @@ static inline void RENAME(yuv2packed1)(SwsContext *c, uint16_t *buf0, uint16_t *
|
||||
"paddusb "MANGLE(r5Dither)", %%mm5\n\t"
|
||||
#endif
|
||||
|
||||
WRITEBGR16(%4, %5, %%eax)
|
||||
:: "r" (buf0), "r" (buf0), "r" (uvbuf0), "r" (uvbuf1), "r" (dest), "m" (dstW),
|
||||
"m" (yalpha1), "m" (uvalpha1)
|
||||
WRITEBGR16(%%esp, 8280(%5), %%eax)
|
||||
"movl "ESP_OFFSET"(%5), %%esp \n\t"
|
||||
|
||||
:: "r" (buf0), "r" (buf1), "r" (uvbuf0), "r" (uvbuf1), "m" (dest),
|
||||
"r" (&c->redDither)
|
||||
: "%eax"
|
||||
);
|
||||
return;
|
||||
case IMGFMT_YUY2:
|
||||
asm volatile(
|
||||
YSCALEYUV2PACKED1b
|
||||
WRITEYUY2(%4, %5, %%eax)
|
||||
:: "r" (buf0), "r" (buf0), "r" (uvbuf0), "r" (uvbuf1), "r" (dest), "m" (dstW),
|
||||
"m" (yalpha1), "m" (uvalpha1)
|
||||
"movl %%esp, "ESP_OFFSET"(%5) \n\t"
|
||||
"movl %4, %%esp \n\t"
|
||||
YSCALEYUV2PACKED1b(%%eax, %5)
|
||||
WRITEYUY2(%%esp, 8280(%5), %%eax)
|
||||
"movl "ESP_OFFSET"(%5), %%esp \n\t"
|
||||
|
||||
:: "r" (buf0), "r" (buf1), "r" (uvbuf0), "r" (uvbuf1), "m" (dest),
|
||||
"r" (&c->redDither)
|
||||
: "%eax"
|
||||
);
|
||||
return;
|
||||
@ -2762,7 +2797,6 @@ i--;
|
||||
if(vLumFilterSize == 1 && vChrFilterSize == 2) //Unscaled RGB
|
||||
{
|
||||
int chrAlpha= vChrFilter[2*dstY+1];
|
||||
|
||||
RENAME(yuv2packed1)(c, *lumSrcPtr, *chrSrcPtr, *(chrSrcPtr+1),
|
||||
dest, dstW, chrAlpha, dstFormat, flags, dstY);
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user