You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
71 lines
1.2 KiB
71 lines
1.2 KiB
7 months ago
|
# 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
|
||
|
|