aboutsummaryrefslogtreecommitdiffstats
path: root/libavutil
diff options
context:
space:
mode:
authorLynne <dev@lynne.ee>2022-09-27 04:47:46 +0200
committerLynne <dev@lynne.ee>2022-11-24 15:58:31 +0100
commit877e575b5d44adc252d4434d2ec53232b2000956 (patch)
tree43c5b9679188cf750f287c01d5943cad6301484b /libavutil
parentfbe4fd992f4327fcf17b2a76a823c38945b0ea13 (diff)
downloadffmpeg-877e575b5d44adc252d4434d2ec53232b2000956.tar.gz
x86/tx_float: optimize and macro out FFT15
Diffstat (limited to 'libavutil')
-rw-r--r--libavutil/x86/tx_float.asm277
1 files changed, 143 insertions, 134 deletions
diff --git a/libavutil/x86/tx_float.asm b/libavutil/x86/tx_float.asm
index 5ed0007530..0061829581 100644
--- a/libavutil/x86/tx_float.asm
+++ b/libavutil/x86/tx_float.asm
@@ -91,7 +91,7 @@ s16_perm: dd 0, 1, 2, 3, 1, 0, 3, 2
s15_perm: dd 0, 6, 5, 3, 2, 4, 7, 1
-mask_mmmmmmpp: dd NEG, NEG, NEG, NEG, NEG, NEG, POS, POS
+mask_mmppmmmm: dd NEG, NEG, POS, POS, NEG, NEG, NEG, NEG
mask_mmmmpppm: dd NEG, NEG, NEG, NEG, POS, POS, POS, NEG
mask_ppmpmmpm: dd POS, POS, NEG, POS, NEG, NEG, POS, NEG
mask_mppmmpmp: dd NEG, POS, POS, NEG, NEG, POS, NEG, POS
@@ -307,6 +307,132 @@ SECTION .text
%undef perm
%endmacro
+; Single 15-point complex FFT
+; Input:
+; xm0 must contain in[0,1].reim
+; m2 - in[3-6].reim
+; m3 - in[7-11].reim
+; m4 - in[12-15].reim
+; xm5 must contain in[2].reimreim
+;
+; Output:
+; m0, m1, m2 - ACs
+; xm14 - out[0]
+; xm15 - out[10, 5]
+%macro FFT15 0
+ shufps xm1, xm0, xm0, q3223 ; in[1].imrereim
+ shufps xm0, xm0, xm0, q1001 ; in[0].imrereim
+
+ xorps xm1, xm11
+ addps xm1, xm0 ; pc[0,1].imre
+
+ shufps xm0, xm1, xm1, q3232 ; pc[1].reimreim
+ addps xm0, xm5 ; dc[0].reimreim
+
+ mulps xm1, xm9 ; tab[0123]*pc[01]
+
+ shufpd xm6, xm1, xm1, 01b ; pc[1,0].reim
+ xorps xm1, xm11
+ addps xm1, xm1, xm6
+ addsubps xm1, xm5, xm1 ; dc[1,2].reim
+
+ subps m7, m2, m3 ; q[0-3].imre
+ addps m6, m2, m3 ; q[4-7]
+ shufps m7, m7, m7, q2301 ; q[0-3].reim
+
+ addps m5, m4, m6 ; y[0-3]
+
+ vperm2f128 m14, m9, m9, 0x11 ; tab[23232323]
+ vbroadcastsd m15, xm9 ; tab[01010101]
+
+ mulps m6, m14
+ mulps m7, m15
+
+ subps m2, m6, m7 ; k[0-3]
+ addps m3, m6, m7 ; k[4-7]
+
+ shufps m12, m11, m11, q3232 ; ppppmmmm
+
+ addsubps m6, m4, m2 ; k[0-3]
+ addsubps m7, m4, m3 ; k[4-7]
+
+ ; 15pt from here on
+ vpermpd m2, m5, q0123 ; y[3-0]
+ vpermpd m3, m6, q0123 ; k[3-0]
+ vpermpd m4, m7, q0123 ; k[7-4]
+
+ xorps m5, m12
+ xorps m6, m12
+ xorps m7, m12
+
+ addps m2, m5 ; t[0-3]
+ addps m3, m6 ; t[4-7]
+ addps m4, m7 ; t[8-11]
+
+ movlhps xm14, xm2 ; out[0]
+ unpcklpd xm15, xm3, xm4 ; out[10,5]
+ unpckhpd xm5, xm3, xm4 ; out[10,5]
+
+ addps xm14, xm2 ; out[0]
+ addps xm15, xm5 ; out[10,5]
+ addps xm14, xm0 ; out[0]
+ addps xm15, xm1 ; out[10,5]
+
+ shufps m12, m10, m10, q3232 ; tab5 4 5 4 5 8 9 8 9
+ shufps m13, m10, m10, q1010 ; tab5 6 7 6 7 10 11 10 11
+
+ mulps m5, m2, m12 ; t[0-3]
+ mulps m6, m3, m12 ; t[4-7]
+ mulps m7, m4, m12 ; t[8-11]
+
+ mulps m2, m13 ; r[0-3]
+ mulps m3, m13 ; r[4-7]
+ mulps m4, m13 ; r[8-11]
+
+ shufps m5, m5, m5, q1032 ; t[1,0,3,2].reim
+ shufps m6, m6, m6, q1032 ; t[5,4,7,6].reim
+ shufps m7, m7, m7, q1032 ; t[9,8,11,10].reim
+
+ vperm2f128 m13, m11, m11, 0x01 ; mmmmmmpp
+ shufps m12, m11, m11, q3232 ; ppppmmmm
+
+ xorps m5, m13
+ xorps m6, m13
+ xorps m7, m13
+
+ addps m2, m5 ; r[0,1,2,3]
+ addps m3, m6 ; r[4,5,6,7]
+ addps m4, m7 ; r[8,9,10,11]
+
+ shufps m5, m2, m2, q2301
+ shufps m6, m3, m3, q2301
+ shufps m7, m4, m4, q2301
+
+ xorps m2, m12
+ xorps m3, m12
+ xorps m4, m12
+
+ vpermpd m5, m5, q0123
+ vpermpd m6, m6, q0123
+ vpermpd m7, m7, q0123
+
+ addps m5, m2
+ addps m6, m3
+ addps m7, m4
+
+ vpermps m5, m8, m5
+ vpermps m6, m8, m6
+ vpermps m7, m8, m7
+
+ vbroadcastsd m0, xm0 ; dc[0]
+ vpermpd m2, m1, q1111 ; dc[2]
+ vbroadcastsd m1, xm1 ; dc[1]
+
+ addps m0, m5
+ addps m1, m6
+ addps m2, m7
+%endmacro
+
; Cobmines m0...m8 (tx1[even, even, odd, odd], tx2,3[even], tx2,3[odd]) coeffs
; Uses all 16 of registers.
; Output is slightly permuted such that tx2,3's coefficients are interleaved
@@ -1610,11 +1736,10 @@ cglobal fft_pfa_15xM_float, 4, 14, 16, 320, ctx, out, in, stride, len, lut, buf,
imul stride3q, strideq, 3
imul stride5q, strideq, 5
- movaps m13, [mask_mmmmmmpp] ; mmmmmmpp
- vpermpd m12, m13, q0033 ; ppppmmmm
- vextractf128 xm11, m13, 1 ; mmpp
+ movaps m11, [mask_mmppmmmm] ; mmppmmmm
movaps m10, [tab_53_float] ; tab5
movaps xm9, [tab_53_float + 32] ; tab3
+ vpermpd m9, m9, q1110 ; tab[23232323]
movaps m8, [s15_perm]
.dim1:
@@ -1622,144 +1747,28 @@ cglobal fft_pfa_15xM_float, 4, 14, 16, 320, ctx, out, in, stride, len, lut, buf,
lea tgtq, [outq + tmpq*8]
%if %2
- movups xm0, [inq]
-%else
- LOAD64_LUT xm0, inq, lutq, 0, tmpq, m14, xm15 ; in[0,1].reim
-%endif
-
- shufps xm1, xm0, xm0, q3223 ; in[1].imrereim
- shufps xm0, xm0, xm0, q1001 ; in[0].imrereim
-
- xorps xm1, xm11
- addps xm1, xm0 ; pc[0,1].imre
-
-%if %2
- movddup xm14, [inq + 16] ; in[2].reimreim
+ movups xm0, [inq] ; in[0,1].reim
+ movddup xm5, [inq + 16] ; in[2].reimreim
+ movups m2, [inq + mmsize*0 + 24] ; in[3-6].reim
+ movups m3, [inq + mmsize*1 + 24] ; in[7-11].reim
+ movups m4, [inq + mmsize*2 + 24] ; in[12-15].reim
%else
+ LOAD64_LUT xm0, inq, lutq, 0, tmpq, m14, xm15 ; in[0,1].reim
+ LOAD64_LUT m2, inq, lutq, (mmsize/2)*0 + 12, tmpq, m6, m7
+ LOAD64_LUT m3, inq, lutq, (mmsize/2)*1 + 12, tmpq, m14, m15
+ LOAD64_LUT m4, inq, lutq, (mmsize/2)*2 + 12, tmpq, m6, m7
mov tmpd, [lutq + 8]
- movddup xm14, [inq + tmpq*8] ; in[2].reimreim
+ movddup xm5, [inq + tmpq*8] ; in[2].reimreim
%endif
- shufps xm0, xm1, xm1, q3232 ; pc[1].reimreim
- addps xm0, xm14 ; dc[0].reimreim
-
- mulps xm1, xm9 ; tab[0123]*pc[01]
-
- shufpd xm5, xm1, xm1, 01b ; pc[1,0].reim
- xorps xm1, xm11
- addps xm1, xm1, xm5
- addsubps xm1, xm14, xm1 ; dc[1,2].reim
-
-%if %2
- movups m2, [inq + mmsize*0 + 24]
- movups m3, [inq + mmsize*1 + 24]
-%else
- LOAD64_LUT m2, inq, lutq, (mmsize/2)*0 + 12, tmpq, m14, m15
- LOAD64_LUT m3, inq, lutq, (mmsize/2)*1 + 12, tmpq, m14, m15
-%endif
-
- subps m7, m2, m3 ; q[0-3].imre
- addps m6, m2, m3 ; q[4-7]
- shufps m7, m7, m7, q2301 ; q[0-3].reim
-
-%if %2
- movups m4, [inq + mmsize*2 + 24]
-%else
- LOAD64_LUT m4, inq, lutq, (mmsize/2)*2 + 12, tmpq, m14, m15
-%endif
-
- addps m5, m4, m6 ; y[0-3]
-
- vpermpd m14, m9, q1111 ; tab[23232323]
- vbroadcastsd m15, xm9 ; tab[01010101]
-
- mulps m6, m14
- mulps m7, m15
-
- subps m2, m6, m7 ; k[0-3]
- addps m3, m6, m7 ; k[4-7]
-
- addsubps m6, m4, m2 ; k[0-3]
- addsubps m7, m4, m3 ; k[4-7]
-
- ; 15pt from here on
- vpermpd m2, m5, q0123 ; y[3-0]
- vpermpd m3, m6, q0123 ; k[3-0]
- vpermpd m4, m7, q0123 ; k[7-4]
-
- xorps m5, m12
- xorps m6, m12
- xorps m7, m12
-
- addps m2, m5 ; t[0-3]
- addps m3, m6 ; t[4-7]
- addps m4, m7 ; t[8-11]
-
- movlhps xm14, xm2 ; out[0]
- unpcklpd xm7, xm3, xm4 ; out[10,5]
- unpckhpd xm5, xm3, xm4 ; out[10,5]
-
- addps xm14, xm2 ; out[0]
- addps xm7, xm5 ; out[10,5]
- addps xm14, xm0 ; out[0]
- addps xm7, xm1 ; out[10,5]
-
- movhps [tgtq], xm14 ; out[0]
- movhps [tgtq + stride5q*1], xm7 ; out[5]
- movlps [tgtq + stride5q*2], xm7 ; out[10]
- shufps m14, m10, m10, q3232 ; tab5 4 5 4 5 8 9 8 9
- shufps m15, m10, m10, q1010 ; tab5 6 7 6 7 10 11 10 11
-
- mulps m5, m2, m14 ; t[0-3]
- mulps m6, m3, m14 ; t[4-7]
- mulps m7, m4, m14 ; t[8-11]
-
- mulps m2, m15 ; r[0-3]
- mulps m3, m15 ; r[4-7]
- mulps m4, m15 ; r[8-11]
-
- shufps m5, m5, m5, q1032 ; t[1,0,3,2].reim
- shufps m6, m6, m6, q1032 ; t[5,4,7,6].reim
- shufps m7, m7, m7, q1032 ; t[9,8,11,10].reim
+ FFT15
lea tgt5q, [tgtq + stride5q]
lea tmpq, [tgtq + stride5q*2]
- xorps m5, m13
- xorps m6, m13
- xorps m7, m13
-
- addps m2, m5 ; r[0,1,2,3]
- addps m3, m6 ; r[4,5,6,7]
- addps m4, m7 ; r[8,9,10,11]
-
- shufps m5, m2, m2, q2301
- shufps m6, m3, m3, q2301
- shufps m7, m4, m4, q2301
-
- xorps m2, m12
- xorps m3, m12
- xorps m4, m12
-
- vpermpd m5, m5, q0123
- vpermpd m6, m6, q0123
- vpermpd m7, m7, q0123
-
- addps m5, m2
- addps m6, m3
- addps m7, m4
-
- vpermps m5, m8, m5
- vpermps m6, m8, m6
- vpermps m7, m8, m7
-
- vbroadcastsd m0, xm0 ; dc[0]
- vpermpd m2, m1, q1111 ; dc[2]
- vbroadcastsd m1, xm1 ; dc[1]
-
- addps m0, m5
- addps m1, m6
- addps m2, m7
+ movhps [tgtq], xm14 ; out[0]
+ movhps [tgtq + stride5q*1], xm15 ; out[5]
+ movlps [tgtq + stride5q*2], xm15 ; out[10]
vextractf128 xm3, m0, 1
vextractf128 xm4, m1, 1