mirror of
https://gitlab.com/sortix/sortix.git
synced 2023-02-13 20:55:38 -05:00
5980be9b3c
This work is based in part on code from NetBSD libm, libc and kernel. The library is partly public domain and partly BSD-style licensed.
38 lines
594 B
ArmAsm
38 lines
594 B
ArmAsm
/*
|
|
* Written by J.T. Conklin <jtc@NetBSD.org>.
|
|
* Public domain.
|
|
*/
|
|
|
|
/*
|
|
* XXXfvdl might as well split this file.
|
|
*/
|
|
|
|
#include <machine/asm.h>
|
|
|
|
RCSID("$NetBSD: s_copysign.S,v 1.7 2011/06/18 20:49:26 joerg Exp $")
|
|
|
|
#ifdef __x86_64__
|
|
.Lpos:
|
|
.quad 0x8000000000000000
|
|
.Lneg:
|
|
.quad 0x7fffffffffffffff
|
|
#endif
|
|
|
|
|
|
ENTRY(copysign)
|
|
#ifdef __i386__
|
|
movl 16(%esp),%edx
|
|
andl $0x80000000,%edx
|
|
movl 8(%esp),%eax
|
|
andl $0x7fffffff,%eax
|
|
orl %edx,%eax
|
|
movl %eax,8(%esp)
|
|
fldl 4(%esp)
|
|
#else
|
|
movq .Lpos(%rip),%xmm2
|
|
movq .Lneg(%rip),%xmm3
|
|
pand %xmm2,%xmm1
|
|
pand %xmm3,%xmm0
|
|
por %xmm1,%xmm0
|
|
#endif
|
|
ret
|