]> sourceware.org Git - glibc.git/commitdiff
Create a header for sparc ifunc expansion and use it for VIS3 ifuncs.
authorDavid S. Miller <davem@davemloft.net>
Fri, 16 Mar 2012 03:20:49 +0000 (20:20 -0700)
committerDavid S. Miller <davem@davemloft.net>
Fri, 16 Mar 2012 03:29:44 +0000 (20:29 -0700)
* sysdeps/sparc/sparc-ifunc.h: New file.
* sysdeps/sparc/sparc32/sparcv9/fpu/multiarch/s_ceil.S: Use sparc-ifunc.h
* sysdeps/sparc/sparc32/sparcv9/fpu/multiarch/s_ceilf.S: Likewise.
* sysdeps/sparc/sparc32/sparcv9/fpu/multiarch/s_copysign.S: Likewise.
* sysdeps/sparc/sparc32/sparcv9/fpu/multiarch/s_copysignf.S: Likewise.
* sysdeps/sparc/sparc32/sparcv9/fpu/multiarch/s_fabs.S: Likewise.
* sysdeps/sparc/sparc32/sparcv9/fpu/multiarch/s_fabsf.S: Likewise.
* sysdeps/sparc/sparc32/sparcv9/fpu/multiarch/s_floor.S: Likewise.
* sysdeps/sparc/sparc32/sparcv9/fpu/multiarch/s_floorf.S: Likewise.
* sysdeps/sparc/sparc32/sparcv9/fpu/multiarch/s_fmax.S: Likewise.
* sysdeps/sparc/sparc32/sparcv9/fpu/multiarch/s_fmaxf.S: Likewise.
* sysdeps/sparc/sparc32/sparcv9/fpu/multiarch/s_fmin.S: Likewise.
* sysdeps/sparc/sparc32/sparcv9/fpu/multiarch/s_fminf.S: Likewise.
* sysdeps/sparc/sparc32/sparcv9/fpu/multiarch/s_llrint.S: Likewise.
* sysdeps/sparc/sparc32/sparcv9/fpu/multiarch/s_llrintf.S: Likewise.
* sysdeps/sparc/sparc32/sparcv9/fpu/multiarch/s_rint.S: Likewise.
* sysdeps/sparc/sparc32/sparcv9/fpu/multiarch/s_rintf.S: Likewise.
* sysdeps/sparc/sparc32/sparcv9/fpu/multiarch/w_sqrt.S: Likewise.
* sysdeps/sparc/sparc32/sparcv9/fpu/multiarch/w_sqrtf.S: Likewise.
* sysdeps/sparc/sparc64/fpu/multiarch/s_ceil.S: Likewise.
* sysdeps/sparc/sparc64/fpu/multiarch/s_ceilf.S: Likewise.
* sysdeps/sparc/sparc64/fpu/multiarch/s_finite.S: Likewise.
* sysdeps/sparc/sparc64/fpu/multiarch/s_finitef.S: Likewise.
* sysdeps/sparc/sparc64/fpu/multiarch/s_floor.S: Likewise.
* sysdeps/sparc/sparc64/fpu/multiarch/s_floorf.S: Likewise.
* sysdeps/sparc/sparc64/fpu/multiarch/s_fmax.S: Likewise.
* sysdeps/sparc/sparc64/fpu/multiarch/s_fmaxf.S: Likewise.
* sysdeps/sparc/sparc64/fpu/multiarch/s_fmin.S: Likewise.
* sysdeps/sparc/sparc64/fpu/multiarch/s_fminf.S: Likewise.
* sysdeps/sparc/sparc64/fpu/multiarch/s_isinf.S: Likewise.
* sysdeps/sparc/sparc64/fpu/multiarch/s_isinff.S: Likewise.
* sysdeps/sparc/sparc64/fpu/multiarch/s_isnan.S: Likewise.
* sysdeps/sparc/sparc64/fpu/multiarch/s_isnanf.S: Likewise.
* sysdeps/sparc/sparc64/fpu/multiarch/s_lrint.S: Likewise.
* sysdeps/sparc/sparc64/fpu/multiarch/s_lrintf.S: Likewise.
* sysdeps/sparc/sparc64/fpu/multiarch/s_rint.S: Likewise.
* sysdeps/sparc/sparc64/fpu/multiarch/s_rintf.S: Likewise.
* sysdeps/sparc/sparc64/fpu/multiarch/s_signbit.S: Likewise.
* sysdeps/sparc/sparc64/fpu/multiarch/s_signbitf.S: Likewise.

40 files changed:
ChangeLog
sysdeps/sparc/sparc-ifunc.h [new file with mode: 0644]
sysdeps/sparc/sparc32/sparcv9/fpu/multiarch/s_ceil.S
sysdeps/sparc/sparc32/sparcv9/fpu/multiarch/s_ceilf.S
sysdeps/sparc/sparc32/sparcv9/fpu/multiarch/s_copysign.S
sysdeps/sparc/sparc32/sparcv9/fpu/multiarch/s_copysignf.S
sysdeps/sparc/sparc32/sparcv9/fpu/multiarch/s_fabs.S
sysdeps/sparc/sparc32/sparcv9/fpu/multiarch/s_fabsf.S
sysdeps/sparc/sparc32/sparcv9/fpu/multiarch/s_floor.S
sysdeps/sparc/sparc32/sparcv9/fpu/multiarch/s_floorf.S
sysdeps/sparc/sparc32/sparcv9/fpu/multiarch/s_fmax.S
sysdeps/sparc/sparc32/sparcv9/fpu/multiarch/s_fmaxf.S
sysdeps/sparc/sparc32/sparcv9/fpu/multiarch/s_fmin.S
sysdeps/sparc/sparc32/sparcv9/fpu/multiarch/s_fminf.S
sysdeps/sparc/sparc32/sparcv9/fpu/multiarch/s_llrint.S
sysdeps/sparc/sparc32/sparcv9/fpu/multiarch/s_llrintf.S
sysdeps/sparc/sparc32/sparcv9/fpu/multiarch/s_rint.S
sysdeps/sparc/sparc32/sparcv9/fpu/multiarch/s_rintf.S
sysdeps/sparc/sparc32/sparcv9/fpu/multiarch/w_sqrt.S
sysdeps/sparc/sparc32/sparcv9/fpu/multiarch/w_sqrtf.S
sysdeps/sparc/sparc64/fpu/multiarch/s_ceil.S
sysdeps/sparc/sparc64/fpu/multiarch/s_ceilf.S
sysdeps/sparc/sparc64/fpu/multiarch/s_finite.S
sysdeps/sparc/sparc64/fpu/multiarch/s_finitef.S
sysdeps/sparc/sparc64/fpu/multiarch/s_floor.S
sysdeps/sparc/sparc64/fpu/multiarch/s_floorf.S
sysdeps/sparc/sparc64/fpu/multiarch/s_fmax.S
sysdeps/sparc/sparc64/fpu/multiarch/s_fmaxf.S
sysdeps/sparc/sparc64/fpu/multiarch/s_fmin.S
sysdeps/sparc/sparc64/fpu/multiarch/s_fminf.S
sysdeps/sparc/sparc64/fpu/multiarch/s_isinf.S
sysdeps/sparc/sparc64/fpu/multiarch/s_isinff.S
sysdeps/sparc/sparc64/fpu/multiarch/s_isnan.S
sysdeps/sparc/sparc64/fpu/multiarch/s_isnanf.S
sysdeps/sparc/sparc64/fpu/multiarch/s_lrint.S
sysdeps/sparc/sparc64/fpu/multiarch/s_lrintf.S
sysdeps/sparc/sparc64/fpu/multiarch/s_rint.S
sysdeps/sparc/sparc64/fpu/multiarch/s_rintf.S
sysdeps/sparc/sparc64/fpu/multiarch/s_signbit.S
sysdeps/sparc/sparc64/fpu/multiarch/s_signbitf.S

