mirror of
https://sourceware.org/git/glibc.git
synced 2024-11-10 15:20:10 +00:00
Update.
* sysdeps/alpha/fpu/s_floor.c (__floor): Don't depend on inlining, duplicate the code. * sysdeps/alpha/fpu/s_floorf.c (__floorf): Likewise.
This commit is contained in:
parent
baa9f3f31e
commit
d51913e933
@ -1,5 +1,9 @@
|
||||
1999-01-29 Ulrich Drepper <drepper@cygnus.com>
|
||||
|
||||
* sysdeps/alpha/fpu/s_floor.c (__floor): Don't depend on inlining,
|
||||
duplicate the code.
|
||||
* sysdeps/alpha/fpu/s_floorf.c (__floorf): Likewise.
|
||||
|
||||
* sysdeps/i386/Versions: Exports functions from libgcc sinc ethis
|
||||
is what was done in glibc 2.0.
|
||||
* sysdeps/m68k/Versions: Likewise. New file.
|
||||
|
@ -1,4 +1,4 @@
|
||||
/* Copyright (C) 1998 Free Software Foundation, Inc.
|
||||
/* Copyright (C) 1998, 1999 Free Software Foundation, Inc.
|
||||
This file is part of the GNU C Library.
|
||||
Contributed by Richard Henderson.
|
||||
|
||||
@ -29,7 +29,20 @@
|
||||
double
|
||||
__floor (double x)
|
||||
{
|
||||
return __i_floor(x);
|
||||
if (x != 0 && fabs (x) < 9007199254740992.0) /* 1 << DBL_MANT_DIG */
|
||||
{
|
||||
double __tmp1;
|
||||
__asm (
|
||||
#ifdef _IEEE_FP_INEXACT
|
||||
"cvttq/svim %2,%1\n\t"
|
||||
#else
|
||||
"cvttq/svm %2,%1\n\t"
|
||||
#endif
|
||||
"cvtqt/m %1,%0\n\t"
|
||||
: "=f"(x), "=&f"(__tmp1)
|
||||
: "f"(x));
|
||||
}
|
||||
return x;
|
||||
}
|
||||
|
||||
weak_alias (__floor, floor)
|
||||
|
@ -1,4 +1,4 @@
|
||||
/* Copyright (C) 1998 Free Software Foundation, Inc.
|
||||
/* Copyright (C) 1998, 1999 Free Software Foundation, Inc.
|
||||
This file is part of the GNU C Library.
|
||||
Contributed by Richard Henderson.
|
||||
|
||||
@ -29,7 +29,27 @@
|
||||
float
|
||||
__floorf (float x)
|
||||
{
|
||||
return __i_floorf(x);
|
||||
/* Check not zero since floor(-0) == -0. */
|
||||
if (x != 0 && fabsf (x) < 16777216.0f) /* 1 << FLT_MANT_DIG */
|
||||
{
|
||||
/* Note that Alpha S_Floating is stored in registers in a
|
||||
restricted T_Floating format, so we don't even need to
|
||||
convert back to S_Floating in the end. The initial
|
||||
conversion to T_Floating is needed to handle denormals. */
|
||||
|
||||
float __tmp1, __tmp2;
|
||||
|
||||
__asm ("cvtst/s %3,%2\n\t"
|
||||
#ifdef _IEEE_FP_INEXACT
|
||||
"cvttq/svim %2,%1\n\t"
|
||||
#else
|
||||
"cvttq/svm %2,%1\n\t"
|
||||
#endif
|
||||
"cvtqt/m %1,%0\n\t"
|
||||
: "=f"(x), "=&f"(__tmp1), "=&f"(__tmp2)
|
||||
: "f"(x));
|
||||
}
|
||||
return x;
|
||||
}
|
||||
|
||||
weak_alias (__floorf, floorf)
|
||||
|
Loading…
Reference in New Issue
Block a user