about summary refs log tree commit diff
diff options
context:
space:
mode:
authorAdhemerval Zanella <azanella@linux.vnet.ibm.com>2013-04-14 15:36:20 -0500
committerAdhemerval Zanella <azanella@linux.vnet.ibm.com>2013-04-14 18:23:00 -0500
commitaa5bd1097bbffa3414dc78c4a9e193389ef29e2c (patch)
tree9ee854e5f26c60b5fa974dffdff15a860ec232a3
parent5974755e7efda38f05d7f3ae855873aa8184eab4 (diff)
downloadglibc-aa5bd1097bbffa3414dc78c4a9e193389ef29e2c.tar.gz
glibc-aa5bd1097bbffa3414dc78c4a9e193389ef29e2c.tar.xz
glibc-aa5bd1097bbffa3414dc78c4a9e193389ef29e2c.zip
PowerPC: trunc/truncf multilib for PowerPC32
-rw-r--r--sysdeps/powerpc/powerpc32/fpu/multiarch/Makefile4
-rw-r--r--sysdeps/powerpc/powerpc32/fpu/multiarch/s_trunc-power5+.S (renamed from sysdeps/powerpc/powerpc32/power5+/fpu/s_trunc.S)14
-rw-r--r--sysdeps/powerpc/powerpc32/fpu/multiarch/s_trunc-ppc32.S13
-rw-r--r--sysdeps/powerpc/powerpc32/fpu/multiarch/s_trunc.c40
-rw-r--r--sysdeps/powerpc/powerpc32/fpu/multiarch/s_truncf-power5+.S (renamed from sysdeps/powerpc/powerpc32/power5+/fpu/s_truncf.S)9
-rw-r--r--sysdeps/powerpc/powerpc32/fpu/multiarch/s_truncf-ppc32.S9
-rw-r--r--sysdeps/powerpc/powerpc32/fpu/multiarch/s_truncf.c32
7 files changed, 102 insertions, 19 deletions
diff --git a/sysdeps/powerpc/powerpc32/fpu/multiarch/Makefile b/sysdeps/powerpc/powerpc32/fpu/multiarch/Makefile
index 8c7868e9d1..20c8dd8b1b 100644
--- a/sysdeps/powerpc/powerpc32/fpu/multiarch/Makefile
+++ b/sysdeps/powerpc/powerpc32/fpu/multiarch/Makefile
@@ -21,7 +21,9 @@ libm-sysdep_routines += s_llrintf-power6 s_llrintf-power4 s_llrintf-c \
 			s_floor-power5+ s_floor-ppc32 \
 			s_floorf-power5+ s_floorf-ppc32 \
 			s_round-power5+ s_round-ppc32 \
-			s_roundf-power5+ s_roundf-ppc32
+			s_roundf-power5+ s_roundf-ppc32 \
+                        s_trunc-power5+ s_trunc-ppc32 \
+                        s_truncf-power5+ s_truncf-ppc32
 
 CFLAGS-s_llround.c = -fno-builtin-llroundf
 endif
diff --git a/sysdeps/powerpc/powerpc32/power5+/fpu/s_trunc.S b/sysdeps/powerpc/powerpc32/fpu/multiarch/s_trunc-power5+.S
index 2d4ec5a060..d9fc987134 100644
--- a/sysdeps/powerpc/powerpc32/power5+/fpu/s_trunc.S
+++ b/sysdeps/powerpc/powerpc32/fpu/multiarch/s_trunc-power5+.S
@@ -20,17 +20,7 @@
 #include <math_ldbl_opt.h>
 
 	.machine	"power5"
-EALIGN (__trunc, 4, 0)
+EALIGN (__trunc_power5plus, 4, 0)
 	friz	fp1, fp1
 	blr