index 276518540a6d59e987b4816c626846fd5a6ac9b9..88f99c37cc5f922142ad5babdf11d3dc06cb01d8 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,45 @@
+2012-03-15  David S. Miller  <davem@davemloft.net>
+
+       * sysdeps/sparc/sparc-ifunc.h: New file.
+       * sysdeps/sparc/sparc32/sparcv9/fpu/multiarch/s_ceil.S: Use sparc-ifunc.h
+       * sysdeps/sparc/sparc32/sparcv9/fpu/multiarch/s_ceilf.S: Likewise.
+       * sysdeps/sparc/sparc32/sparcv9/fpu/multiarch/s_copysign.S: Likewise.
+       * sysdeps/sparc/sparc32/sparcv9/fpu/multiarch/s_copysignf.S: Likewise.
+       * sysdeps/sparc/sparc32/sparcv9/fpu/multiarch/s_fabs.S: Likewise.
+       * sysdeps/sparc/sparc32/sparcv9/fpu/multiarch/s_fabsf.S: Likewise.
+       * sysdeps/sparc/sparc32/sparcv9/fpu/multiarch/s_floor.S: Likewise.
+       * sysdeps/sparc/sparc32/sparcv9/fpu/multiarch/s_floorf.S: Likewise.
+       * sysdeps/sparc/sparc32/sparcv9/fpu/multiarch/s_fmax.S: Likewise.
+       * sysdeps/sparc/sparc32/sparcv9/fpu/multiarch/s_fmaxf.S: Likewise.
+       * sysdeps/sparc/sparc32/sparcv9/fpu/multiarch/s_fmin.S: Likewise.
+       * sysdeps/sparc/sparc32/sparcv9/fpu/multiarch/s_fminf.S: Likewise.
+       * sysdeps/sparc/sparc32/sparcv9/fpu/multiarch/s_llrint.S: Likewise.
+       * sysdeps/sparc/sparc32/sparcv9/fpu/multiarch/s_llrintf.S: Likewise.
+       * sysdeps/sparc/sparc32/sparcv9/fpu/multiarch/s_rint.S: Likewise.
+       * sysdeps/sparc/sparc32/sparcv9/fpu/multiarch/s_rintf.S: Likewise.
+       * sysdeps/sparc/sparc32/sparcv9/fpu/multiarch/w_sqrt.S: Likewise.
+       * sysdeps/sparc/sparc32/sparcv9/fpu/multiarch/w_sqrtf.S: Likewise.
+       * sysdeps/sparc/sparc64/fpu/multiarch/s_ceil.S: Likewise.
+       * sysdeps/sparc/sparc64/fpu/multiarch/s_ceilf.S: Likewise.
+       * sysdeps/sparc/sparc64/fpu/multiarch/s_finite.S: Likewise.
+       * sysdeps/sparc/sparc64/fpu/multiarch/s_finitef.S: Likewise.
+       * sysdeps/sparc/sparc64/fpu/multiarch/s_floor.S: Likewise.
+       * sysdeps/sparc/sparc64/fpu/multiarch/s_floorf.S: Likewise.
+       * sysdeps/sparc/sparc64/fpu/multiarch/s_fmax.S: Likewise.
+       * sysdeps/sparc/sparc64/fpu/multiarch/s_fmaxf.S: Likewise.
+       * sysdeps/sparc/sparc64/fpu/multiarch/s_fmin.S: Likewise.
+       * sysdeps/sparc/sparc64/fpu/multiarch/s_fminf.S: Likewise.
+       * sysdeps/sparc/sparc64/fpu/multiarch/s_isinf.S: Likewise.
+       * sysdeps/sparc/sparc64/fpu/multiarch/s_isinff.S: Likewise.
+       * sysdeps/sparc/sparc64/fpu/multiarch/s_isnan.S: Likewise.
+       * sysdeps/sparc/sparc64/fpu/multiarch/s_isnanf.S: Likewise.
+       * sysdeps/sparc/sparc64/fpu/multiarch/s_lrint.S: Likewise.
+       * sysdeps/sparc/sparc64/fpu/multiarch/s_lrintf.S: Likewise.
+       * sysdeps/sparc/sparc64/fpu/multiarch/s_rint.S: Likewise.
+       * sysdeps/sparc/sparc64/fpu/multiarch/s_rintf.S: Likewise.
+       * sysdeps/sparc/sparc64/fpu/multiarch/s_signbit.S: Likewise.
+       * sysdeps/sparc/sparc64/fpu/multiarch/s_signbitf.S: Likewise.
+
 2012-03-15  Andreas Schwab  <schwab@linux-m68k.org>
 
        * sysdeps/powerpc/fpu/e_hypotf.c: Use double precision instead of
