| # MMX assist routines for peakval |
| # Copyright 2001 Phil Karn, KA9Q |
| # May be used under the terms of the GNU Lesser General Public License (LGPL) |
| |
| .text |
| |
| # Find peak value in signed 16-bit input samples |
| # int peakval_mmx(signed short *in,int cnt); |
| .global peakval_mmx |
| .type peakval_mmx,@function |
| .align 16 |
| peakval_mmx: |
| pushl %ebp |
| movl %esp,%ebp |
| pushl %esi |
| pushl %ecx |
| pushl %ebx |
| |
| movl 8(%ebp),%esi |
| movl 12(%ebp),%ecx |
| |
| pxor %mm7,%mm7 # clear peak |
| |
| 1: subl $4,%ecx |
| jl 2f |
| movq (%esi),%mm0 |
| movq %mm0,%mm1 |
| psraw $15,%mm1 # mm1 = 1's if negative, 0's if positive |
| pxor %mm1,%mm0 # complement negatives |
| psubw %mm1,%mm0 # add 1 to negatives |
| movq %mm7,%mm6 # copy previous peak |
| pcmpgtw %mm0,%mm6 # ff == old peak greater |
| pand %mm6,%mm7 # select old peaks that are greater |
| pandn %mm0,%mm6 # select new values that are greater |
| por %mm6,%mm7 |
| |
| addl $8,%esi |
| jmp 1b |
| |
| 2: movd %mm7,%eax |
| psrlq $16,%mm7 |
| andl $0xffff,%eax |
| |
| movd %mm7,%edx |
| psrlq $16,%mm7 |
| andl $0xffff,%edx |
| cmpl %edx,%eax |
| jnl 3f |
| movl %edx,%eax |
| 3: |
| movd %mm7,%edx |
| psrlq $16,%mm7 |
| andl $0xffff,%edx |
| cmpl %edx,%eax |
| jnl 4f |
| movl %edx,%eax |
| 4: |
| movd %mm7,%edx |
| andl $0xffff,%edx |
| cmpl %edx,%eax |
| jnl 5f |
| movl %edx,%eax |
| 5: |
| emms |
| popl %ebx |
| popl %ecx |
| popl %esi |
| popl %ebp |
| ret |
| |