|
|
@ -26,6 +26,10 @@ SECTION_TEXT |
|
|
|
; int ff_scalarproduct_and_madd_int16(int16_t *v1, int16_t *v2, int16_t *v3, |
|
|
|
; int ff_scalarproduct_and_madd_int16(int16_t *v1, int16_t *v2, int16_t *v3, |
|
|
|
; int order, int mul) |
|
|
|
; int order, int mul) |
|
|
|
cglobal scalarproduct_and_madd_int16, 4,4,8, v1, v2, v3, order, mul |
|
|
|
cglobal scalarproduct_and_madd_int16, 4,4,8, v1, v2, v3, order, mul |
|
|
|
|
|
|
|
%if mmsize == 16 |
|
|
|
|
|
|
|
test orderq, 8 |
|
|
|
|
|
|
|
jnz scalarproduct_and_madd_int16_mmxext; |
|
|
|
|
|
|
|
%endif |
|
|
|
shl orderq, 1 |
|
|
|
shl orderq, 1 |
|
|
|
movd m7, mulm |
|
|
|
movd m7, mulm |
|
|
|
%if mmsize == 16 |
|
|
|
%if mmsize == 16 |
|
|
@ -117,6 +121,8 @@ align 16 |
|
|
|
; int order, int mul) |
|
|
|
; int order, int mul) |
|
|
|
INIT_XMM ssse3 |
|
|
|
INIT_XMM ssse3 |
|
|
|
cglobal scalarproduct_and_madd_int16, 4,5,10, v1, v2, v3, order, mul |
|
|
|
cglobal scalarproduct_and_madd_int16, 4,5,10, v1, v2, v3, order, mul |
|
|
|
|
|
|
|
test orderq, 8 |
|
|
|
|
|
|
|
jnz scalarproduct_and_madd_int16_mmxext; |
|
|
|
shl orderq, 1 |
|
|
|
shl orderq, 1 |
|
|
|
movd m7, mulm |
|
|
|
movd m7, mulm |
|
|
|
pshuflw m7, m7, 0 |
|
|
|
pshuflw m7, m7, 0 |
|
|
|