mirror of
https://github.com/alsa-project/alsa-lib.git
synced 2025-12-15 08:56:36 -05:00
Reverted to 1.3 version (race window is smaller)
This commit is contained in:
parent
0b3b4b912d
commit
6ed583287a
1 changed files with 18 additions and 16 deletions
|
|
@ -40,15 +40,14 @@ static void MIX_AREAS1(unsigned int size,
|
||||||
* EBX - sum
|
* EBX - sum
|
||||||
* ECX - old sample
|
* ECX - old sample
|
||||||
* EAX - sample / temporary
|
* EAX - sample / temporary
|
||||||
* EDX - size
|
* EDX - temporary
|
||||||
*/
|
*/
|
||||||
__asm__ __volatile__ (
|
__asm__ __volatile__ (
|
||||||
"\n"
|
"\n"
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* initialization, load EDX, ESI, EDI, EBX registers
|
* initialization, load ESI, EDI, EBX registers
|
||||||
*/
|
*/
|
||||||
"\tmovl %0, %%edx\n"
|
|
||||||
"\tmovl %1, %%edi\n"
|
"\tmovl %1, %%edi\n"
|
||||||
"\tmovl %2, %%esi\n"
|
"\tmovl %2, %%esi\n"
|
||||||
"\tmovl %3, %%ebx\n"
|
"\tmovl %3, %%ebx\n"
|
||||||
|
|
@ -56,7 +55,7 @@ static void MIX_AREAS1(unsigned int size,
|
||||||
/*
|
/*
|
||||||
* while (size-- > 0) {
|
* while (size-- > 0) {
|
||||||
*/
|
*/
|
||||||
"\tcmp $0, %%edx\n"
|
"\tcmp $0, %0\n"
|
||||||
"jz 6f\n"
|
"jz 6f\n"
|
||||||
|
|
||||||
"\t.p2align 4,,15\n"
|
"\t.p2align 4,,15\n"
|
||||||
|
|
@ -65,16 +64,18 @@ static void MIX_AREAS1(unsigned int size,
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* sample = *src;
|
* sample = *src;
|
||||||
|
* sum_sample = *sum;
|
||||||
* if (cmpxchg(*dst, 0, 1) == 0)
|
* if (cmpxchg(*dst, 0, 1) == 0)
|
||||||
* sample -= *sum;
|
* sample -= sum_sample;
|
||||||
* xadd(*sum, sample);
|
* xadd(*sum, sample);
|
||||||
*/
|
*/
|
||||||
"\tmovw $0, %%ax\n"
|
"\tmovw $0, %%ax\n"
|
||||||
"\tmovw $1, %%cx\n"
|
"\tmovw $1, %%cx\n"
|
||||||
|
"\tmovl (%%ebx), %%edx\n"
|
||||||
"\t" LOCK_PREFIX "cmpxchgw %%cx, (%%edi)\n"
|
"\t" LOCK_PREFIX "cmpxchgw %%cx, (%%edi)\n"
|
||||||
"\tmovswl (%%esi), %%ecx\n"
|
"\tmovswl (%%esi), %%ecx\n"
|
||||||
"\tjnz 2f\n"
|
"\tjnz 2f\n"
|
||||||
"\tsubl (%%ebx), %%ecx\n"
|
"\tsubl %%edx, %%ecx\n"
|
||||||
"2:"
|
"2:"
|
||||||
"\t" LOCK_PREFIX "addl %%ecx, (%%ebx)\n"
|
"\t" LOCK_PREFIX "addl %%ecx, (%%ebx)\n"
|
||||||
|
|
||||||
|
|
@ -102,7 +103,7 @@ static void MIX_AREAS1(unsigned int size,
|
||||||
"\tadd %4, %%edi\n"
|
"\tadd %4, %%edi\n"
|
||||||
"\tadd %5, %%esi\n"
|
"\tadd %5, %%esi\n"
|
||||||
"\tadd %6, %%ebx\n"
|
"\tadd %6, %%ebx\n"
|
||||||
"\tdecl %%edx\n"
|
"\tdecl %0\n"
|
||||||
"\tjnz 1b\n"
|
"\tjnz 1b\n"
|
||||||
"\tjmp 6f\n"
|
"\tjmp 6f\n"
|
||||||
|
|
||||||
|
|
@ -120,7 +121,7 @@ static void MIX_AREAS1(unsigned int size,
|
||||||
"\tadd %4, %%edi\n"
|
"\tadd %4, %%edi\n"
|
||||||
"\tadd %5, %%esi\n"
|
"\tadd %5, %%esi\n"
|
||||||
"\tadd %6, %%ebx\n"
|
"\tadd %6, %%ebx\n"
|
||||||
"\tdecl %%edx\n"
|
"\tdecl %0\n"
|
||||||
"\tjnz 1b\n"
|
"\tjnz 1b\n"
|
||||||
"\tjmp 6f\n"
|
"\tjmp 6f\n"
|
||||||
|
|
||||||
|
|
@ -138,7 +139,7 @@ static void MIX_AREAS1(unsigned int size,
|
||||||
"\tadd %4, %%edi\n"
|
"\tadd %4, %%edi\n"
|
||||||
"\tadd %5, %%esi\n"
|
"\tadd %5, %%esi\n"
|
||||||
"\tadd %6, %%ebx\n"
|
"\tadd %6, %%ebx\n"
|
||||||
"\tdecl %%edx\n"
|
"\tdecl %0\n"
|
||||||
"\tjnz 1b\n"
|
"\tjnz 1b\n"
|
||||||
// "\tjmp 6f\n"
|
// "\tjmp 6f\n"
|
||||||
|
|
||||||
|
|
@ -164,15 +165,14 @@ static void MIX_AREAS1_MMX(unsigned int size,
|
||||||
* EBX - sum
|
* EBX - sum
|
||||||
* ECX - old sample
|
* ECX - old sample
|
||||||
* EAX - sample / temporary
|
* EAX - sample / temporary
|
||||||
* EDX - size
|
* EDX - temporary
|
||||||
*/
|
*/
|
||||||
__asm__ __volatile__ (
|
__asm__ __volatile__ (
|
||||||
"\n"
|
"\n"
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* initialization, load EDX, ESI, EDI, EBX registers
|
* initialization, load ESI, EDI, EBX registers
|
||||||
*/
|
*/
|
||||||
"\tmovl %0, %%edx\n"
|
|
||||||
"\tmovl %1, %%edi\n"
|
"\tmovl %1, %%edi\n"
|
||||||
"\tmovl %2, %%esi\n"
|
"\tmovl %2, %%esi\n"
|
||||||
"\tmovl %3, %%ebx\n"
|
"\tmovl %3, %%ebx\n"
|
||||||
|
|
@ -180,7 +180,7 @@ static void MIX_AREAS1_MMX(unsigned int size,
|
||||||
/*
|
/*
|
||||||
* while (size-- > 0) {
|
* while (size-- > 0) {
|
||||||
*/
|
*/
|
||||||
"\tcmp $0, %%edx\n"
|
"\tcmp $0, %0\n"
|
||||||
"jz 6f\n"
|
"jz 6f\n"
|
||||||
|
|
||||||
"\t.p2align 4,,15\n"
|
"\t.p2align 4,,15\n"
|
||||||
|
|
@ -189,16 +189,18 @@ static void MIX_AREAS1_MMX(unsigned int size,
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* sample = *src;
|
* sample = *src;
|
||||||
|
* sum_sample = *sum;
|
||||||
* if (cmpxchg(*dst, 0, 1) == 0)
|
* if (cmpxchg(*dst, 0, 1) == 0)
|
||||||
* sample -= *sum;
|
* sample -= sum_sample;
|
||||||
* xadd(*sum, sample);
|
* xadd(*sum, sample);
|
||||||
*/
|
*/
|
||||||
"\tmovw $0, %%ax\n"
|
"\tmovw $0, %%ax\n"
|
||||||
"\tmovw $1, %%cx\n"
|
"\tmovw $1, %%cx\n"
|
||||||
|
"\tmovl (%%ebx), %%edx\n"
|
||||||
"\t" LOCK_PREFIX "cmpxchgw %%cx, (%%edi)\n"
|
"\t" LOCK_PREFIX "cmpxchgw %%cx, (%%edi)\n"
|
||||||
"\tmovswl (%%esi), %%ecx\n"
|
"\tmovswl (%%esi), %%ecx\n"
|
||||||
"\tjnz 2f\n"
|
"\tjnz 2f\n"
|
||||||
"\tsubl (%%ebx), %%ecx\n"
|
"\tsubl %%edx, %%ecx\n"
|
||||||
"2:"
|
"2:"
|
||||||
"\t" LOCK_PREFIX "addl %%ecx, (%%ebx)\n"
|
"\t" LOCK_PREFIX "addl %%ecx, (%%ebx)\n"
|
||||||
|
|
||||||
|
|
@ -225,7 +227,7 @@ static void MIX_AREAS1_MMX(unsigned int size,
|
||||||
"\tadd %4, %%edi\n"
|
"\tadd %4, %%edi\n"
|
||||||
"\tadd %5, %%esi\n"
|
"\tadd %5, %%esi\n"
|
||||||
"\tadd %6, %%ebx\n"
|
"\tadd %6, %%ebx\n"
|
||||||
"\tdecl %%edx\n"
|
"\tdecl %0\n"
|
||||||
"\tjnz 1b\n"
|
"\tjnz 1b\n"
|
||||||
"\tjmp 6f\n"
|
"\tjmp 6f\n"
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue