Revision e6b1ed69 libavcodec/x86/fft_mmx.asm

View differences:

libavcodec/x86/fft_mmx.asm
51 51
%define M_SQRT1_2 0.70710678118654752440
52 52
ps_root2: times 4 dd M_SQRT1_2
53 53
ps_root2mppm: dd -M_SQRT1_2, M_SQRT1_2, M_SQRT1_2, -M_SQRT1_2
54
ps_p1p1m1p1: dd 0, 0, 1<<31, 0
54 55
ps_m1p1: dd 1<<31, 0
55 56

  
56 57
%assign i 16
......
95 96
    SWAP     %3, %6
96 97
%endmacro
97 98

  
98
; in:  %1={r0,i0,r1,i1} %2={r2,i2,r3,i3}
99
; in:  %1={r0,i0,r2,i2} %2={r1,i1,r3,i3}
99 100
; out: %1={r0,r1,r2,r3} %2={i0,i1,i2,i3}
100 101
%macro T4_SSE 3
101 102
    mova     %3, %1
102
    shufps   %1, %2, 0x64 ; {r0,i0,r3,i2}
103
    shufps   %3, %2, 0xce ; {r1,i1,r2,i3}
103
    addps    %1, %2       ; {t1,t2,t6,t5}
104
    subps    %3, %2       ; {t3,t4,-t8,t7}
105
    xorps    %3, [ps_p1p1m1p1]
104 106
    mova     %2, %1
105
    addps    %1, %3       ; {t1,t2,t6,t5}
106
    subps    %2, %3       ; {t3,t4,t8,t7}
107
    shufps   %1, %3, 0x44 ; {t1,t2,t3,t4}
108
    shufps   %2, %3, 0xbe ; {t6,t5,t7,t8}
107 109
    mova     %3, %1
108
    shufps   %1, %2, 0x44 ; {t1,t2,t3,t4}
109
    shufps   %3, %2, 0xbe ; {t6,t5,t7,t8}
110
    addps    %1, %2       ; {r0,i0,r1,i1}
111
    subps    %3, %2       ; {r2,i2,r3,i3}
110 112
    mova     %2, %1
111
    addps    %1, %3       ; {r0,i0,r1,i1}
112
    subps    %2, %3       ; {r2,i2,r3,i3}
113
    mova     %3, %1
114
    shufps   %1, %2, 0x88 ; {r0,r1,r2,r3}
115
    shufps   %3, %2, 0xdd ; {i0,i1,i2,i3}
116
    SWAP     %2, %3
113
    shufps   %1, %3, 0x88 ; {r0,r1,r2,r3}
114
    shufps   %2, %3, 0xdd ; {i0,i1,i2,i3}
117 115
%endmacro
118 116

  
119
%macro T8_SSE 6 ; r0,i0,r1,i1,t0,t1
120
    mova     %5, %3
121
    shufps   %3, %4, 0x44 ; {r4,i4,r6,i6}
122
    shufps   %5, %4, 0xee ; {r5,i5,r7,i7}
117
; in:  %1={r0,r1,r2,r3} %2={i0,i1,i2,i3} %3={r4,i4,r6,i6} %4={r5,i5,r7,i7}
118
; out: %1={r0,r1,r2,r3} %2={i0,i1,i2,i3} %1={r4,r5,r6,r7} %2={i4,i5,i6,i7}
119
%macro T8_SSE 6
123 120
    mova     %6, %3
124
    subps    %3, %5       ; {r5,i5,r7,i7}
125
    addps    %6, %5       ; {t1,t2,t3,t4}
126
    mova     %5, %3
127
    shufps   %5, %5, 0xb1 ; {i5,r5,i7,r7}
121
    subps    %3, %4       ; {r5,i5,r7,i7}
122
    addps    %6, %4       ; {t1,t2,t3,t4}
123
    mova     %4, %3
124
    shufps   %4, %4, 0xb1 ; {i5,r5,i7,r7}
128 125
    mulps    %3, [ps_root2mppm] ; {-r5,i5,r7,-i7}
129
    mulps    %5, [ps_root2]
130
    addps    %3, %5       ; {t8,t7,ta,t9}
131
    mova     %5, %6
126
    mulps    %4, [ps_root2]
127
    addps    %3, %4       ; {t8,t7,ta,t9}
128
    mova     %4, %6
132 129
    shufps   %6, %3, 0x36 ; {t3,t2,t9,t8}
133
    shufps   %5, %3, 0x9c ; {t1,t4,t7,ta}
130
    shufps   %4, %3, 0x9c ; {t1,t4,t7,ta}
134 131
    mova     %3, %6
135
    addps    %6, %5       ; {t1,t2,t9,ta}
136
    subps    %3, %5       ; {t6,t5,tc,tb}
137
    mova     %5, %6
132
    addps    %6, %4       ; {t1,t2,t9,ta}
133
    subps    %3, %4       ; {t6,t5,tc,tb}
134
    mova     %4, %6
138 135
    shufps   %6, %3, 0xd8 ; {t1,t9,t5,tb}
139
    shufps   %5, %3, 0x8d ; {t2,ta,t6,tc}
136
    shufps   %4, %3, 0x8d ; {t2,ta,t6,tc}
140 137
    mova     %3, %1
141
    mova     %4, %2
138
    mova     %5, %2
142 139
    addps    %1, %6       ; {r0,r1,r2,r3}
143
    addps    %2, %5       ; {i0,i1,i2,i3}
140
    addps    %2, %4       ; {i0,i1,i2,i3}
144 141
    subps    %3, %6       ; {r4,r5,r6,r7}
145
    subps    %4, %5       ; {i4,i5,i6,i7}
142
    subps    %5, %4       ; {i4,i5,i6,i7}
143
    SWAP     %4, %5
146 144
%endmacro
147 145

  
148 146
; scheduled for cpu-bound sizes

Also available in: Unified diff