summaryrefslogtreecommitdiff
path: root/lib/libm/arch/amd64
diff options
context:
space:
mode:
authorMartynas Venckus <martynas@cvs.openbsd.org>2009-04-08 22:30:42 +0000
committerMartynas Venckus <martynas@cvs.openbsd.org>2009-04-08 22:30:42 +0000
commitb614770f1cfeead5d0639ceb07a51056854cbeb3 (patch)
treef696e3438802d20ab246d8e96e02f11712edc45e /lib/libm/arch/amd64
parentd713073343b3f1e0d3b7aa7d9528f61a8ce62dd7 (diff)
remove i386/x86_64 ifdefs. i386 lives @ i387. miod@ agrees
object code matches so this got to be oki
Diffstat (limited to 'lib/libm/arch/amd64')
-rw-r--r--lib/libm/arch/amd64/abi.h28
-rw-r--r--lib/libm/arch/amd64/e_sqrt.S7
-rw-r--r--lib/libm/arch/amd64/e_sqrtf.S7
-rw-r--r--lib/libm/arch/amd64/s_ceil.S22
-rw-r--r--lib/libm/arch/amd64/s_ceilf.S22
-rw-r--r--lib/libm/arch/amd64/s_copysign.S15
-rw-r--r--lib/libm/arch/amd64/s_copysignf.S14
-rw-r--r--lib/libm/arch/amd64/s_floor.S22
-rw-r--r--lib/libm/arch/amd64/s_floorf.S22
-rw-r--r--lib/libm/arch/amd64/s_ilogb.S17
-rw-r--r--lib/libm/arch/amd64/s_ilogbf.S17
11 files changed, 10 insertions, 183 deletions
diff --git a/lib/libm/arch/amd64/abi.h b/lib/libm/arch/amd64/abi.h
index cbfbd02c5f5..fdfc0517c16 100644
--- a/lib/libm/arch/amd64/abi.h
+++ b/lib/libm/arch/amd64/abi.h
@@ -14,8 +14,6 @@
* xmm regs to local variables.
*/
-#ifdef __x86_64__
-
#define ARG_DOUBLE_ONE -8(%rsp)
#define ARG_DOUBLE_TWO -16(%rsp)
#define ARG_FLOAT_ONE -4(%rsp)
@@ -45,29 +43,3 @@
#define FLDL_VAR(x) fldl x(%rip)
-#else
-
-#define ARG_DOUBLE_ONE 4(%esp)
-#define ARG_DOUBLE_TWO 12(%esp)
-#define ARG_FLOAT_ONE 4(%esp)
-#define ARG_FLOAT_TWO 8(%esp)
-
-#define XMM_ONE_ARG_DOUBLE_PROLOGUE
-#define XMM_TWO_ARG_DOUBLE_PROLOGUE
-#define XMM_ONE_ARG_FLOAT_PROLOGUE
-#define XMM_TWO_ARG_FLOAT_PROLOGUE
-
-#define XMM_DOUBLE_EPILOGUE
-#define XMM_FLOAT_EPILOGUE
-
-#ifdef PIC
-#define FLDL_VAR(x) \
- PIC_PROLOGUE ; \
- fldl PIC_GOTOFF(x) ; \
- PIC_EPILOGUE
-#else
-#define FLDL_VAR(x) \
- fldl x
-
-#endif
-#endif
diff --git a/lib/libm/arch/amd64/e_sqrt.S b/lib/libm/arch/amd64/e_sqrt.S
index 65f26380f0e..5b014868c9f 100644
--- a/lib/libm/arch/amd64/e_sqrt.S
+++ b/lib/libm/arch/amd64/e_sqrt.S
@@ -1,4 +1,4 @@
-/* $OpenBSD: e_sqrt.S,v 1.3 2008/09/07 20:36:08 martynas Exp $ */
+/* $OpenBSD: e_sqrt.S,v 1.4 2009/04/08 22:30:41 martynas Exp $ */
/*
* Written by J.T. Conklin <jtc@NetBSD.org>.
* Public domain.
@@ -7,10 +7,5 @@
#include <machine/asm.h>
ENTRY(sqrt)
-#ifdef __i386__
- fldl 4(%esp)
- fsqrt
-#else
sqrtsd %xmm0,%xmm0
-#endif
ret
diff --git a/lib/libm/arch/amd64/e_sqrtf.S b/lib/libm/arch/amd64/e_sqrtf.S
index 599358f70f8..50fd81b84a2 100644
--- a/lib/libm/arch/amd64/e_sqrtf.S
+++ b/lib/libm/arch/amd64/e_sqrtf.S
@@ -1,4 +1,4 @@
-/* $OpenBSD: e_sqrtf.S,v 1.3 2008/09/07 20:36:08 martynas Exp $ */
+/* $OpenBSD: e_sqrtf.S,v 1.4 2009/04/08 22:30:41 martynas Exp $ */
/*
* Written by J.T. Conklin <jtc@NetBSD.org>.
* Public domain.
@@ -7,10 +7,5 @@
#include <machine/asm.h>
ENTRY(sqrtf)
-#ifdef __i386__
- flds 4(%esp)
- fsqrt
-#else
sqrtss %xmm0,%xmm0
-#endif
ret
diff --git a/lib/libm/arch/amd64/s_ceil.S b/lib/libm/arch/amd64/s_ceil.S
index 6ab7aa350db..0208581bf4b 100644
--- a/lib/libm/arch/amd64/s_ceil.S
+++ b/lib/libm/arch/amd64/s_ceil.S
@@ -1,4 +1,4 @@
-/* $OpenBSD: s_ceil.S,v 1.2 2005/08/02 11:17:31 espie Exp $ */
+/* $OpenBSD: s_ceil.S,v 1.3 2009/04/08 22:30:41 martynas Exp $ */
/*
* Written by J.T. Conklin <jtc@NetBSD.org>.
* Public domain.
@@ -9,25 +9,6 @@
#include "abi.h"
ENTRY(ceil)
-#ifdef __i386__
- pushl %ebp
- movl %esp,%ebp
- subl $8,%esp
-
- fstcw -4(%ebp) /* store fpu control word */
- movw -4(%ebp),%dx
- orw $0x0800,%dx /* round towards +oo */
- andw $0xfbff,%dx
- movw %dx,-8(%ebp)
- fldcw -8(%ebp) /* load modfied control word */
-
- fldl 8(%ebp); /* round */
- frndint
-
- fldcw -4(%ebp) /* restore original control word */
-
- leave
-#else
fstcw -12(%rsp)
movw -12(%rsp),%dx
orw $0x0800,%dx
@@ -40,5 +21,4 @@ ENTRY(ceil)
fldcw -12(%rsp)
fstpl -8(%rsp)
movsd -8(%rsp),%xmm0
-#endif
ret
diff --git a/lib/libm/arch/amd64/s_ceilf.S b/lib/libm/arch/amd64/s_ceilf.S
index 8d726046ecf..a02291eed29 100644
--- a/lib/libm/arch/amd64/s_ceilf.S
+++ b/lib/libm/arch/amd64/s_ceilf.S
@@ -1,4 +1,4 @@
-/* $OpenBSD: s_ceilf.S,v 1.3 2005/08/02 11:17:31 espie Exp $ */
+/* $OpenBSD: s_ceilf.S,v 1.4 2009/04/08 22:30:41 martynas Exp $ */
/*
* Written by J.T. Conklin <jtc@NetBSD.org>.
* Public domain.
@@ -7,25 +7,6 @@
#include <machine/asm.h>
ENTRY(ceilf)
-#ifdef __i386__
- pushl %ebp
- movl %esp,%ebp
- subl $8,%esp
-
- fstcw -4(%ebp) /* store fpu control word */
- movw -4(%ebp),%dx
- orw $0x0800,%dx /* round towards +oo */
- andw $0xfbff,%dx
- movw %dx,-8(%ebp)
- fldcw -8(%ebp) /* load modfied control word */
-
- flds 8(%ebp); /* round */
- frndint
-
- fldcw -4(%ebp) /* restore original control word */
-
- leave
-#else
fstcw -8(%rsp)
movw -8(%rsp),%dx
orw $0x0800,%dx
@@ -38,5 +19,4 @@ ENTRY(ceilf)
fldcw -8(%rsp)
fstps -4(%rsp)
movss -4(%rsp),%xmm0
-#endif
ret
diff --git a/lib/libm/arch/amd64/s_copysign.S b/lib/libm/arch/amd64/s_copysign.S
index 9f5064dd9c1..92efcac557c 100644
--- a/lib/libm/arch/amd64/s_copysign.S
+++ b/lib/libm/arch/amd64/s_copysign.S
@@ -1,4 +1,4 @@
-/* $OpenBSD: s_copysign.S,v 1.2 2005/08/02 11:17:31 espie Exp $ */
+/* $OpenBSD: s_copysign.S,v 1.3 2009/04/08 22:30:41 martynas Exp $ */
/*
* Written by J.T. Conklin <jtc@NetBSD.org>.
* Public domain.
@@ -10,24 +10,12 @@
#include <machine/asm.h>
-#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
#if 0
/*
* XXXfvdl gas doesn't grok this yet.
@@ -48,5 +36,4 @@ ENTRY(copysign)
movl %eax,-4(%rsp)
movsd -8(%rsp),%xmm0
#endif
-#endif
ret
diff --git a/lib/libm/arch/amd64/s_copysignf.S b/lib/libm/arch/amd64/s_copysignf.S
index 3351be2f119..b0e29f8718f 100644
--- a/lib/libm/arch/amd64/s_copysignf.S
+++ b/lib/libm/arch/amd64/s_copysignf.S
@@ -1,4 +1,4 @@
-/* $OpenBSD: s_copysignf.S,v 1.2 2005/08/02 11:17:31 espie Exp $ */
+/* $OpenBSD: s_copysignf.S,v 1.3 2009/04/08 22:30:41 martynas Exp $ */
/*
* Written by J.T. Conklin <jtc@NetBSD.org>.
* Public domain.
@@ -10,23 +10,12 @@
* XXXfvdl split this file.
*/
-#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
#if 0
/*
* XXXfvdl gas doesn't grok this.
@@ -48,5 +37,4 @@ ENTRY(copysignf)
movl %eax,-4(%rsp)
movss -4(%rsp),%xmm0
#endif
-#endif
ret
diff --git a/lib/libm/arch/amd64/s_floor.S b/lib/libm/arch/amd64/s_floor.S
index 433f3eca9a2..aa611f76940 100644
--- a/lib/libm/arch/amd64/s_floor.S
+++ b/lib/libm/arch/amd64/s_floor.S
@@ -1,4 +1,4 @@
-/* $OpenBSD: s_floor.S,v 1.2 2005/08/02 11:17:31 espie Exp $ */
+/* $OpenBSD: s_floor.S,v 1.3 2009/04/08 22:30:41 martynas Exp $ */
/*
* Written by J.T. Conklin <jtc@NetBSD.org>.
* Public domain.
@@ -7,25 +7,6 @@
#include <machine/asm.h>
ENTRY(floor)
-#ifdef __i386__
- pushl %ebp
- movl %esp,%ebp
- subl $8,%esp
-
- fstcw -4(%ebp) /* store fpu control word */
- movw -4(%ebp),%dx
- orw $0x0400,%dx /* round towards -oo */
- andw $0xf7ff,%dx
- movw %dx,-8(%ebp)
- fldcw -8(%ebp) /* load modfied control word */
-
- fldl 8(%ebp); /* round */
- frndint
-
- fldcw -4(%ebp) /* restore original control word */
-
- leave
-#else
movsd %xmm0, -8(%rsp)
fstcw -12(%rsp)
movw -12(%rsp),%dx
@@ -38,5 +19,4 @@ ENTRY(floor)
fldcw -12(%rsp)
fstpl -8(%rsp)
movsd -8(%rsp),%xmm0
-#endif
ret
diff --git a/lib/libm/arch/amd64/s_floorf.S b/lib/libm/arch/amd64/s_floorf.S
index 4159469991f..66bef665dd0 100644
--- a/lib/libm/arch/amd64/s_floorf.S
+++ b/lib/libm/arch/amd64/s_floorf.S
@@ -1,4 +1,4 @@
-/* $OpenBSD: s_floorf.S,v 1.3 2007/04/20 21:12:31 martynas Exp $ */
+/* $OpenBSD: s_floorf.S,v 1.4 2009/04/08 22:30:41 martynas Exp $ */
/*
* Written by J.T. Conklin <jtc@NetBSD.org>.
* Public domain.
@@ -7,25 +7,6 @@
#include <machine/asm.h>
ENTRY(floorf)
-#ifdef __i386__
- pushl %ebp
- movl %esp,%ebp
- subl $8,%esp
-
- fstcw -4(%ebp) /* store fpu control word */
- movw -4(%ebp),%dx
- orw $0x0400,%dx /* round towards -oo */
- andw $0xf7ff,%dx
- movw %dx,-8(%ebp)
- fldcw -8(%ebp) /* load modfied control word */
-
- flds 8(%ebp); /* round */
- frndint
-
- fldcw -4(%ebp) /* restore original control word */
-
- leave
-#else
movss %xmm0, -4(%rsp)
fstcw -8(%rsp)
movw -8(%rsp),%dx
@@ -38,5 +19,4 @@ ENTRY(floorf)
fldcw -8(%rsp)
fstps -4(%rsp)
movss -4(%rsp),%xmm0
-#endif
ret
diff --git a/lib/libm/arch/amd64/s_ilogb.S b/lib/libm/arch/amd64/s_ilogb.S
index 5610ff29f9a..e8a512e3604 100644
--- a/lib/libm/arch/amd64/s_ilogb.S
+++ b/lib/libm/arch/amd64/s_ilogb.S
@@ -1,4 +1,4 @@
-/* $OpenBSD: s_ilogb.S,v 1.2 2005/08/02 11:17:31 espie Exp $ */
+/* $OpenBSD: s_ilogb.S,v 1.3 2009/04/08 22:30:41 martynas Exp $ */
/*
* Written by J.T. Conklin <jtc@NetBSD.org>.
* Public domain.
@@ -7,25 +7,10 @@
#include <machine/asm.h>
ENTRY(ilogb)
-#ifdef __i386__
- pushl %ebp
- movl %esp,%ebp
- subl $4,%esp
-
- fldl 8(%ebp)
- fxtract
- fstp %st
-
- fistpl -4(%ebp)
- movl -4(%ebp),%eax
-
- leave
-#else
movsd %xmm0,-8(%rsp)
fldl -8(%rsp)
fxtract
fstp %st
fistpl -8(%rsp)
movl -8(%rsp),%eax
-#endif
ret
diff --git a/lib/libm/arch/amd64/s_ilogbf.S b/lib/libm/arch/amd64/s_ilogbf.S
index 0938585cc55..be0809536b9 100644
--- a/lib/libm/arch/amd64/s_ilogbf.S
+++ b/lib/libm/arch/amd64/s_ilogbf.S
@@ -1,4 +1,4 @@
-/* $OpenBSD: s_ilogbf.S,v 1.2 2005/08/02 11:17:31 espie Exp $ */
+/* $OpenBSD: s_ilogbf.S,v 1.3 2009/04/08 22:30:41 martynas Exp $ */
/*
* Written by J.T. Conklin <jtc@NetBSD.org>.
* Public domain.
@@ -7,25 +7,10 @@
#include <machine/asm.h>
ENTRY(ilogbf)
-#ifdef __i386__
- pushl %ebp
- movl %esp,%ebp
- subl $4,%esp
-
- flds 8(%ebp)
- fxtract
- fstp %st
-
- fistpl -4(%ebp)
- movl -4(%ebp),%eax
-
- leave
-#else
movss %xmm0,-4(%rsp)
flds -4(%rsp)
fxtract
fstp %st
fistpl -4(%rsp)
movl -4(%rsp),%eax
-#endif
ret