-	END (__trunc)
-
-weak_alias (__trunc, trunc)
-
-#ifdef NO_LONG_DOUBLE
-weak_alias (__trunc, truncl)
-strong_alias (__trunc, __truncl)
-#endif
-#if LONG_DOUBLE_COMPAT(libm, GLIBC_2_1)
-compat_symbol (libm, __trunc, truncl, GLIBC_2_1)
-#endif
+END (__trunc_power5plus)
diff --git a/sysdeps/powerpc/powerpc32/fpu/multiarch/s_trunc-ppc32.S b/sysdeps/powerpc/powerpc32/fpu/multiarch/s_trunc-ppc32.S
new file mode 100644
index 0000000000..2e931c6a8c
--- /dev/null
+++ b/sysdeps/powerpc/powerpc32/fpu/multiarch/s_trunc-ppc32.S
@@ -0,0 +1,13 @@
+#include <sysdep.h>
+#include <math_ldbl_opt.h>
+
+#undef weak_alias
+#define weak_alias(a,b)
+#undef strong_alias
+#define strong_alias(a,b)
+#undef compat_symbol
+#define compat_symbol(a,b,c,d)
+
+#define __trunc __trunc_ppc32
+
+#include <sysdeps/powerpc/powerpc32/fpu/s_trunc.S>
diff --git a/sysdeps/powerpc/powerpc32/fpu/multiarch/s_trunc.c b/sysdeps/powerpc/powerpc32/fpu/multiarch/s_trunc.c
new file mode 100644
index 0000000000..a5fa8addf5
--- /dev/null
+++ b/sysdeps/powerpc/powerpc32/fpu/multiarch/s_trunc.c
@@ -0,0 +1,40 @@
+/* Multiple versions of s_trunc.
+   Copyright (C) 2013 Free Software Foundation, Inc.
+   This file is part of the GNU C Library.
+
+   The GNU C Library is free software; you can redistribute it and/or
+   modify it under the terms of the GNU Lesser General Public
+   License as published by the Free Software Foundation; either
+   version 2.1 of the License, or (at your option) any later version.
+
+   The GNU C Library is distributed in the hope that it will be useful,
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+   Lesser General Public License for more details.
+
+   You should have received a copy of the GNU Lesser General Public
+   License along with the GNU C Library; if not, see
+   <http://www.gnu.org/licenses/>.  */
+
+#include <math.h>
+#include <math_ldbl_opt.h>
+#include <shlib-compat.h>
+#include "init-arch.h"
+
+extern __typeof (__trunc) __trunc_ppc32 attribute_hidden;
+extern __typeof (__trunc) __trunc_power5plus attribute_hidden;
+
+libc_ifunc (__trunc,
+	    (hwcap & PPC_FEATURE_POWER5_PLUS)
+	    ? __trunc_power5plus
+            : __trunc_ppc32);
+
+weak_alias (__trunc, trunc)
+
+#ifdef NO_LONG_DOUBLE
+strong_alias (__trunc, __truncl)
+weak_alias (__trunc, truncl)
+#endif
+#if LONG_DOUBLE_COMPAT(libm, GLIBC_2_1)
+compat_symbol (libm, __trunc, truncl, GLIBC_2_1);
+#endif
diff --git a/sysdeps/powerpc/powerpc32/power5+/fpu/s_truncf.S b/sysdeps/powerpc/powerpc32/fpu/multiarch/s_truncf-power5+.S
index 0ca5b5c505..35cd65acab 100644
--- a/sysdeps/powerpc/powerpc32/power5+/fpu/s_truncf.S
+++ b/sysdeps/powerpc/powerpc32/fpu/multiarch/s_truncf-power5+.S
@@ -19,11 +19,8 @@
 #include <sysdep.h>
 
 	.machine	"power5"
-EALIGN (__truncf, 4, 0)
+EALIGN (__truncf_power5plus, 4, 0)
 	friz	fp1, fp1	/* The rounding instructions are double.  */
-	frsp	fp1, fp1	/* But we need to set ooverflow for float.  */
+	frsp	fp1, fp1	/* But we need to set overflow for float.  */
 	blr
-	END (__truncf)
-
-weak_alias (__truncf, truncf)
-
+END (__truncf_power5plus)
diff --git a/sysdeps/powerpc/powerpc32/fpu/multiarch/s_truncf-ppc32.S b/sysdeps/powerpc/powerpc32/fpu/multiarch/s_truncf-ppc32.S
new file mode 100644
index 0000000000..e4fe3b948b
--- /dev/null
+++ b/sysdeps/powerpc/powerpc32/fpu/multiarch/s_truncf-ppc32.S
@@ -0,0 +1,9 @@
+#include <sysdep.h>
+#include <math_ldbl_opt.h>
+
+#undef weak_alias
+#define weak_alias(a,b)
+
+#define __truncf __truncf_ppc32
+
+#include <sysdeps/powerpc/powerpc32/fpu/s_truncf.S>
diff --git a/sysdeps/powerpc/powerpc32/fpu/multiarch/s_truncf.c b/sysdeps/powerpc/powerpc32/fpu/multiarch/s_truncf.c
new file mode 100644
index 0000000000..b0ab04a90e
--- /dev/null
+++ b/sysdeps/powerpc/powerpc32/fpu/multiarch/s_truncf.c
@@ -0,0 +1,32 @@
+/* Multiple versions of s_truncf.
+   Copyright (C) 2013 Free Software Foundation, Inc.
+   This file is part of the GNU C Library.
+
+   The GNU C Library is free software; you can redistribute it and/or
+   modify it under the terms of the GNU Lesser General Public
+   License as published by the Free Software Foundation; either
+   version 2.1 of the License, or (at your option) any later version.
+
+   The GNU C Library is distributed in the hope that it will be useful,
+   but WITHOUT ANY WARRANTY; without even the implied warranty of
+   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+   Lesser General Public License for more details.
+
+   You should have received a copy of the GNU Lesser General Public
+   License along with the GNU C Library; if not, see
+   <http://www.gnu.org/licenses/>.  */
+
+#include <math.h>
+#include <math_ldbl_opt.h>
+#include <shlib-compat.h>
+#include "init-arch.h"
+
+extern __typeof (__truncf) __truncf_ppc32 attribute_hidden;
+extern __typeof (__truncf) __truncf_power5plus attribute_hidden;
+
+libc_ifunc (__truncf,
+	    (hwcap & PPC_FEATURE_POWER5_PLUS)
+	    ? __truncf_power5plus
+            : __truncf_ppc32);
+
+weak_alias (__truncf, truncf)