Chromium Code Reviews| Index: source/row_gcc.cc |
| diff --git a/source/row_gcc.cc b/source/row_gcc.cc |
| index 866bded7901985f6d893ff306190482f90b8ac8b..7793ca1d4a553988e3ae9de3f6a410ae09ae789b 100644 |
| --- a/source/row_gcc.cc |
| +++ b/source/row_gcc.cc |
| @@ -2936,6 +2936,33 @@ void ARGBCopyAlphaRow_AVX2(const uint8* src, uint8* dst, int width) { |
| } |
| #endif // HAS_ARGBCOPYALPHAROW_AVX2 |
| +#ifdef HAS_ARGBEXTRACTALPHAROW_SSE2 |
| +// width in pixels |
| +void ARGBExtractAlphaRow_SSE2(const uint8* src_argb, uint8* dst_a, int width) { |
| + asm volatile ( |
| + LABELALIGN |
| + "1: \n" |
| + "movdqu " MEMACCESS(0) ", %%xmm0 \n" |
| + "movdqu " MEMACCESS2(0x10, 0) ", %%xmm1 \n" |
| + "lea " MEMLEA(0x20, 0) ", %0 \n" |
| + "psrld $0x18, %%xmm0 \n" |
| + "psrld $0x18, %%xmm1 \n" |
| + "packssdw %%xmm1, %%xmm0 \n" |
| + "packuswb %%xmm1, %%xmm0 \n" |
|
fbarchard1
2016/05/25 21:34:35
ditto bit... could use xmm0
packuswb %%xmm0, %%xm
magjed_chromium
2016/05/26 08:28:33
Done.
|
| + "movq %%xmm0," MEMACCESS(1) " \n" |
| + "lea " MEMLEA(0x8, 1) ", %1 \n" |
| + "sub $0x8, %2 \n" |
| + "jg 1b \n" |
| + : "+r"(src_argb), // %0 |
| + "+r"(dst_a), // %1 |
| + "+rm"(width) // %2 |
| + : |
| + : "memory", "cc" |
| + , "xmm0", "xmm1" |
| + ); |
| +} |
| +#endif // HAS_ARGBEXTRACTALPHAROW_SSE2 |
| + |
| #ifdef HAS_ARGBCOPYYTOALPHAROW_SSE2 |
| // width in pixels |
| void ARGBCopyYToAlphaRow_SSE2(const uint8* src, uint8* dst, int width) { |