annotate mp3lib/decode_MMX.c @ 4185:85c90bb8729a

initial stuff. comments welcomed...
author arpi
date Wed, 16 Jan 2002 00:14:59 +0000
parents 5e8231233418
children 3f677202418b
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
4142
nick
parents:
diff changeset
1 /*
nick
parents:
diff changeset
2 * this code comes under GPL
nick
parents:
diff changeset
3 * This code was taken from http://www.mpg123.org
nick
parents:
diff changeset
4 * See ChangeLog of mpg123-0.59s-pre.1 for detail
nick
parents:
diff changeset
5 * Applied to mplayer by Nick Kurshev <nickols_k@mail.ru>
nick
parents:
diff changeset
6 *
nick
parents:
diff changeset
7 * Local ChangeLog:
nick
parents:
diff changeset
8 * - Partial loops unrolling and removing MOVW insn from loops
nick
parents:
diff changeset
9 */
nick
parents:
diff changeset
10 #define real float /* ugly - but only way */
nick
parents:
diff changeset
11
nick
parents:
diff changeset
12 static unsigned long long __attribute__((aligned(8))) null_one = 0x0000ffff0000ffffULL;
nick
parents:
diff changeset
13 static unsigned long long __attribute__((aligned(8))) one_null = 0xffff0000ffff0000ULL;
nick
parents:
diff changeset
14 unsigned long __attribute__((aligned(8))) costab_mmx[] =
nick
parents:
diff changeset
15 {
nick
parents:
diff changeset
16 1056974725,
nick
parents:
diff changeset
17 1057056395,
nick
parents:
diff changeset
18 1057223771,
nick
parents:
diff changeset
19 1057485416,
nick
parents:
diff changeset
20 1057855544,
nick
parents:
diff changeset
21 1058356026,
nick
parents:
diff changeset
22 1059019886,
nick
parents:
diff changeset
23 1059897405,
nick
parents:
diff changeset
24 1061067246,
nick
parents:
diff changeset
25 1062657950,
nick
parents:
diff changeset
26 1064892987,
nick
parents:
diff changeset
27 1066774581,
nick
parents:
diff changeset
28 1069414683,
nick
parents:
diff changeset
29 1073984175,
nick
parents:
diff changeset
30 1079645762,
nick
parents:
diff changeset
31 1092815430,
nick
parents:
diff changeset
32 1057005197,
nick
parents:
diff changeset
33 1057342072,
nick
parents:
diff changeset
34 1058087743,
nick
parents:
diff changeset
35 1059427869,
nick
parents:
diff changeset
36 1061799040,
nick
parents:
diff changeset
37 1065862217,
nick
parents:
diff changeset
38 1071413542,
nick
parents:
diff changeset
39 1084439708,
nick
parents:
diff changeset
40 1057128951,
nick
parents:
diff changeset
41 1058664893,
nick
parents:
diff changeset
42 1063675095,
nick
parents:
diff changeset
43 1076102863,
nick
parents:
diff changeset
44 1057655764,
nick
parents:
diff changeset
45 1067924853,
nick
parents:
diff changeset
46 1060439283,
nick
parents:
diff changeset
47 };
nick
parents:
diff changeset
48
nick
parents:
diff changeset
49 void synth_1to1_MMX_s(real *bandPtr, int channel, short *samples,
nick
parents:
diff changeset
50 short *buffs, int *bo)
nick
parents:
diff changeset
51 {
nick
parents:
diff changeset
52
nick
parents:
diff changeset
53 __asm __volatile(
nick
parents:
diff changeset
54 "movl %1,%%ecx\n\t"
nick
parents:
diff changeset
55 "movl %2,%%edi\n\t"
nick
parents:
diff changeset
56 "movl $15,%%ebx\n\t"
nick
parents:
diff changeset
57 "movl %4,%%edx\n\t"
nick
parents:
diff changeset
58 "leal (%%edi,%%ecx,2),%%edi\n\t"
nick
parents:
diff changeset
59 "decl %%ecx\n\t"
nick
parents:
diff changeset
60 "movl %3,%%esi\n\t"
nick
parents:
diff changeset
61 "movl (%%edx),%%eax\n\t"
nick
parents:
diff changeset
62 "jecxz .L1\n\t"
nick
parents:
diff changeset
63 "decl %%eax\n\t"
nick
parents:
diff changeset
64 "andl %%ebx,%%eax\n\t"
nick
parents:
diff changeset
65 "leal 1088(%%esi),%%esi\n\t"
nick
parents:
diff changeset
66 "movl %%eax,(%%edx)\n\t"
nick
parents:
diff changeset
67 ".L1:\n\t"
nick
parents:
diff changeset
68 "leal (%%esi,%%eax,2),%%edx\n\t"
nick
parents:
diff changeset
69 "movl %%eax,%%ebp\n\t"
nick
parents:
diff changeset
70 "incl %%eax\n\t"
nick
parents:
diff changeset
71 "pushl %0\n\t"
nick
parents:
diff changeset
72 "andl %%ebx,%%eax\n\t"
nick
parents:
diff changeset
73 "leal 544(%%esi,%%eax,2),%%ecx\n\t"
nick
parents:
diff changeset
74 "incl %%ebx\n\t"
nick
parents:
diff changeset
75 "testl $1, %%eax\n\t"
nick
parents:
diff changeset
76 "jnz .L2\n\t"
nick
parents:
diff changeset
77 "xchgl %%edx,%%ecx\n\t"
nick
parents:
diff changeset
78 "incl %%ebp\n\t"
nick
parents:
diff changeset
79 "leal 544(%%esi),%%esi\n\t"
nick
parents:
diff changeset
80 ".L2:\n\t"
nick
parents:
diff changeset
81 "emms\n\t"
nick
parents:
diff changeset
82 "pushl %%edx\n\t"
nick
parents:
diff changeset
83 "pushl %%ecx\n\t"
nick
parents:
diff changeset
84 "call *dct64_MMX_func\n\t"
nick
parents:
diff changeset
85 "leal 1(%%ebx), %%ecx\n\t"
nick
parents:
diff changeset
86 "subl %%ebp,%%ebx\n\t"
nick
parents:
diff changeset
87 "pushl %%ecx\n\t"
nick
parents:
diff changeset
88 "leal decwins(%%ebx,%%ebx,1), %%edx\n\t"
nick
parents:
diff changeset
89 "shrl $1, %%ecx\n\t"
nick
parents:
diff changeset
90 ".align 16\n\t"
nick
parents:
diff changeset
91 ".L3:\n\t"
nick
parents:
diff changeset
92 "movq (%%edx),%%mm0\n\t"
nick
parents:
diff changeset
93 "movq 64(%%edx),%%mm4\n\t"
nick
parents:
diff changeset
94 "pmaddwd (%%esi),%%mm0\n\t"
nick
parents:
diff changeset
95 "pmaddwd 32(%%esi),%%mm4\n\t"
nick
parents:
diff changeset
96 "movq 8(%%edx),%%mm1\n\t"
nick
parents:
diff changeset
97 "movq 72(%%edx),%%mm5\n\t"
nick
parents:
diff changeset
98 "pmaddwd 8(%%esi),%%mm1\n\t"
nick
parents:
diff changeset
99 "pmaddwd 40(%%esi),%%mm5\n\t"
nick
parents:
diff changeset
100 "movq 16(%%edx),%%mm2\n\t"
nick
parents:
diff changeset
101 "movq 80(%%edx),%%mm6\n\t"
nick
parents:
diff changeset
102 "pmaddwd 16(%%esi),%%mm2\n\t"
nick
parents:
diff changeset
103 "pmaddwd 48(%%esi),%%mm6\n\t"
nick
parents:
diff changeset
104 "movq 24(%%edx),%%mm3\n\t"
nick
parents:
diff changeset
105 "movq 88(%%edx),%%mm7\n\t"
nick
parents:
diff changeset
106 "pmaddwd 24(%%esi),%%mm3\n\t"
nick
parents:
diff changeset
107 "pmaddwd 56(%%esi),%%mm7\n\t"
nick
parents:
diff changeset
108 "paddd %%mm1,%%mm0\n\t"
nick
parents:
diff changeset
109 "paddd %%mm5,%%mm4\n\t"
nick
parents:
diff changeset
110 "paddd %%mm2,%%mm0\n\t"
nick
parents:
diff changeset
111 "paddd %%mm6,%%mm4\n\t"
nick
parents:
diff changeset
112 "paddd %%mm3,%%mm0\n\t"
nick
parents:
diff changeset
113 "paddd %%mm7,%%mm4\n\t"
nick
parents:
diff changeset
114 "movq %%mm0,%%mm1\n\t"
nick
parents:
diff changeset
115 "movq %%mm4,%%mm5\n\t"
nick
parents:
diff changeset
116 "psrlq $32,%%mm1\n\t"
nick
parents:
diff changeset
117 "psrlq $32,%%mm5\n\t"
nick
parents:
diff changeset
118 "paddd %%mm1,%%mm0\n\t"
nick
parents:
diff changeset
119 "paddd %%mm5,%%mm4\n\t"
nick
parents:
diff changeset
120 "psrad $13,%%mm0\n\t"
nick
parents:
diff changeset
121 "psrad $13,%%mm4\n\t"
nick
parents:
diff changeset
122 "packssdw %%mm0,%%mm0\n\t"
nick
parents:
diff changeset
123 "packssdw %%mm4,%%mm4\n\t"
nick
parents:
diff changeset
124
nick
parents:
diff changeset
125 "movq (%%edi), %%mm1\n\t"
nick
parents:
diff changeset
126 "punpckldq %%mm4, %%mm0\n\t"
nick
parents:
diff changeset
127 "pand one_null, %%mm1\n\t"
nick
parents:
diff changeset
128 "pand null_one, %%mm0\n\t"
nick
parents:
diff changeset
129 "por %%mm0, %%mm1\n\t"
nick
parents:
diff changeset
130 "movq %%mm1,(%%edi)\n\t"
nick
parents:
diff changeset
131
nick
parents:
diff changeset
132 "leal 64(%%esi),%%esi\n\t"
nick
parents:
diff changeset
133 "leal 128(%%edx),%%edx\n\t"
nick
parents:
diff changeset
134 "leal 8(%%edi),%%edi\n\t"
nick
parents:
diff changeset
135
nick
parents:
diff changeset
136 "decl %%ecx\n\t"
nick
parents:
diff changeset
137 "jnz .L3\n\t"
nick
parents:
diff changeset
138
nick
parents:
diff changeset
139 "popl %%ecx\n\t"
nick
parents:
diff changeset
140 "andl $1, %%ecx\n\t"
nick
parents:
diff changeset
141 "jecxz .next_loop\n\t"
nick
parents:
diff changeset
142
nick
parents:
diff changeset
143 "movq (%%edx),%%mm0\n\t"
nick
parents:
diff changeset
144 "pmaddwd (%%esi),%%mm0\n\t"
nick
parents:
diff changeset
145 "movq 8(%%edx),%%mm1\n\t"
nick
parents:
diff changeset
146 "pmaddwd 8(%%esi),%%mm1\n\t"
nick
parents:
diff changeset
147 "movq 16(%%edx),%%mm2\n\t"
nick
parents:
diff changeset
148 "pmaddwd 16(%%esi),%%mm2\n\t"
nick
parents:
diff changeset
149 "movq 24(%%edx),%%mm3\n\t"
nick
parents:
diff changeset
150 "pmaddwd 24(%%esi),%%mm3\n\t"
nick
parents:
diff changeset
151 "paddd %%mm1,%%mm0\n\t"
nick
parents:
diff changeset
152 "paddd %%mm2,%%mm0\n\t"
nick
parents:
diff changeset
153 "paddd %%mm3,%%mm0\n\t"
nick
parents:
diff changeset
154 "movq %%mm0,%%mm1\n\t"
nick
parents:
diff changeset
155 "psrlq $32,%%mm1\n\t"
nick
parents:
diff changeset
156 "paddd %%mm1,%%mm0\n\t"
nick
parents:
diff changeset
157 "psrad $13,%%mm0\n\t"
nick
parents:
diff changeset
158 "packssdw %%mm0,%%mm0\n\t"
nick
parents:
diff changeset
159 "movd %%mm0,%%eax\n\t"
nick
parents:
diff changeset
160 "movw %%ax, (%%edi)\n\t"
nick
parents:
diff changeset
161 "leal 32(%%esi),%%esi\n\t"
nick
parents:
diff changeset
162 "leal 64(%%edx),%%edx\n\t"
nick
parents:
diff changeset
163 "leal 4(%%edi),%%edi\n\t"
nick
parents:
diff changeset
164
nick
parents:
diff changeset
165 ".next_loop:\n\t"
nick
parents:
diff changeset
166 "subl $64,%%esi\n\t"
nick
parents:
diff changeset
167 "movl $7,%%ecx\n\t"
nick
parents:
diff changeset
168 ".align 16\n\t"
nick
parents:
diff changeset
169 ".L4:\n\t"
nick
parents:
diff changeset
170 "movq (%%edx),%%mm0\n\t"
nick
parents:
diff changeset
171 "movq 64(%%edx),%%mm4\n\t"
nick
parents:
diff changeset
172 "pmaddwd (%%esi),%%mm0\n\t"
nick
parents:
diff changeset
173 "pmaddwd -32(%%esi),%%mm4\n\t"
nick
parents:
diff changeset
174 "movq 8(%%edx),%%mm1\n\t"
nick
parents:
diff changeset
175 "movq 72(%%edx),%%mm5\n\t"
nick
parents:
diff changeset
176 "pmaddwd 8(%%esi),%%mm1\n\t"
nick
parents:
diff changeset
177 "pmaddwd -24(%%esi),%%mm5\n\t"
nick
parents:
diff changeset
178 "movq 16(%%edx),%%mm2\n\t"
nick
parents:
diff changeset
179 "movq 80(%%edx),%%mm6\n\t"
nick
parents:
diff changeset
180 "pmaddwd 16(%%esi),%%mm2\n\t"
nick
parents:
diff changeset
181 "pmaddwd -16(%%esi),%%mm6\n\t"
nick
parents:
diff changeset
182 "movq 24(%%edx),%%mm3\n\t"
nick
parents:
diff changeset
183 "movq 88(%%edx),%%mm7\n\t"
nick
parents:
diff changeset
184 "pmaddwd 24(%%esi),%%mm3\n\t"
nick
parents:
diff changeset
185 "pmaddwd -8(%%esi),%%mm7\n\t"
nick
parents:
diff changeset
186 "paddd %%mm1,%%mm0\n\t"
nick
parents:
diff changeset
187 "paddd %%mm5,%%mm4\n\t"
nick
parents:
diff changeset
188 "paddd %%mm2,%%mm0\n\t"
nick
parents:
diff changeset
189 "paddd %%mm6,%%mm4\n\t"
nick
parents:
diff changeset
190 "paddd %%mm3,%%mm0\n\t"
nick
parents:
diff changeset
191 "paddd %%mm7,%%mm4\n\t"
nick
parents:
diff changeset
192 "movq %%mm0,%%mm1\n\t"
nick
parents:
diff changeset
193 "movq %%mm4,%%mm5\n\t"
nick
parents:
diff changeset
194 "psrlq $32,%%mm1\n\t"
nick
parents:
diff changeset
195 "psrlq $32,%%mm5\n\t"
nick
parents:
diff changeset
196 "paddd %%mm0,%%mm1\n\t"
nick
parents:
diff changeset
197 "paddd %%mm4,%%mm5\n\t"
nick
parents:
diff changeset
198 "psrad $13,%%mm1\n\t"
nick
parents:
diff changeset
199 "psrad $13,%%mm5\n\t"
nick
parents:
diff changeset
200 "packssdw %%mm1,%%mm1\n\t"
nick
parents:
diff changeset
201 "packssdw %%mm5,%%mm5\n\t"
nick
parents:
diff changeset
202 "psubd %%mm0,%%mm0\n\t"
nick
parents:
diff changeset
203 "psubd %%mm4,%%mm4\n\t"
nick
parents:
diff changeset
204 "psubsw %%mm1,%%mm0\n\t"
nick
parents:
diff changeset
205 "psubsw %%mm5,%%mm4\n\t"
nick
parents:
diff changeset
206
nick
parents:
diff changeset
207 "movq (%%edi), %%mm1\n\t"
nick
parents:
diff changeset
208 "punpckldq %%mm4, %%mm0\n\t"
nick
parents:
diff changeset
209 "pand one_null, %%mm1\n\t"
nick
parents:
diff changeset
210 "pand null_one, %%mm0\n\t"
nick
parents:
diff changeset
211 "por %%mm0, %%mm1\n\t"
nick
parents:
diff changeset
212 "movq %%mm1,(%%edi)\n\t"
nick
parents:
diff changeset
213
nick
parents:
diff changeset
214 "subl $64,%%esi\n\t"
nick
parents:
diff changeset
215 "addl $128,%%edx\n\t"
nick
parents:
diff changeset
216 "leal 8(%%edi),%%edi\n\t"
nick
parents:
diff changeset
217 "decl %%ecx\n\t"
nick
parents:
diff changeset
218 "jnz .L4\n\t"
nick
parents:
diff changeset
219
nick
parents:
diff changeset
220 "movq (%%edx),%%mm0\n\t"
nick
parents:
diff changeset
221 "pmaddwd (%%esi),%%mm0\n\t"
nick
parents:
diff changeset
222 "movq 8(%%edx),%%mm1\n\t"
nick
parents:
diff changeset
223 "pmaddwd 8(%%esi),%%mm1\n\t"
nick
parents:
diff changeset
224 "movq 16(%%edx),%%mm2\n\t"
nick
parents:
diff changeset
225 "pmaddwd 16(%%esi),%%mm2\n\t"
nick
parents:
diff changeset
226 "movq 24(%%edx),%%mm3\n\t"
nick
parents:
diff changeset
227 "pmaddwd 24(%%esi),%%mm3\n\t"
nick
parents:
diff changeset
228 "paddd %%mm1,%%mm0\n\t"
nick
parents:
diff changeset
229 "paddd %%mm2,%%mm0\n\t"
nick
parents:
diff changeset
230 "paddd %%mm3,%%mm0\n\t"
nick
parents:
diff changeset
231 "movq %%mm0,%%mm1\n\t"
nick
parents:
diff changeset
232 "psrlq $32,%%mm1\n\t"
nick
parents:
diff changeset
233 "paddd %%mm0,%%mm1\n\t"
nick
parents:
diff changeset
234 "psrad $13,%%mm1\n\t"
nick
parents:
diff changeset
235 "packssdw %%mm1,%%mm1\n\t"
nick
parents:
diff changeset
236 "psubd %%mm0,%%mm0\n\t"
nick
parents:
diff changeset
237 "psubsw %%mm1,%%mm0\n\t"
nick
parents:
diff changeset
238 "movd %%mm0,%%eax\n\t"
nick
parents:
diff changeset
239 "movw %%ax,(%%edi)\n\t"
nick
parents:
diff changeset
240 "emms\n\t"
nick
parents:
diff changeset
241 :
nick
parents:
diff changeset
242 :"m"(bandPtr),"m"(channel),"m"(samples),"m"(buffs),"m"(bo)
nick
parents:
diff changeset
243 :"memory","%ebp","%edi","%esi","%ebx");
nick
parents:
diff changeset
244 }