diff --git a/sysdeps/sparc/sparc-ifunc.h b/sysdeps/sparc/sparc-ifunc.h
new file mode 100644 (file)
index 0000000..db53a71
--- /dev/null
@@ -0,0 +1,112 @@
+/* This file is part of the GNU C Library.
+   Copyright (C) 2012 Free Software Foundation, Inc.
+
+   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 <sysdep.h>
+
+#ifdef __ASSEMBLER__
+
+# ifdef SHARED
+
+#  define SPARC_ASM_IFUNC_DFLT(name, dflt)             \
+ENTRY (__##name)                                       \
+       .type   __##name, @gnu_indirect_function;       \
+       SETUP_PIC_REG_LEAF(o3, o5);                     \
+       sethi   %gdop_hix22(dflt), %o1;                 \
+       xor     %o1, %gdop_lox10(dflt), %o1;            \
+       add     %o3, %o1, %o1;                          \
+       retl;                                           \
+        mov    %o1, %o0;                               \
+END (__##name)
+
+#  define SPARC_ASM_IFUNC1(name, m1, f1, dflt)         \
+ENTRY (__##name)                                       \
+       .type   __##name, @gnu_indirect_function;       \
+       SETUP_PIC_REG_LEAF(o3, o5);                     \
+       set     m1, %o1;                                \
+       andcc   %o0, %o1, %g0;                          \
+       be      9f;                                     \
+        nop;                                           \
+       sethi   %gdop_hix22(f1), %o1;                   \
+       xor     %o1, %gdop_lox10(f1), %o1;              \
+       ba      10f;                                    \
+        nop;                                           \
+9:     sethi   %gdop_hix22(dflt), %o1;                 \
+       xor     %o1, %gdop_lox10(dflt), %o1;            \
+10:    add     %o3, %o1, %o1;                          \
+       retl;                                           \
+        mov    %o1, %o0;                               \
+END (__##name)
+
+# else /* SHARED */
+
+# ifdef __arch64__
+#  define SET(SYM, TMP, REG)   setx SYM, TMP, REG
+# else
+#  define SET(SYM, TMP, REG)   set SYM, REG
+# endif
+
+#  define SPARC_ASM_IFUNC_DFLT(name, dflt)             \
+ENTRY (__##name)                                       \
+       .type   __##name, @gnu_indirect_function;       \
+       SET(dflt, %g1, %o1);                            \
+       retl;                                           \
+        mov    %o1, %o0;                               \
+END (__##name)
+
+#  define SPARC_ASM_IFUNC1(name, m1, f1, dflt)         \
+ENTRY (__##name)                                       \
+       .type   __##name, @gnu_indirect_function;       \
+       set     m1, %o1;                                \
+       andcc   %o0, %o1, %g0;                          \
+       be      9f;                                     \
+        nop;                                           \
+       SET(f1, %g1, %o1);                              \
+       ba      10f;                                    \
+        nop;                                           \
+9:     SET(dflt, %g1, %o1);                            \
+10:    retl;                                           \
+        mov    %o1, %o0;                               \
+END (__##name)
+
+# endif /* SHARED */
+
+# ifdef HAVE_AS_VIS3_SUPPORT
+
+#define SPARC_ASM_VIS3_IFUNC(name)                     \
+       SPARC_ASM_IFUNC1(name, HWCAP_SPARC_VIS3,        \
+                        __##name##_vis3, __##name##_generic)
+
+# else /* HAVE_AS_VIS3_SUPPORT */
+
+#define SPARC_ASM_VIS3_IFUNC(name)                     \
+       SPARC_ASM_IFUNC_DFLT(name, __##name##_generic)
+
+# endif /* HAVE_AS_VIS3_SUPPORT */
+
+
+#else  /* __ASSEMBLER__ */
+
+# define sparc_libm_ifunc(name, expr)                                  \
+  extern void *name##_ifunc (int) __asm__ (#name);                     \
+  void *name##_ifunc (int hwcap)                                       \
+  {                                                                    \
+    __typeof (name) *res = expr;                                       \
+    return res;                                                                \
+  }                                                                    \
+  __asm__ (".type " #name ", %gnu_indirect_function");
+
+#endif /* __ASSEMBLER__ */
index f91fda61b91530767f83301fd4afc4c135bb3071..fa4c7c353fdd4226fbf0af3df2074d4a66eed37a 100644 (file)
@@ -1,41 +1,7 @@
-#include <sysdep.h>
+#include <sparc-ifunc.h>
+
+SPARC_ASM_VIS3_IFUNC(ceil)
 
-       .text
-ENTRY(__ceil)
-       .type   __ceil, @gnu_indirect_function
-# ifdef SHARED
-       SETUP_PIC_REG_LEAF(o3, o5)
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-       set     HWCAP_SPARC_VIS3, %o1
-       andcc   %o0, %o1, %g0
-       be      9f
-        nop
-#  ifdef SHARED
-       sethi   %gdop_hix22(__ceil_vis3), %o1
-       xor     %o1, %gdop_lox10(__ceil_vis3), %o1
-#  else
-       set     __ceil_vis3, %o1
-#  endif
-       ba      10f
-        nop
-9:
-# endif
-# ifdef SHARED
-       sethi   %gdop_hix22(__ceil_generic), %o1
-       xor     %o1, %gdop_lox10(__ceil_generic), %o1
-# else
-       set     __ceil_generic, %o1
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-10:
-# endif
-# ifdef SHARED
-       add     %o3, %o1, %o1
-# endif
-       retl
-        mov    %o1, %o0
-END(__ceil)
 weak_alias (__ceil, ceil)
 
 # undef weak_alias
index 048b6195d84cea3fae72b9acd81e3450c7bea1f3..3047dd8faa391771bb8ba0bf5e3008ad383dc978 100644 (file)
@@ -1,41 +1,7 @@
-#include <sysdep.h>
+#include <sparc-ifunc.h>
+
+SPARC_ASM_VIS3_IFUNC(ceilf)
 
-       .text
-ENTRY(__ceilf)
-       .type   __ceilf, @gnu_indirect_function
-# ifdef SHARED
-       SETUP_PIC_REG_LEAF(o3, o5)
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-       set     HWCAP_SPARC_VIS3, %o1
-       andcc   %o0, %o1, %g0
-       be      9f
-        nop
-#  ifdef SHARED
-       sethi   %gdop_hix22(__ceilf_vis3), %o1
-       xor     %o1, %gdop_lox10(__ceilf_vis3), %o1
-#  else
-       set     __ceilf_vis3, %o1
-#  endif
-       ba      10f
-        nop
-9:
-# endif
-# ifdef SHARED
-       sethi   %gdop_hix22(__ceilf_generic), %o1
-       xor     %o1, %gdop_lox10(__ceilf_generic), %o1
-# else
-       set     __ceilf_generic, %o1
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-10:
-# endif
-# ifdef SHARED
-       add     %o3, %o1, %o1
-# endif
-       retl
-        mov    %o1, %o0
-END(__ceilf)
 weak_alias (__ceilf, ceilf)
 
 # undef weak_alias
index 7179058f06f2e14c1e95eb899bc65202853ac15b..cdd98c00f4bbcdf72f4318fff3491c6b879497cc 100644 (file)
@@ -1,41 +1,7 @@
-#include <sysdep.h>
+#include <sparc-ifunc.h>
+
+SPARC_ASM_VIS3_IFUNC(copysign)
 
-       .text
-ENTRY(__copysign)
-       .type   __copysign, @gnu_indirect_function
-# ifdef SHARED
-       SETUP_PIC_REG_LEAF(o3, o5)
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-       set     HWCAP_SPARC_VIS3, %o1
-       andcc   %o0, %o1, %g0
-       be      9f
-        nop
-#  ifdef SHARED
-       sethi   %gdop_hix22(__copysign_vis3), %o1
-       xor     %o1, %gdop_lox10(__copysign_vis3), %o1
-#  else
-       set     __copysign_vis3, %o1
-#  endif
-       ba      10f
-        nop
-9:
-# endif
-# ifdef SHARED
-       sethi   %gdop_hix22(__copysign_generic), %o1
-       xor     %o1, %gdop_lox10(__copysign_generic), %o1
-# else
-       set     __copysign_generic, %o1
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-10:
-# endif
-# ifdef SHARED
-       add     %o3, %o1, %o1
-# endif
-       retl
-        mov    %o1, %o0
-END(__copysign)
 weak_alias (__copysign, copysign)
 
 # undef weak_alias
index 4d055f2df5301342d794ecbc0a5284cc9851ffb1..cd409550de5f3320edafaf7f3a60a6680cb1aa75 100644 (file)
@@ -1,41 +1,7 @@
-#include <sysdep.h>
+#include <sparc-ifunc.h>
+
+SPARC_ASM_VIS3_IFUNC(copysignf)
 
-       .text
-ENTRY(__copysignf)
-       .type   __copysignf, @gnu_indirect_function
-# ifdef SHARED
-       SETUP_PIC_REG_LEAF(o3, o5)
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-       set     HWCAP_SPARC_VIS3, %o1
-       andcc   %o0, %o1, %g0
-       be      9f
-        nop
-#  ifdef SHARED
-       sethi   %gdop_hix22(__copysignf_vis3), %o1
-       xor     %o1, %gdop_lox10(__copysignf_vis3), %o1
-#  else
-       set     __copysignf_vis3, %o1
-#  endif
-       ba      10f
-        nop
-9:
-# endif
-# ifdef SHARED
-       sethi   %gdop_hix22(__copysignf_generic), %o1
-       xor     %o1, %gdop_lox10(__copysignf_generic), %o1
-# else
-       set     __copysignf_generic, %o1
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-10:
-# endif
-# ifdef SHARED
-       add     %o3, %o1, %o1
-# endif
-       retl
-        mov    %o1, %o0
-END(__copysignf)
 weak_alias (__copysignf, copysignf)
 
 # undef weak_alias
index ed70e4be2c22685e10fb480bf40ca77cb32f0855..86c63989a477436c31ce036be42431b3700c2afb 100644 (file)
@@ -1,41 +1,7 @@
-#include <sysdep.h>
+#include <sparc-ifunc.h>
+
+SPARC_ASM_VIS3_IFUNC(fabs)
 
-       .text
-ENTRY(__fabs)
-       .type   __fabs, @gnu_indirect_function
-# ifdef SHARED
-       SETUP_PIC_REG_LEAF(o3, o5)
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-       set     HWCAP_SPARC_VIS3, %o1
-       andcc   %o0, %o1, %g0
-       be      9f
-        nop
-#  ifdef SHARED
-       sethi   %gdop_hix22(__fabs_vis3), %o1
-       xor     %o1, %gdop_lox10(__fabs_vis3), %o1
-#  else
-       set     __fabs_vis3, %o1
-#  endif
-       ba      10f
-        nop
-9:
-# endif
-# ifdef SHARED
-       sethi   %gdop_hix22(__fabs_generic), %o1
-       xor     %o1, %gdop_lox10(__fabs_generic), %o1
-# else
-       set     __fabs_generic, %o1
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-10:
-# endif
-# ifdef SHARED
-       add     %o3, %o1, %o1
-# endif
-       retl
-        mov    %o1, %o0
-END(__fabs)
 weak_alias (__fabs, fabs)
 
 # undef weak_alias
index 4b7351fc2e22ecc305e0457f58c0830388a677db..0f2e11e01f770e5840e97fedbb36791529132a10 100644 (file)
@@ -1,41 +1,7 @@
-#include <sysdep.h>
+#include <sparc-ifunc.h>
+
+SPARC_ASM_VIS3_IFUNC(fabsf)
 
-       .text
-ENTRY(__fabsf)
-       .type   __fabsf, @gnu_indirect_function
-# ifdef SHARED
-       SETUP_PIC_REG_LEAF(o3, o5)
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-       set     HWCAP_SPARC_VIS3, %o1
-       andcc   %o0, %o1, %g0
-       be      9f
-        nop
-#  ifdef SHARED
-       sethi   %gdop_hix22(__fabsf_vis3), %o1
-       xor     %o1, %gdop_lox10(__fabsf_vis3), %o1
-#  else
-       set     __fabsf_vis3, %o1
-#  endif
-       ba      10f
-        nop
-9:
-# endif
-# ifdef SHARED
-       sethi   %gdop_hix22(__fabsf_generic), %o1
-       xor     %o1, %gdop_lox10(__fabsf_generic), %o1
-# else
-       set     __fabsf_generic, %o1
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-10:
-# endif
-# ifdef SHARED
-       add     %o3, %o1, %o1
-# endif
-       retl
-        mov    %o1, %o0
-END(__fabsf)
 weak_alias (__fabsf, fabsf)
 
 # undef weak_alias
index 1cdc53fb842011ce7074878b4ac14d4fee0667e8..6ae9947a7af801a2cf93e686c0acfb07ab50ba8c 100644 (file)
@@ -1,41 +1,7 @@
-#include <sysdep.h>
+#include <sparc-ifunc.h>
+
+SPARC_ASM_VIS3_IFUNC(floor)
 
-       .text
-ENTRY(__floor)
-       .type   __floor, @gnu_indirect_function
-# ifdef SHARED
-       SETUP_PIC_REG_LEAF(o3, o5)
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-       set     HWCAP_SPARC_VIS3, %o1
-       andcc   %o0, %o1, %g0
-       be      9f
-        nop
-#  ifdef SHARED
-       sethi   %gdop_hix22(__floor_vis3), %o1
-       xor     %o1, %gdop_lox10(__floor_vis3), %o1
-#  else
-       set     __floor_vis3, %o1
-#  endif
-       ba      10f
-        nop
-9:
-# endif
-# ifdef SHARED
-       sethi   %gdop_hix22(__floor_generic), %o1
-       xor     %o1, %gdop_lox10(__floor_generic), %o1
-# else
-       set     __floor_generic, %o1
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-10:
-# endif
-# ifdef SHARED
-       add     %o3, %o1, %o1
-# endif
-       retl
-        mov    %o1, %o0
-END(__floor)
 weak_alias (__floor, floor)
 
 # undef weak_alias
index 0dcd0e143152aeda50a3067d9b5e60b695b5577d..31cda385b7174e52e7fc00258b25c33a806695e6 100644 (file)
@@ -1,41 +1,7 @@
-#include <sysdep.h>
+#include <sparc-ifunc.h>
+
+SPARC_ASM_VIS3_IFUNC(floorf)
 
-       .text
-ENTRY(__floorf)
-       .type   __floorf, @gnu_indirect_function
-# ifdef SHARED
-       SETUP_PIC_REG_LEAF(o3, o5)
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-       set     HWCAP_SPARC_VIS3, %o1
-       andcc   %o0, %o1, %g0
-       be      9f
-        nop
-#  ifdef SHARED
-       sethi   %gdop_hix22(__floorf_vis3), %o1
-       xor     %o1, %gdop_lox10(__floorf_vis3), %o1
-#  else
-       set     __floorf_vis3, %o1
-#  endif
-       ba      10f
-        nop
-9:
-# endif
-# ifdef SHARED
-       sethi   %gdop_hix22(__floorf_generic), %o1
-       xor     %o1, %gdop_lox10(__floorf_generic), %o1
-# else
-       set     __floorf_generic, %o1
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-10:
-# endif
-# ifdef SHARED
-       add     %o3, %o1, %o1
-# endif
-       retl
-        mov    %o1, %o0
-END(__floorf)
 weak_alias (__floorf, floorf)
 
 # undef weak_alias
index f604f5b533442c68dae2b6e63f1094d28b65e544..d5e59d8d1ed6e874b3ff456d9cae348ad43e1815 100644 (file)
@@ -1,41 +1,7 @@
-#include <sysdep.h>
+#include <sparc-ifunc.h>
+
+SPARC_ASM_VIS3_IFUNC(fmax)
 
-       .text
-ENTRY(__fmax)
-       .type   __fmax, @gnu_indirect_function
-# ifdef SHARED
-       SETUP_PIC_REG_LEAF(o3, o5)
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-       set     HWCAP_SPARC_VIS3, %o1
-       andcc   %o0, %o1, %g0
-       be      9f
-        nop
-#  ifdef SHARED
-       sethi   %gdop_hix22(__fmax_vis3), %o1
-       xor     %o1, %gdop_lox10(__fmax_vis3), %o1
-#  else
-       set     __fmax_vis3, %o1
-#  endif
-       ba      10f
-        nop
-9:
-# endif
-# ifdef SHARED
-       sethi   %gdop_hix22(__fmax_generic), %o1
-       xor     %o1, %gdop_lox10(__fmax_generic), %o1
-# else
-       set     __fmax_generic, %o1
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-10:
-# endif
-# ifdef SHARED
-       add     %o3, %o1, %o1
-# endif
-       retl
-        mov    %o1, %o0
-END(__fmax)
 weak_alias (__fmax, fmax)
 
 # undef weak_alias
index c188f8e568722d506574470b4e3d327cbc79251e..daa91579c430ff8cf2443e45ff0b04cee2d66b43 100644 (file)
@@ -1,41 +1,7 @@
-#include <sysdep.h>
+#include <sparc-ifunc.h>
+
+SPARC_ASM_VIS3_IFUNC(fmaxf)
 
-       .text
-ENTRY(__fmaxf)
-       .type   __fmaxf, @gnu_indirect_function
-# ifdef SHARED
-       SETUP_PIC_REG_LEAF(o3, o5)
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-       set     HWCAP_SPARC_VIS3, %o1
-       andcc   %o0, %o1, %g0
-       be      9f
-        nop
-#  ifdef SHARED
-       sethi   %gdop_hix22(__fmaxf_vis3), %o1
-       xor     %o1, %gdop_lox10(__fmaxf_vis3), %o1
-#  else
-       set     __fmaxf_vis3, %o1
-#  endif
-       ba      10f
-        nop
-9:
-# endif
-# ifdef SHARED
-       sethi   %gdop_hix22(__fmaxf_generic), %o1
-       xor     %o1, %gdop_lox10(__fmaxf_generic), %o1
-# else
-       set     __fmaxf_generic, %o1
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-10:
-# endif
-# ifdef SHARED
-       add     %o3, %o1, %o1
-# endif
-       retl
-        mov    %o1, %o0
-END(__fmaxf)
 weak_alias (__fmaxf, fmaxf)
 
 # undef weak_alias
index ed7018b58b8c8de75d00e6fcb9ac8c64202ee23b..b2aec1bbc00be566fa86069114f7b7ea7655107d 100644 (file)
@@ -1,41 +1,7 @@
-#include <sysdep.h>
+#include <sparc-ifunc.h>
+
+SPARC_ASM_VIS3_IFUNC(fmin)
 
-       .text
-ENTRY(__fmin)
-       .type   __fmin, @gnu_indirect_function
-# ifdef SHARED
-       SETUP_PIC_REG_LEAF(o3, o5)
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-       set     HWCAP_SPARC_VIS3, %o1
-       andcc   %o0, %o1, %g0
-       be      9f
-        nop
-#  ifdef SHARED
-       sethi   %gdop_hix22(__fmin_vis3), %o1
-       xor     %o1, %gdop_lox10(__fmin_vis3), %o1
-#  else
-       set     __fmin_vis3, %o1
-#  endif
-       ba      10f
-        nop
-9:
-# endif
-# ifdef SHARED
-       sethi   %gdop_hix22(__fmin_generic), %o1
-       xor     %o1, %gdop_lox10(__fmin_generic), %o1
-# else
-       set     __fmin_generic, %o1
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-10:
-# endif
-# ifdef SHARED
-       add     %o3, %o1, %o1
-# endif
-       retl
-        mov    %o1, %o0
-END(__fmin)
 weak_alias (__fmin, fmin)
 
 # undef weak_alias
index 6c7a4928c1f249d8cbee496422eb7aece852807c..c4690e1df9b977b2627cbc72da9b256cf29145d2 100644 (file)
@@ -1,41 +1,7 @@
-#include <sysdep.h>
+#include <sparc-ifunc.h>
+
+SPARC_ASM_VIS3_IFUNC(fminf)
 
-       .text
-ENTRY(__fminf)
-       .type   __fminf, @gnu_indirect_function
-# ifdef SHARED
-       SETUP_PIC_REG_LEAF(o3, o5)
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-       set     HWCAP_SPARC_VIS3, %o1
-       andcc   %o0, %o1, %g0
-       be      9f
-        nop
-#  ifdef SHARED
-       sethi   %gdop_hix22(__fminf_vis3), %o1
-       xor     %o1, %gdop_lox10(__fminf_vis3), %o1
-#  else
-       set     __fminf_vis3, %o1
-#  endif
-       ba      10f
-        nop
-9:
-# endif
-# ifdef SHARED
-       sethi   %gdop_hix22(__fminf_generic), %o1
-       xor     %o1, %gdop_lox10(__fminf_generic), %o1
-# else
-       set     __fminf_generic, %o1
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-10:
-# endif
-# ifdef SHARED
-       add     %o3, %o1, %o1
-# endif
-       retl
-        mov    %o1, %o0
-END(__fminf)
 weak_alias (__fminf, fminf)
 
 # undef weak_alias
index 3a9294d3a84b6b9298f4962d47f16f5cf1442cde..a904aeca2a4c39610cc9f41bedbe72c81a46af0e 100644 (file)
@@ -1,41 +1,7 @@
-#include <sysdep.h>
+#include <sparc-ifunc.h>
+
+SPARC_ASM_VIS3_IFUNC(llrint)
 
-       .text
-ENTRY(__llrint)
-       .type   __llrint, @gnu_indirect_function
-# ifdef SHARED
-       SETUP_PIC_REG_LEAF(o3, o5)
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-       set     HWCAP_SPARC_VIS3, %o1
-       andcc   %o0, %o1, %g0
-       be      9f
-        nop
-#  ifdef SHARED
-       sethi   %gdop_hix22(__llrint_vis3), %o1
-       xor     %o1, %gdop_lox10(__llrint_vis3), %o1
-#  else
-       set     __llrint_vis3, %o1
-#  endif
-       ba      10f
-        nop
-9:
-# endif
-# ifdef SHARED
-       sethi   %gdop_hix22(__llrint_generic), %o1
-       xor     %o1, %gdop_lox10(__llrint_generic), %o1
-# else
-       set     __llrint_generic, %o1
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-10:
-# endif
-# ifdef SHARED
-       add     %o3, %o1, %o1
-# endif
-       retl
-        mov    %o1, %o0
-END(__llrint)
 weak_alias (__llrint, llrint)
 
 strong_alias (__llrint, __lllrint)
index f2236f0eec37453005a72e3f681add0376892318..8af5244e7e27972ccfdcb11abfffde40d4d8d159 100644 (file)
@@ -1,41 +1,7 @@
-#include <sysdep.h>
+#include <sparc-ifunc.h>
+
+SPARC_ASM_VIS3_IFUNC(llrintf)
 
-       .text
-ENTRY(__llrintf)
-       .type   __llrintf, @gnu_indirect_function
-# ifdef SHARED
-       SETUP_PIC_REG_LEAF(o3, o5)
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-       set     HWCAP_SPARC_VIS3, %o1
-       andcc   %o0, %o1, %g0
-       be      9f
-        nop
-#  ifdef SHARED
-       sethi   %gdop_hix22(__llrintf_vis3), %o1
-       xor     %o1, %gdop_lox10(__llrintf_vis3), %o1
-#  else
-       set     __llrintf_vis3, %o1
-#  endif
-       ba      10f
-        nop
-9:
-# endif
-# ifdef SHARED
-       sethi   %gdop_hix22(__llrintf_generic), %o1
-       xor     %o1, %gdop_lox10(__llrintf_generic), %o1
-# else
-       set     __llrintf_generic, %o1
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-10:
-# endif
-# ifdef SHARED
-       add     %o3, %o1, %o1
-# endif
-       retl
-        mov    %o1, %o0
-END(__llrintf)
 weak_alias (__llrintf, llrintf)
 
 strong_alias (__llrintf, __lllrintf)
index 3872ae299e1a720dcf7b3915faf452a80d660563..cc980eb8c7c8b0145aaca9050aec26e460509604 100644 (file)
@@ -1,41 +1,7 @@
-#include <sysdep.h>
+#include <sparc-ifunc.h>
+
+SPARC_ASM_VIS3_IFUNC(rint)
 
-       .text
-ENTRY(__rint)
-       .type   __rint, @gnu_indirect_function
-# ifdef SHARED
-       SETUP_PIC_REG_LEAF(o3, o5)
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-       set     HWCAP_SPARC_VIS3, %o1
-       andcc   %o0, %o1, %g0
-       be      9f
-        nop
-#  ifdef SHARED
-       sethi   %gdop_hix22(__rint_vis3), %o1
-       xor     %o1, %gdop_lox10(__rint_vis3), %o1
-#  else
-       set     __rint_vis3, %o1
-#  endif
-       ba      10f
-        nop
-9:
-# endif
-# ifdef SHARED
-       sethi   %gdop_hix22(__rint_generic), %o1
-       xor     %o1, %gdop_lox10(__rint_generic), %o1
-# else
-       set     __rint_generic, %o1
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-10:
-# endif
-# ifdef SHARED
-       add     %o3, %o1, %o1
-# endif
-       retl
-        mov    %o1, %o0
-END(__rint)
 weak_alias (__rint, rint)
 
 # undef weak_alias
index 9918929220ce551702ea7490fc15a20b8ea1d3ff..38fd936086c33a8a179bd55c087ecacdb9a0cbde 100644 (file)
@@ -1,41 +1,7 @@
-#include <sysdep.h>
+#include <sparc-ifunc.h>
+
+SPARC_ASM_VIS3_IFUNC(rintf)
 
-       .text
-ENTRY(__rintf)
-       .type   __rintf, @gnu_indirect_function
-# ifdef SHARED
-       SETUP_PIC_REG_LEAF(o3, o5)
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-       set     HWCAP_SPARC_VIS3, %o1
-       andcc   %o0, %o1, %g0
-       be      9f
-        nop
-#  ifdef SHARED
-       sethi   %gdop_hix22(__rintf_vis3), %o1
-       xor     %o1, %gdop_lox10(__rintf_vis3), %o1
-#  else
-       set     __rintf_vis3, %o1
-#  endif
-       ba      10f
-        nop
-9:
-# endif
-# ifdef SHARED
-       sethi   %gdop_hix22(__rintf_generic), %o1
-       xor     %o1, %gdop_lox10(__rintf_generic), %o1
-# else
-       set     __rintf_generic, %o1
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-10:
-# endif
-# ifdef SHARED
-       add     %o3, %o1, %o1
-# endif
-       retl
-        mov    %o1, %o0
-END(__rintf)
 weak_alias (__rintf, rintf)
 
 # undef weak_alias
index 80b15767cee95beb9d8aabdd2980e9c9a8156170..3b070721d23d775b2d05aa96d782d4499c250b63 100644 (file)
@@ -1,41 +1,7 @@
-#include <sysdep.h>
+#include <sparc-ifunc.h>
+
+SPARC_ASM_VIS3_IFUNC(sqrt)
 
-       .text
-ENTRY(__sqrt)
-       .type   __sqrt, @gnu_indirect_function
-# ifdef SHARED
-       SETUP_PIC_REG_LEAF(o3, o5)
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-       set     HWCAP_SPARC_VIS3, %o1
-       andcc   %o0, %o1, %g0
-       be      9f
-        nop
-#  ifdef SHARED
-       sethi   %gdop_hix22(__sqrt_vis3), %o1
-       xor     %o1, %gdop_lox10(__sqrt_vis3), %o1
-#  else
-       set     __sqrt_vis3, %o1
-#  endif
-       ba      10f
-        nop
-9:
-# endif
-# ifdef SHARED
-       sethi   %gdop_hix22(__sqrt_generic), %o1
-       xor     %o1, %gdop_lox10(__sqrt_generic), %o1
-# else
-       set     __sqrt_generic, %o1
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-10:
-# endif
-# ifdef SHARED
-       add     %o3, %o1, %o1
-# endif
-       retl
-        mov    %o1, %o0
-END(__sqrt)
 weak_alias (__sqrt, sqrt)
 
 # undef weak_alias
index a700a4e876dfff2d59d5523dc04ee83aa4fb459c..777a04058ccfb11de9c0277a5e6caca32263355c 100644 (file)
@@ -1,41 +1,7 @@
-#include <sysdep.h>
+#include <sparc-ifunc.h>
+
+SPARC_ASM_VIS3_IFUNC(sqrtf)
 
-       .text
-ENTRY(__sqrtf)
-       .type   __sqrtf, @gnu_indirect_function
-# ifdef SHARED
-       SETUP_PIC_REG_LEAF(o3, o5)
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-       set     HWCAP_SPARC_VIS3, %o1
-       andcc   %o0, %o1, %g0
-       be      9f
-        nop
-#  ifdef SHARED
-       sethi   %gdop_hix22(__sqrtf_vis3), %o1
-       xor     %o1, %gdop_lox10(__sqrtf_vis3), %o1
-#  else
-       set     __sqrtf_vis3, %o1
-#  endif
-       ba      10f
-        nop
-9:
-# endif
-# ifdef SHARED
-       sethi   %gdop_hix22(__sqrtf_generic), %o1
-       xor     %o1, %gdop_lox10(__sqrtf_generic), %o1
-# else
-       set     __sqrtf_generic, %o1
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-10:
-# endif
-# ifdef SHARED
-       add     %o3, %o1, %o1
-# endif
-       retl
-        mov    %o1, %o0
-END(__sqrtf)
 weak_alias (__sqrtf, sqrtf)
 
 # undef weak_alias
index f91fda61b91530767f83301fd4afc4c135bb3071..fa4c7c353fdd4226fbf0af3df2074d4a66eed37a 100644 (file)
@@ -1,41 +1,7 @@
-#include <sysdep.h>
+#include <sparc-ifunc.h>
+
+SPARC_ASM_VIS3_IFUNC(ceil)
 
-       .text
-ENTRY(__ceil)
-       .type   __ceil, @gnu_indirect_function
-# ifdef SHARED
-       SETUP_PIC_REG_LEAF(o3, o5)
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-       set     HWCAP_SPARC_VIS3, %o1
-       andcc   %o0, %o1, %g0
-       be      9f
-        nop
-#  ifdef SHARED
-       sethi   %gdop_hix22(__ceil_vis3), %o1
-       xor     %o1, %gdop_lox10(__ceil_vis3), %o1
-#  else
-       set     __ceil_vis3, %o1
-#  endif
-       ba      10f
-        nop
-9:
-# endif
-# ifdef SHARED
-       sethi   %gdop_hix22(__ceil_generic), %o1
-       xor     %o1, %gdop_lox10(__ceil_generic), %o1
-# else
-       set     __ceil_generic, %o1
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-10:
-# endif
-# ifdef SHARED
-       add     %o3, %o1, %o1
-# endif
-       retl
-        mov    %o1, %o0
-END(__ceil)
 weak_alias (__ceil, ceil)
 
 # undef weak_alias
index 048b6195d84cea3fae72b9acd81e3450c7bea1f3..3047dd8faa391771bb8ba0bf5e3008ad383dc978 100644 (file)
@@ -1,41 +1,7 @@
-#include <sysdep.h>
+#include <sparc-ifunc.h>
+
+SPARC_ASM_VIS3_IFUNC(ceilf)
 
-       .text
-ENTRY(__ceilf)
-       .type   __ceilf, @gnu_indirect_function
-# ifdef SHARED
-       SETUP_PIC_REG_LEAF(o3, o5)
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-       set     HWCAP_SPARC_VIS3, %o1
-       andcc   %o0, %o1, %g0
-       be      9f
-        nop
-#  ifdef SHARED
-       sethi   %gdop_hix22(__ceilf_vis3), %o1
-       xor     %o1, %gdop_lox10(__ceilf_vis3), %o1
-#  else
-       set     __ceilf_vis3, %o1
-#  endif
-       ba      10f
-        nop
-9:
-# endif
-# ifdef SHARED
-       sethi   %gdop_hix22(__ceilf_generic), %o1
-       xor     %o1, %gdop_lox10(__ceilf_generic), %o1
-# else
-       set     __ceilf_generic, %o1
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-10:
-# endif
-# ifdef SHARED
-       add     %o3, %o1, %o1
-# endif
-       retl
-        mov    %o1, %o0
-END(__ceilf)
 weak_alias (__ceilf, ceilf)
 
 # undef weak_alias
index f4bfdcef96663425f444e49597086234a794c159..78406a62b182052ddc7ff17ba357595a078e6b7b 100644 (file)
@@ -1,41 +1,7 @@
-#include <sysdep.h>
+#include <sparc-ifunc.h>
+
+SPARC_ASM_VIS3_IFUNC(finite)
 
-       .text
-ENTRY(__finite)
-       .type   __finite, @gnu_indirect_function
-# ifdef SHARED
-       SETUP_PIC_REG_LEAF(o3, o5)
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-       set     HWCAP_SPARC_VIS3, %o1
-       andcc   %o0, %o1, %g0
-       be      9f
-        nop
-#  ifdef SHARED
-       sethi   %gdop_hix22(__finite_vis3), %o1
-       xor     %o1, %gdop_lox10(__finite_vis3), %o1
-#  else
-       set     __finite_vis3, %o1
-#  endif
-       ba      10f
-        nop
-9:
-# endif
-# ifdef SHARED
-       sethi   %gdop_hix22(__finite_generic), %o1
-       xor     %o1, %gdop_lox10(__finite_generic), %o1
-# else
-       set     __finite_generic, %o1
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-10:
-# endif
-# ifdef SHARED
-       add     %o3, %o1, %o1
-# endif
-       retl
-        mov    %o1, %o0
-END(__finite)
 hidden_def (__finite)
 weak_alias (__finite, finite)
 
index 65ca7fd1c618d08dfdd2dc36c6fe79a04958fcbf..cafd41fd92fe45c0ca2a493d1f2805b7f3342b31 100644 (file)
@@ -1,41 +1,7 @@
-#include <sysdep.h>
+#include <sparc-ifunc.h>
+
+SPARC_ASM_VIS3_IFUNC(finitef)
 
-       .text
-ENTRY(__finitef)
-       .type   __finitef, @gnu_indirect_function
-# ifdef SHARED
-       SETUP_PIC_REG_LEAF(o3, o5)
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-       set     HWCAP_SPARC_VIS3, %o1
-       andcc   %o0, %o1, %g0
-       be      9f
-        nop
-#  ifdef SHARED
-       sethi   %gdop_hix22(__finitef_vis3), %o1
-       xor     %o1, %gdop_lox10(__finitef_vis3), %o1
-#  else
-       set     __finitef_vis3, %o1
-#  endif
-       ba      10f
-        nop
-9:
-# endif
-# ifdef SHARED
-       sethi   %gdop_hix22(__finitef_generic), %o1
-       xor     %o1, %gdop_lox10(__finitef_generic), %o1
-# else
-       set     __finitef_generic, %o1
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-10:
-# endif
-# ifdef SHARED
-       add     %o3, %o1, %o1
-# endif
-       retl
-        mov    %o1, %o0
-END(__finitef)
 hidden_def (__finitef)
 weak_alias (__finitef, finitef)
 
index 1cdc53fb842011ce7074878b4ac14d4fee0667e8..6ae9947a7af801a2cf93e686c0acfb07ab50ba8c 100644 (file)
@@ -1,41 +1,7 @@
-#include <sysdep.h>
+#include <sparc-ifunc.h>
+
+SPARC_ASM_VIS3_IFUNC(floor)
 
-       .text
-ENTRY(__floor)
-       .type   __floor, @gnu_indirect_function
-# ifdef SHARED
-       SETUP_PIC_REG_LEAF(o3, o5)
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-       set     HWCAP_SPARC_VIS3, %o1
-       andcc   %o0, %o1, %g0
-       be      9f
-        nop
-#  ifdef SHARED
-       sethi   %gdop_hix22(__floor_vis3), %o1
-       xor     %o1, %gdop_lox10(__floor_vis3), %o1
-#  else
-       set     __floor_vis3, %o1
-#  endif
-       ba      10f
-        nop
-9:
-# endif
-# ifdef SHARED
-       sethi   %gdop_hix22(__floor_generic), %o1
-       xor     %o1, %gdop_lox10(__floor_generic), %o1
-# else
-       set     __floor_generic, %o1
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-10:
-# endif
-# ifdef SHARED
-       add     %o3, %o1, %o1
-# endif
-       retl
-        mov    %o1, %o0
-END(__floor)
 weak_alias (__floor, floor)
 
 # undef weak_alias
index 0dcd0e143152aeda50a3067d9b5e60b695b5577d..31cda385b7174e52e7fc00258b25c33a806695e6 100644 (file)
@@ -1,41 +1,7 @@
-#include <sysdep.h>
+#include <sparc-ifunc.h>
+
+SPARC_ASM_VIS3_IFUNC(floorf)
 
-       .text
-ENTRY(__floorf)
-       .type   __floorf, @gnu_indirect_function
-# ifdef SHARED
-       SETUP_PIC_REG_LEAF(o3, o5)
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-       set     HWCAP_SPARC_VIS3, %o1
-       andcc   %o0, %o1, %g0
-       be      9f
-        nop
-#  ifdef SHARED
-       sethi   %gdop_hix22(__floorf_vis3), %o1
-       xor     %o1, %gdop_lox10(__floorf_vis3), %o1
-#  else
-       set     __floorf_vis3, %o1
-#  endif
-       ba      10f
-        nop
-9:
-# endif
-# ifdef SHARED
-       sethi   %gdop_hix22(__floorf_generic), %o1
-       xor     %o1, %gdop_lox10(__floorf_generic), %o1
-# else
-       set     __floorf_generic, %o1
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-10:
-# endif
-# ifdef SHARED
-       add     %o3, %o1, %o1
-# endif
-       retl
-        mov    %o1, %o0
-END(__floorf)
 weak_alias (__floorf, floorf)
 
 # undef weak_alias
index f604f5b533442c68dae2b6e63f1094d28b65e544..d5e59d8d1ed6e874b3ff456d9cae348ad43e1815 100644 (file)
@@ -1,41 +1,7 @@
-#include <sysdep.h>
+#include <sparc-ifunc.h>
+
+SPARC_ASM_VIS3_IFUNC(fmax)
 
-       .text
-ENTRY(__fmax)
-       .type   __fmax, @gnu_indirect_function
-# ifdef SHARED
-       SETUP_PIC_REG_LEAF(o3, o5)
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-       set     HWCAP_SPARC_VIS3, %o1
-       andcc   %o0, %o1, %g0
-       be      9f
-        nop
-#  ifdef SHARED
-       sethi   %gdop_hix22(__fmax_vis3), %o1
-       xor     %o1, %gdop_lox10(__fmax_vis3), %o1
-#  else
-       set     __fmax_vis3, %o1
-#  endif
-       ba      10f
-        nop
-9:
-# endif
-# ifdef SHARED
-       sethi   %gdop_hix22(__fmax_generic), %o1
-       xor     %o1, %gdop_lox10(__fmax_generic), %o1
-# else
-       set     __fmax_generic, %o1
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-10:
-# endif
-# ifdef SHARED
-       add     %o3, %o1, %o1
-# endif
-       retl
-        mov    %o1, %o0
-END(__fmax)
 weak_alias (__fmax, fmax)
 
 # undef weak_alias
index c188f8e568722d506574470b4e3d327cbc79251e..daa91579c430ff8cf2443e45ff0b04cee2d66b43 100644 (file)
@@ -1,41 +1,7 @@
-#include <sysdep.h>
+#include <sparc-ifunc.h>
+
+SPARC_ASM_VIS3_IFUNC(fmaxf)
 
-       .text
-ENTRY(__fmaxf)
-       .type   __fmaxf, @gnu_indirect_function
-# ifdef SHARED
-       SETUP_PIC_REG_LEAF(o3, o5)
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-       set     HWCAP_SPARC_VIS3, %o1
-       andcc   %o0, %o1, %g0
-       be      9f
-        nop
-#  ifdef SHARED
-       sethi   %gdop_hix22(__fmaxf_vis3), %o1
-       xor     %o1, %gdop_lox10(__fmaxf_vis3), %o1
-#  else
-       set     __fmaxf_vis3, %o1
-#  endif
-       ba      10f
-        nop
-9:
-# endif
-# ifdef SHARED
-       sethi   %gdop_hix22(__fmaxf_generic), %o1
-       xor     %o1, %gdop_lox10(__fmaxf_generic), %o1
-# else
-       set     __fmaxf_generic, %o1
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-10:
-# endif
-# ifdef SHARED
-       add     %o3, %o1, %o1
-# endif
-       retl
-        mov    %o1, %o0
-END(__fmaxf)
 weak_alias (__fmaxf, fmaxf)
 
 # undef weak_alias
index ed7018b58b8c8de75d00e6fcb9ac8c64202ee23b..b2aec1bbc00be566fa86069114f7b7ea7655107d 100644 (file)
@@ -1,41 +1,7 @@
-#include <sysdep.h>
+#include <sparc-ifunc.h>
+
+SPARC_ASM_VIS3_IFUNC(fmin)
 
-       .text
-ENTRY(__fmin)
-       .type   __fmin, @gnu_indirect_function
-# ifdef SHARED
-       SETUP_PIC_REG_LEAF(o3, o5)
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-       set     HWCAP_SPARC_VIS3, %o1
-       andcc   %o0, %o1, %g0
-       be      9f
-        nop
-#  ifdef SHARED
-       sethi   %gdop_hix22(__fmin_vis3), %o1
-       xor     %o1, %gdop_lox10(__fmin_vis3), %o1
-#  else
-       set     __fmin_vis3, %o1
-#  endif
-       ba      10f
-        nop
-9:
-# endif
-# ifdef SHARED
-       sethi   %gdop_hix22(__fmin_generic), %o1
-       xor     %o1, %gdop_lox10(__fmin_generic), %o1
-# else
-       set     __fmin_generic, %o1
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-10:
-# endif
-# ifdef SHARED
-       add     %o3, %o1, %o1
-# endif
-       retl
-        mov    %o1, %o0
-END(__fmin)
 weak_alias (__fmin, fmin)
 
 # undef weak_alias
index 6c7a4928c1f249d8cbee496422eb7aece852807c..c4690e1df9b977b2627cbc72da9b256cf29145d2 100644 (file)
@@ -1,41 +1,7 @@
-#include <sysdep.h>
+#include <sparc-ifunc.h>
+
+SPARC_ASM_VIS3_IFUNC(fminf)
 
-       .text
-ENTRY(__fminf)
-       .type   __fminf, @gnu_indirect_function
-# ifdef SHARED
-       SETUP_PIC_REG_LEAF(o3, o5)
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-       set     HWCAP_SPARC_VIS3, %o1
-       andcc   %o0, %o1, %g0
-       be      9f
-        nop
-#  ifdef SHARED
-       sethi   %gdop_hix22(__fminf_vis3), %o1
-       xor     %o1, %gdop_lox10(__fminf_vis3), %o1
-#  else
-       set     __fminf_vis3, %o1
-#  endif
-       ba      10f
-        nop
-9:
-# endif
-# ifdef SHARED
-       sethi   %gdop_hix22(__fminf_generic), %o1
-       xor     %o1, %gdop_lox10(__fminf_generic), %o1
-# else
-       set     __fminf_generic, %o1
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-10:
-# endif
-# ifdef SHARED
-       add     %o3, %o1, %o1
-# endif
-       retl
-        mov    %o1, %o0
-END(__fminf)
 weak_alias (__fminf, fminf)
 
 # undef weak_alias
index 8b47267f6b59b1130395da65d3bf33a4be4e8d18..ed9b62640d319a16f614e825e98dfc8fa0db2909 100644 (file)
@@ -1,41 +1,7 @@
-#include <sysdep.h>
+#include <sparc-ifunc.h>
+
+SPARC_ASM_VIS3_IFUNC(isinf)
 
-       .text
-ENTRY(__isinf)
-       .type   __isinf, @gnu_indirect_function
-# ifdef SHARED
-       SETUP_PIC_REG_LEAF(o3, o5)
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-       set     HWCAP_SPARC_VIS3, %o1
-       andcc   %o0, %o1, %g0
-       be      9f
-        nop
-#  ifdef SHARED
-       sethi   %gdop_hix22(__isinf_vis3), %o1
-       xor     %o1, %gdop_lox10(__isinf_vis3), %o1
-#  else
-       set     __isinf_vis3, %o1
-#  endif
-       ba      10f
-        nop
-9:
-# endif
-# ifdef SHARED
-       sethi   %gdop_hix22(__isinf_generic), %o1
-       xor     %o1, %gdop_lox10(__isinf_generic), %o1
-# else
-       set     __isinf_generic, %o1
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-10:
-# endif
-# ifdef SHARED
-       add     %o3, %o1, %o1
-# endif
-       retl
-        mov    %o1, %o0
-END(__isinf)
 hidden_def (__isinf)
 weak_alias (__isinf, isinf)
 
index 9a42a01d4059dc121d9d9ff5d2f7c967be4b58af..04517398f8f86c1090671df6a4a192a4f63df7da 100644 (file)
@@ -1,41 +1,7 @@
-#include <sysdep.h>
+#include <sparc-ifunc.h>
+
+SPARC_ASM_VIS3_IFUNC(isinff)
 
-       .text
-ENTRY(__isinff)
-       .type   __isinff, @gnu_indirect_function
-# ifdef SHARED
-       SETUP_PIC_REG_LEAF(o3, o5)
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-       set     HWCAP_SPARC_VIS3, %o1
-       andcc   %o0, %o1, %g0
-       be      9f
-        nop
-#  ifdef SHARED
-       sethi   %gdop_hix22(__isinff_vis3), %o1
-       xor     %o1, %gdop_lox10(__isinff_vis3), %o1
-#  else
-       set     __isinff_vis3, %o1
-#  endif
-       ba      10f
-        nop
-9:
-# endif
-# ifdef SHARED
-       sethi   %gdop_hix22(__isinff_generic), %o1
-       xor     %o1, %gdop_lox10(__isinff_generic), %o1
-# else
-       set     __isinff_generic, %o1
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-10:
-# endif
-# ifdef SHARED
-       add     %o3, %o1, %o1
-# endif
-       retl
-        mov    %o1, %o0
-END(__isinff)
 hidden_def (__isinff)
 weak_alias (__isinff, isinff)
 
index d75077cfec3bf3e130bfdae79b259c000d1cde12..40e985a5d4688a8ec31c1776c2e0780479efb0a6 100644 (file)
@@ -1,41 +1,7 @@
-#include <sysdep.h>
+#include <sparc-ifunc.h>
+
+SPARC_ASM_VIS3_IFUNC(isnan)
 
-       .text
-ENTRY(__isnan)
-       .type   __isnan, @gnu_indirect_function
-# ifdef SHARED
-       SETUP_PIC_REG_LEAF(o3, o5)
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-       set     HWCAP_SPARC_VIS3, %o1
-       andcc   %o0, %o1, %g0
-       be      9f
-        nop
-#  ifdef SHARED
-       sethi   %gdop_hix22(__isnan_vis3), %o1
-       xor     %o1, %gdop_lox10(__isnan_vis3), %o1
-#  else
-       set     __isnan_vis3, %o1
-#  endif
-       ba      10f
-        nop
-9:
-# endif
-# ifdef SHARED
-       sethi   %gdop_hix22(__isnan_generic), %o1
-       xor     %o1, %gdop_lox10(__isnan_generic), %o1
-# else
-       set     __isnan_generic, %o1
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-10:
-# endif
-# ifdef SHARED
-       add     %o3, %o1, %o1
-# endif
-       retl
-        mov    %o1, %o0
-END(__isnan)
 hidden_def (__isnan)
 weak_alias (__isnan, isnan)
 
index 6d11dd4b4e13b1af8d0b7ca5b5efbfed59a15df7..6b53b69d2e0bac756f565f0d7198722439bbf7ef 100644 (file)
@@ -1,41 +1,7 @@
-#include <sysdep.h>
+#include <sparc-ifunc.h>
+
+SPARC_ASM_VIS3_IFUNC(isnanf)
 
-       .text
-ENTRY(__isnanf)
-       .type   __isnanf, @gnu_indirect_function
-# ifdef SHARED
-       SETUP_PIC_REG_LEAF(o3, o5)
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-       set     HWCAP_SPARC_VIS3, %o1
-       andcc   %o0, %o1, %g0
-       be      9f
-        nop
-#  ifdef SHARED
-       sethi   %gdop_hix22(__isnanf_vis3), %o1
-       xor     %o1, %gdop_lox10(__isnanf_vis3), %o1
-#  else
-       set     __isnanf_vis3, %o1
-#  endif
-       ba      10f
-        nop
-9:
-# endif
-# ifdef SHARED
-       sethi   %gdop_hix22(__isnanf_generic), %o1
-       xor     %o1, %gdop_lox10(__isnanf_generic), %o1
-# else
-       set     __isnanf_generic, %o1
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-10:
-# endif
-# ifdef SHARED
-       add     %o3, %o1, %o1
-# endif
-       retl
-        mov    %o1, %o0
-END(__isnanf)
 hidden_def (__isnanf)
 weak_alias (__isnanf, isnanf)
 
index e63e83343b8335f4e85bfe35e2a02d402e3c7836..94af8f028c715290b754f84ed5aee620cbd692c0 100644 (file)
@@ -1,41 +1,7 @@
-#include <sysdep.h>
+#include <sparc-ifunc.h>
+
+SPARC_ASM_VIS3_IFUNC(lrint)
 
-       .text
-ENTRY(__lrint)
-       .type   __lrint, @gnu_indirect_function
-# ifdef SHARED
-       SETUP_PIC_REG_LEAF(o3, o5)
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-       set     HWCAP_SPARC_VIS3, %o1
-       andcc   %o0, %o1, %g0
-       be      9f
-        nop
-#  ifdef SHARED
-       sethi   %gdop_hix22(__lrint_vis3), %o1
-       xor     %o1, %gdop_lox10(__lrint_vis3), %o1
-#  else
-       set     __lrint_vis3, %o1
-#  endif
-       ba      10f
-        nop
-9:
-# endif
-# ifdef SHARED
-       sethi   %gdop_hix22(__lrint_generic), %o1
-       xor     %o1, %gdop_lox10(__lrint_generic), %o1
-# else
-       set     __lrint_generic, %o1
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-10:
-# endif
-# ifdef SHARED
-       add     %o3, %o1, %o1
-# endif
-       retl
-        mov    %o1, %o0
-END(__lrint)
 weak_alias (__lrint, lrint)
 
 strong_alias (__lrint, __llrint)
index 809aaa8a143af4434e82a92109f3a0dbea2e6a3a..e6ea4061c3ff306093ea7b2a2d0bc508bc3159d9 100644 (file)
@@ -1,41 +1,7 @@
-#include <sysdep.h>
+#include <sparc-ifunc.h>
+
+SPARC_ASM_VIS3_IFUNC(lrintf)
 
-       .text
-ENTRY(__lrintf)
-       .type   __lrintf, @gnu_indirect_function
-# ifdef SHARED
-       SETUP_PIC_REG_LEAF(o3, o5)
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-       set     HWCAP_SPARC_VIS3, %o1
-       andcc   %o0, %o1, %g0
-       be      9f
-        nop
-#  ifdef SHARED
-       sethi   %gdop_hix22(__lrintf_vis3), %o1
-       xor     %o1, %gdop_lox10(__lrintf_vis3), %o1
-#  else
-       set     __lrintf_vis3, %o1
-#  endif
-       ba      10f
-        nop
-9:
-# endif
-# ifdef SHARED
-       sethi   %gdop_hix22(__lrintf_generic), %o1
-       xor     %o1, %gdop_lox10(__lrintf_generic), %o1
-# else
-       set     __lrintf_generic, %o1
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-10:
-# endif
-# ifdef SHARED
-       add     %o3, %o1, %o1
-# endif
-       retl
-        mov    %o1, %o0
-END(__lrintf)
 weak_alias (__lrintf, lrintf)
 
 strong_alias (__lrintf, __llrintf)
index 3872ae299e1a720dcf7b3915faf452a80d660563..cc980eb8c7c8b0145aaca9050aec26e460509604 100644 (file)
@@ -1,41 +1,7 @@
-#include <sysdep.h>
+#include <sparc-ifunc.h>
+
+SPARC_ASM_VIS3_IFUNC(rint)
 
-       .text
-ENTRY(__rint)
-       .type   __rint, @gnu_indirect_function
-# ifdef SHARED
-       SETUP_PIC_REG_LEAF(o3, o5)
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-       set     HWCAP_SPARC_VIS3, %o1
-       andcc   %o0, %o1, %g0
-       be      9f
-        nop
-#  ifdef SHARED
-       sethi   %gdop_hix22(__rint_vis3), %o1
-       xor     %o1, %gdop_lox10(__rint_vis3), %o1
-#  else
-       set     __rint_vis3, %o1
-#  endif
-       ba      10f
-        nop
-9:
-# endif
-# ifdef SHARED
-       sethi   %gdop_hix22(__rint_generic), %o1
-       xor     %o1, %gdop_lox10(__rint_generic), %o1
-# else
-       set     __rint_generic, %o1
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-10:
-# endif
-# ifdef SHARED
-       add     %o3, %o1, %o1
-# endif
-       retl
-        mov    %o1, %o0
-END(__rint)
 weak_alias (__rint, rint)
 
 # undef weak_alias
index 9918929220ce551702ea7490fc15a20b8ea1d3ff..38fd936086c33a8a179bd55c087ecacdb9a0cbde 100644 (file)
@@ -1,41 +1,7 @@
-#include <sysdep.h>
+#include <sparc-ifunc.h>
+
+SPARC_ASM_VIS3_IFUNC(rintf)
 
-       .text
-ENTRY(__rintf)
-       .type   __rintf, @gnu_indirect_function
-# ifdef SHARED
-       SETUP_PIC_REG_LEAF(o3, o5)
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-       set     HWCAP_SPARC_VIS3, %o1
-       andcc   %o0, %o1, %g0
-       be      9f
-        nop
-#  ifdef SHARED
-       sethi   %gdop_hix22(__rintf_vis3), %o1
-       xor     %o1, %gdop_lox10(__rintf_vis3), %o1
-#  else
-       set     __rintf_vis3, %o1
-#  endif
-       ba      10f
-        nop
-9:
-# endif
-# ifdef SHARED
-       sethi   %gdop_hix22(__rintf_generic), %o1
-       xor     %o1, %gdop_lox10(__rintf_generic), %o1
-# else
-       set     __rintf_generic, %o1
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-10:
-# endif
-# ifdef SHARED
-       add     %o3, %o1, %o1
-# endif
-       retl
-        mov    %o1, %o0
-END(__rintf)
 weak_alias (__rintf, rintf)
 
 # undef weak_alias
index a8e97289357f9f09002688436ee8b07f679d6d03..e69550c474d10a0aa2865f1fe74cbdad6fdad34e 100644 (file)
@@ -1,41 +1,7 @@
-#include <sysdep.h>
+#include <sparc-ifunc.h>
+
+SPARC_ASM_VIS3_IFUNC(signbit)
 
-       .text
-ENTRY(__signbit)
-       .type   __signbit, @gnu_indirect_function
-# ifdef SHARED
-       SETUP_PIC_REG_LEAF(o3, o5)
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-       set     HWCAP_SPARC_VIS3, %o1
-       andcc   %o0, %o1, %g0
-       be      9f
-        nop
-#  ifdef SHARED
-       sethi   %gdop_hix22(__signbit_vis3), %o1
-       xor     %o1, %gdop_lox10(__signbit_vis3), %o1
-#  else
-       set     __signbit_vis3, %o1
-#  endif
-       ba      10f
-        nop
-9:
-# endif
-# ifdef SHARED
-       sethi   %gdop_hix22(__signbit_generic), %o1
-       xor     %o1, %gdop_lox10(__signbit_generic), %o1
-# else
-       set     __signbit_generic, %o1
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-10:
-# endif
-# ifdef SHARED
-       add     %o3, %o1, %o1
-# endif
-       retl
-        mov    %o1, %o0
-END(__signbit)
 weak_alias (__signbit, signbit)
 
 /* On 64-bit the double version will also always work for
index 721bc7fe4a4b41f95c15a0a588fbd1324bbfb852..c35c79f88aab3df7357892d4211dddcbc099993a 100644 (file)
@@ -1,41 +1,7 @@
-#include <sysdep.h>
+#include <sparc-ifunc.h>
+
+SPARC_ASM_VIS3_IFUNC(signbitf)
 
-       .text
-ENTRY(__signbitf)
-       .type   __signbitf, @gnu_indirect_function
-# ifdef SHARED
-       SETUP_PIC_REG_LEAF(o3, o5)
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-       set     HWCAP_SPARC_VIS3, %o1
-       andcc   %o0, %o1, %g0
-       be      9f
-        nop
-#  ifdef SHARED
-       sethi   %gdop_hix22(__signbitf_vis3), %o1
-       xor     %o1, %gdop_lox10(__signbitf_vis3), %o1
-#  else
-       set     __signbitf_vis3, %o1
-#  endif
-       ba      10f
-        nop
-9:
-# endif
-# ifdef SHARED
-       sethi   %gdop_hix22(__signbitf_generic), %o1
-       xor     %o1, %gdop_lox10(__signbitf_generic), %o1
-# else
-       set     __signbitf_generic, %o1
-# endif
-# ifdef HAVE_AS_VIS3_SUPPORT
-10:
-# endif
-# ifdef SHARED
-       add     %o3, %o1, %o1
-# endif
-       retl
-        mov    %o1, %o0
-END(__signbitf)
 weak_alias (__signbitf, signbitf)
 
 # undef weak_alias
This page took 0.106876 seconds and 5 git commands to generate.