mirror of
https://sourceware.org/git/glibc.git
synced 2025-01-13 12:40:08 +00:00
a2b08ee541
1997-09-27 01:14 Ulrich Drepper <drepper@cygnus.com> * Makeconfig (extra-objs): Depend in before-compile. * configure.in: Locate Perl and substitute with complete path. * config.make.in: Add PERL for substitution. * elf/Makefile (routines): Add dl-addr. * elf/dladdr.c: Move the real code into ... * elf/dl-addr.c: New file. * elf/link.h: Add prototype for _dl_addr. * elf/dladdr.c (dladdr): Change address argument to be const. * elf/dlfcn.h: Likewise. * locale/C_name.c: Add _nl_POSIX_name. * locale/localeinfo.h: Add declaration of _nl_POSIX_name. * locale/findlocale.c (_nl_find_locale): Use _nl_POSIX_name. (_nl_remove_locale): Free name of data set. * locale/setlocale.c (clever_copy): Remove. (new_composite_name): Use _nl_C_name and _nl_POSIX_name in compare. (setname): Only remove old name when it is for category LC_ALL. Change malloc, free, realloc, and memalign hooks for glibc to take another parameter indicating the location of the caller. * malloc/malloc.c: Change hook functions and variables. * malloc/malloc.h: Likewise. * malloc/mcheck.c: Likewise. Make sure later hooked function also get the original caller address. * malloc/mtrace.c: Likewise. (tr_where): If no information in _mtrace_file is given use the information about the caller. * malloc/Makefile (distribute): Replace mtrace.awk by mtrace.pl. Add rules to install mtrace.pl after rewriting. * malloc/mtrace.pl: New file. Based on the old AWK script but with extended functionality. * malloc/mtrace.awk: Removed. * po/fr.po: New version. * string/Makefile: Do use builtins for tester.c and inl-tester.c. * string/tester.c: Rewrite. Split in many small functions to not exceed gcc's limits. * sysdeps/unix/sysv/linux/syscalls.list: Add prctl. 1997-09-25 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de> * string/bits/string2.h (__stpcpy_small): Don't use casts as lvalues. 1997-09-26 Andreas Jaeger <aj@arthur.rhein-neckar.de> * manual/time.texi (Formatting Date and Time): Clarify explanation of strftime flags a bit. Suggested by Robert Bihlmeyer <robbe@orcus.priv.at>. 1997-09-25 00:13 David S. Miller <davem@tanya.rutgers.edu> * sysdeps/libm-ieee754/s_exp2f.c: Protect _GNU_SOURCE definition. Fix typo, it is FLT_MANT_DIG. 1997-09-24 18:52 H.J. Lu <hjl@gnu.ai.mit.edu> * math/atest-exp2.c: Include <stdlib/gmp.h> instead of <gmp.h>. 1997-08-27 08:10 H.J. Lu <hjl@gnu.ai.mit.edu> * libio/libio.h, libio/libioP.h: Support libio in libstdc++. * libio/libio.h (_IO_peekc): Defined as _IO_peekc_unlocked if _IO_MTSAFE_IO is undefined. 1997-09-24 23:27 Richard Henderson <rth@cygnus.com> * elf/dl-runtime.c (fixup): Don't go through elf_machine_relplt, but lookup the value of the target symbol ourselves and call the new elf_machine_fixup_plt. This kills the ELF_FIXUP_RETURN_VALUE hack. (profile_fixup): Likewise, but don't fix up the plt. * elf/rtld.c (_dl_main): ELF_MACHINE_RELOC_NOPLT renamed _JMP_SLOT. * sysdeps/alpha/dl-machine.h (ELF_MACHINE_RELOC_NOPLT): Renamed. (elf_alpha_fix_plt): Renamed elf_machine_fixup_plt. * sysdeps/i386/dl-machine.h (elf_machine_relplt): Killed. (ELF_MACHINE_JMP_SLOT): Renamed. (elf_machine_fixup_plt): New function. * sysdeps/m68k/dl-machine.h: Likewise. * sysdeps/powerpc/dl-machine.h: Likewise. (elf_machine_rela): Moved JMP_SLOT fixup out to elf_machine_fixup_plt. * sysdeps/sparc/sparc32/dl-machine.h: Likewise. * sysdeps/sparc/sparc64/dl-machine.h: Likewise. * sysdeps/stub/dl-machine.h: Update, sorta. * sysdeps/alpha/dl-machine.h (elf_machine_runtime_setup): Do profiling. (TRAMPOLINE_TEMPLATE): From the carcas of _RUNTIME_TRAMPOLINE, do both normal and profile code. (elf_machine_rela): Handle r_addend for .got and .plt too.
129 lines
3.9 KiB
C
129 lines
3.9 KiB
C
/* Single-precision floating point 2^x.
|
|
Copyright (C) 1997 Free Software Foundation, Inc.
|
|
This file is part of the GNU C Library.
|
|
Contributed by Geoffrey Keating <geoffk@ozemail.com.au>
|
|
|
|
The GNU C Library is free software; you can redistribute it and/or
|
|
modify it under the terms of the GNU Library General Public License as
|
|
published by the Free Software Foundation; either version 2 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
|
|
Library General Public License for more details.
|
|
|
|
You should have received a copy of the GNU Library General Public
|
|
License along with the GNU C Library; see the file COPYING.LIB. If not,
|
|
write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
Boston, MA 02111-1307, USA. */
|
|
|
|
/* The basic design here is from
|
|
Shmuel Gal and Boris Bachelis, "An Accurate Elementary Mathematical
|
|
Library for the IEEE Floating Point Standard", ACM Trans. Math. Soft.,
|
|
17 (1), March 1991, pp. 26-45.
|
|
It has been slightly modified to compute 2^x instead of e^x, and for
|
|
single-precision.
|
|
*/
|
|
#ifndef _GNU_SOURCE
|
|
# define _GNU_SOURCE
|
|
#endif
|
|
#include <float.h>
|
|
#include <ieee754.h>
|
|
#include <math.h>
|
|
#include <fenv.h>
|
|
#include <inttypes.h>
|
|
#include <math_private.h>
|
|
|
|
#include "t_exp2f.h"
|
|
|
|
static const volatile float TWOM100 = 7.88860905e-31;
|
|
static const volatile float huge = 1e+30;
|
|
|
|
float
|
|
__ieee754_exp2f (float x)
|
|
{
|
|
static const uint32_t a_inf = 0x7f800000;
|
|
/* Check for usual case. */
|
|
if (isless (x, (float) FLT_MAX_EXP)
|
|
&& isgreater (x, (float) (FLT_MIN_EXP - 1)))
|
|
{
|
|
static const float TWO16 = 65536.0;
|
|
int tval;
|
|
float rx, x22;
|
|
union ieee754_float ex2_u;
|
|
fenv_t oldenv;
|
|
|
|
feholdexcept (&oldenv);
|
|
fesetround (FE_TONEAREST);
|
|
|
|
/* 1. Argument reduction.
|
|
Choose integers ex, -128 <= t < 128, and some real
|
|
-1/512 <= x1 <= 1/512 so that
|
|
x = ex + t/512 + x1.
|
|
|
|
First, calculate rx = ex + t/256. */
|
|
if (x >= 0)
|
|
{
|
|
rx = x + TWO16;
|
|
rx -= TWO16;
|
|
}
|
|
else
|
|
{
|
|
rx = x - TWO16;
|
|
rx += TWO16;
|
|
}
|
|
x -= rx; /* Compute x=x1. */
|
|
/* Compute tval = (ex*256 + t)+128.
|
|
Now, t = (tval mod 256)-128 and ex=tval/256 [that's mod, NOT %; and
|
|
/-round-to-nearest not the usual c integer /]. */
|
|
tval = (int) (rx * 256.0f + 128.0f);
|
|
|
|
/* 2. Adjust for accurate table entry.
|
|
Find e so that
|
|
x = ex + t/256 + e + x2
|
|
where -7e-4 < e < 7e-4, and
|
|
(float)(2^(t/256+e))
|
|
is accurate to one part in 2^-64. */
|
|
|
|
/* 'tval & 255' is the same as 'tval%256' except that it's always
|
|
positive.
|
|
Compute x = x2. */
|
|
x -= exp2_deltatable[tval & 255];
|
|
|
|
/* 3. Compute ex2 = 2^(t/255+e+ex). */
|
|
ex2_u.f = exp2_accuratetable[tval & 255];
|
|
ex2_u.ieee.exponent += tval >> 8;
|
|
|
|
/* 4. Approximate 2^x2 - 1, using a second-degree polynomial,
|
|
2^x2 ~= sum(k=0..2 | (x2 * ln(2))^k / k! ) +
|
|
so
|
|
2^x2 - 1 ~= sum(k=1..4 | (x2 * ln(2))^k / k! )
|
|
with error less than 2^(1/512+7e-4) * (x2 * ln(2))^3 / 3! < 1.2e-18. */
|
|
|
|
x22 = (.240226507f * x + .6931471806f) * ex2_u.f;
|
|
|
|
/* 5. Return (2^x2-1) * 2^(t/512+e+ex) + 2^(t/512+e+ex). */
|
|
fesetenv (&oldenv);
|
|
|
|
/* Need to check: does this set FE_INEXACT correctly? */
|
|
return x22 * x + ex2_u.f;
|
|
}
|
|
/* 2^inf == inf, with no error. */
|
|
else if (x == *(const float *)&a_inf)
|
|
{
|
|
return x;
|
|
}
|
|
/* Check for overflow. */
|
|
else if (isgreaterequal (x, (float) FLT_MAX_EXP))
|
|
return huge * huge;
|
|
/* And underflow (including -inf). */
|
|
else if (isless (x, (float) (FLT_MIN_EXP - FLT_MANT_DIG)))
|
|
return TWOM100 * TWOM100;
|
|
/* Maybe the result needs to be a denormalised number... */
|
|
else if (!isnan (x))
|
|
return __ieee754_exp2f (x + 100.0) * TWOM100;
|
|
else /* isnan(x) */
|
|
return x + x;
|
|
}
|