2011-03-18 16:52:16 +01:00
|
|
|
/*
|
|
|
|
* Written by J.T. Conklin <jtc@NetBSD.org>.
|
|
|
|
* Public domain.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <machine/asm.h>
|
|
|
|
|
|
|
|
/*
|
|
|
|
* XXXfvdl split this file.
|
|
|
|
*/
|
|
|
|
|
2013-12-06 12:04:52 +01:00
|
|
|
RCSID("$NetBSD: s_copysignf.S,v 1.7 2011/06/21 21:52:49 joerg Exp $")
|
2011-03-18 16:52:16 +01:00
|
|
|
|
|
|
|
#ifdef __x86_64__
|
|
|
|
.Lneg:
|
|
|
|
.long 0x7fffffff
|
|
|
|
.Lpos:
|
|
|
|
.long 0x80000000
|
|
|
|
#endif
|
|
|
|
|
|
|
|
ENTRY(copysignf)
|
|
|
|
#ifdef __i386__
|
|
|
|
movl 8(%esp),%edx
|
|
|
|
andl $0x80000000,%edx
|
|
|
|
movl 4(%esp),%eax
|
|
|
|
andl $0x7fffffff,%eax
|
|
|
|
orl %edx,%eax
|
|
|
|
movl %eax,4(%esp)
|
|
|
|
flds 4(%esp)
|
|
|
|
#else
|
2013-12-06 12:04:52 +01:00
|
|
|
movss .Lpos(%rip),%xmm2
|
|
|
|
movss .Lneg(%rip),%xmm3
|
|
|
|
pand %xmm2,%xmm1
|
|
|
|
pand %xmm3,%xmm0
|
|
|
|
por %xmm1,%xmm0
|
2011-03-18 16:52:16 +01:00
|
|
|
#endif
|
|
|
|
ret
|