1996-12-30 01:47:46 +00:00
|
|
|
/* ix87 specific implementation of arcsinh.
|
2014-01-01 11:03:15 +00:00
|
|
|
Copyright (C) 1996-2014 Free Software Foundation, Inc.
|
1996-12-30 01:47:46 +00:00
|
|
|
This file is part of the GNU C Library.
|
|
|
|
Contributed by Ulrich Drepper <drepper@cygnus.com>, 1996.
|
|
|
|
|
|
|
|
The GNU C Library is free software; you can redistribute it and/or
|
2001-07-06 04:58:11 +00:00
|
|
|
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.
|
1996-12-30 01:47:46 +00:00
|
|
|
|
|
|
|
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
|
2001-07-06 04:58:11 +00:00
|
|
|
Lesser General Public License for more details.
|
1996-12-30 01:47:46 +00:00
|
|
|
|
2001-07-06 04:58:11 +00:00
|
|
|
You should have received a copy of the GNU Lesser General Public
|
2012-02-09 23:18:22 +00:00
|
|
|
License along with the GNU C Library; if not, see
|
|
|
|
<http://www.gnu.org/licenses/>. */
|
1996-12-30 01:47:46 +00:00
|
|
|
|
|
|
|
#include <machine/asm.h>
|
|
|
|
|
2011-10-12 15:27:51 +00:00
|
|
|
.section .rodata.cst8,"aM",@progbits,8
|
1996-12-30 01:47:46 +00:00
|
|
|
|
2011-10-12 15:27:51 +00:00
|
|
|
.p2align 3
|
1996-12-30 01:47:46 +00:00
|
|
|
/* Please note that we use double value for 1.0. This number
|
|
|
|
has an exact representation and so we don't get accuracy
|
|
|
|
problems. The advantage is that the code is simpler. */
|
2012-08-02 19:04:29 +00:00
|
|
|
.type one,@object
|
1996-12-30 01:47:46 +00:00
|
|
|
one: .double 1.0
|
|
|
|
ASM_SIZE_DIRECTIVE(one)
|
|
|
|
/* It is not important that this constant is precise. It is only
|
|
|
|
a value which is known to be on the safe side for using the
|
|
|
|
fyl2xp1 instruction. */
|
2012-08-02 19:04:29 +00:00
|
|
|
.type limit,@object
|
1996-12-30 01:47:46 +00:00
|
|
|
limit: .double 0.29
|
|
|
|
ASM_SIZE_DIRECTIVE(limit)
|
|
|
|
|
|
|
|
#ifdef PIC
|
|
|
|
#define MO(op) op##@GOTOFF(%edx)
|
|
|
|
#else
|
|
|
|
#define MO(op) op
|
|
|
|
#endif
|
|
|
|
|
|
|
|
.text
|
|
|
|
ENTRY(__ieee754_acoshl)
|
|
|
|
movl 12(%esp), %ecx
|
update from main archive 970226
1997-02-27 05:12 Ulrich Drepper <drepper@cygnus.com>
* manual/Makefile: Add rules to run and distribute xtract-typefun.
* manual/xtract-typefun.awk: New file. Script to extract function,
variable, macro anchor to put into the `dir' file.
* manual/signal.texi: Document difference between SysV and BSD
signal(3) function and add documentation for sysv_signal.
* sysdeps/libm-i387/e_acoshl.c: Clear upper half of word containing
exponent before comparing.
1997-02-27 01:13 Ulrich Drepper <drepper@cygnus.com>
* sysdeps/generic/netinet/in.h (htonl, htons, ntohl, ntohs): Change
prototypes to use types with explicit width. `unsigned long' is
different on 64 bit systems.
* sysdeps/unix/sysv/linux/netinet/in.h: Likewise.
* sysdeps/generic/htonl.c: Likewise.
* sysdeps/generic/htons.c: Likewise.
* sysdeps/generic/ntohl.c: Likewise.
* sysdeps/generic/ntohs.c: Likewise.
Suggested by a sun <asun@zoology.washington.edu>.
1997-02-26 08:30 Andreas Jaeger <aj@arthur.pfalz.de>
* math/math.h: Include <__math.h> if __NO_MATH_INLINES is not
defined and we want optimization.
1997-02-27 01:13 Ulrich Drepper <drepper@cygnus.com>
* sysdeps/generic/netinet/in.h (htonl, htons, ntohl, ntohs): Change
prototypes to use types with explicit width. `unsigned long' is
different on 64 bit systems.
Suggested by a sun <asun@zoology.washington.edu>.
1997-02-02 19:53 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
* misc/getpass.c: Don't disable canonical input.
Reverted patch of Mon Jan 6 01:35:29 1997.
1996-12-14 22:07 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
* libio/libioP.h (_IO_finish_t): Take additional parameter, to
match the hidden __in_chrg parameter of the destructor.
(_IO_FINISH): Pass zero for it.
* libio/genops.c (_IO_default_finish): Add second parameter, which
is ignored.
* libio/memstream.c (_IO_mem_finish): Likewise.
* libio/fileops.c (_IO_mem_finish): Likewise.
* libio/strops.c (_IO_str_finish): Likewise. All callers changed.
1997-02-27 00:23 H.J. Lu <hjl@lucon.org>
* time/Makefile: Avoid using patterns in dependencies.
1997-02-26 00:56 Miguel de Icaza <miguel@nuclecu.unam.mx>
* elf/rtld.c: Make _dl_start static. Otherwise the linker on the
SPARC will convert the call _dl_start into a call into the PLT.
* elf/rtld.c (_dl_start): On the SPARC we need to adjust the value
of arg to make it point to the actual values.
* sysdeps/sparc/elf/DEFS.h: New ELF specific version.
* sysdeps/sparc/Dist: Mention sysdeps/sparc/elf/DEFS.h.
* sysdeps/sparc/bsd-_setjmp.S, sysdeps/sparc/bsd-setjmp.S: Make
them PIC aware.
* sysdeps/sparc/dl-machine.h (elf_machine_load_address):
Implemented.
(elf_machine_rela): Make it compile; fix existing relocation
types; add unhandled relocation types.
(ELF_ADJUST_ARG): Get pointer to arguments at program startup.
(RTLD_START): Initial implementation, not yet finished.
* sysdeps/sparc/elf/start.S: Fix.
* sysdeps/sparc/fpu_control.h: Remove duplicate declaration of
__setfpucw.
* sysdeps/sparc/divrem.m4: Make compilable under Linux.
* sysdeps/sparc/rem.S, sysdeps/sparc/sdiv.S, sysdeps/sparc/udiv.S,
sysdeps/sparc/urem.S : Regenerated.
* sysdeps/sparc/setjmp.S: Make it PIC aware.
* sysdeps/unix/sysv/linux/sparc/__sigtrampoline.S: Define
__ASSEMBLY__ before using kernel header.
* sysdeps/unix/sysv/linux/sparc/Makefile: Use -mv8 flag to compile
rtld.c.
* sysdeps/unix/sysv/linux/sparc/brk.c: Implement.
* sysdeps/unix/sysv/linux/sparc/profil-counter.h: Remove code
to handle old signals.
* sysdeps/unix/sysv/linux/sparc/sigaction.c: Implements sigaction
for all Linux/SPARC kernels.
* sysdeps/unix/sysv/linux/sparc/syscall.S: Add code to store
errno using __errno_location.
* sysdeps/unix/sysv/linux/sparc/sysdep.h: Add various handler
macros for assembler sources.
* sysdeps/unix/sysv/linux/sparc/errno.c: Define errno.
1997-02-25 16:02 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
* elf/rtld.c (dl_main): Remove dead code that is never executed.
Rename local variable l to main_map where it is used to point to
the load_map for the executable.
1997-02-25 15:03 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
* elf/dl-version.c (_dl_check_all_versions): Ignore libraries that
could not be found.
1997-02-24 23:18 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
* Makerules: Generate implicit object suffix rules automagically.
(o-iterator): Move before first use.
* Makeconfig (all-object-suffixes): Add .bo suffix.
1997-02-25 15:11 Ulrich Drepper <drepper@cygnus.com>
* sysdeps/libm-i387/e_acoshf.S (__ieee754_acoshf): Test correct
word on stack for overflow.
C++. Use __exception instead.
1997-02-27 06:01:16 +00:00
|
|
|
andl $0xffff, %ecx
|
1996-12-30 01:47:46 +00:00
|
|
|
cmpl $0x3fff, %ecx
|
|
|
|
jl 5f // < 1 => invalid
|
|
|
|
fldln2 // log(2)
|
|
|
|
fldt 4(%esp) // x : log(2)
|
|
|
|
cmpl $0x4020, %ecx
|
|
|
|
ja 3f // x > 2^34
|
|
|
|
#ifdef PIC
|
2005-05-04 17:58:13 +00:00
|
|
|
LOAD_PIC_REG (dx)
|
1996-12-30 01:47:46 +00:00
|
|
|
#endif
|
|
|
|
cmpl $0x4000, %ecx
|
|
|
|
ja 4f // x > 2
|
|
|
|
|
|
|
|
// 1 <= x <= 2 => y = log1p(x-1+sqrt(2*(x-1)+(x-1)^2))
|
|
|
|
fsubl MO(one) // x-1 : log(2)
|
2014-05-14 12:35:40 +00:00
|
|
|
fabs // acosh(1) is +0 in all rounding modes
|
1996-12-30 01:47:46 +00:00
|
|
|
fld %st // x-1 : x-1 : log(2)
|
|
|
|
fmul %st(1) // (x-1)^2 : x-1 : log(2)
|
|
|
|
fadd %st(1) // x-1+(x-1)^2 : x-1 : log(2)
|
|
|
|
fadd %st(1) // 2*(x-1)+(x-1)^2 : x-1 : log(2)
|
|
|
|
fsqrt // sqrt(2*(x-1)+(x-1)^2) : x-1 : log(2)
|
|
|
|
faddp // x-1+sqrt(2*(x-1)+(x-1)^2) : log(2)
|
|
|
|
fcoml MO(limit)
|
|
|
|
fnstsw
|
|
|
|
sahf
|
|
|
|
ja 2f
|
|
|
|
fyl2xp1 // log1p(x-1+sqrt(2*(x-1)+(x-1)^2))
|
|
|
|
ret
|
|
|
|
|
|
|
|
2: faddl MO(one) // x+sqrt(2*(x-1)+(x-1)^2) : log(2)
|
|
|
|
fyl2x // log(x+sqrt(2*(x-1)+(x-1)^2))
|
|
|
|
ret
|
|
|
|
|
|
|
|
// x > 2^34 => y = log(x) + log(2)
|
|
|
|
.align ALIGNARG(4)
|
|
|
|
3: fyl2x // log(x)
|
|
|
|
fldln2 // log(2) : log(x)
|
|
|
|
faddp // log(x)+log(2)
|
|
|
|
ret
|
|
|
|
|
|
|
|
// 2^34 > x > 2 => y = log(2*x - 1/(x+sqrt(x*x-1)))
|
|
|
|
.align ALIGNARG(4)
|
|
|
|
4: fld %st // x : x : log(2)
|
|
|
|
fadd %st, %st(1) // x : 2*x : log(2)
|
|
|
|
fld %st // x : x : 2*x : log(2)
|
|
|
|
fmul %st(1) // x^2 : x : 2*x : log(2)
|
|
|
|
fsubl MO(one) // x^2-1 : x : 2*x : log(2)
|
|
|
|
fsqrt // sqrt(x^2-1) : x : 2*x : log(2)
|
|
|
|
faddp // x+sqrt(x^2-1) : 2*x : log(2)
|
|
|
|
fdivrl MO(one) // 1/(x+sqrt(x^2-1)) : 2*x : log(2)
|
|
|
|
fsubrp // 2*x+1/(x+sqrt(x^2)-1) : log(2)
|
|
|
|
fyl2x // log(2*x+1/(x+sqrt(x^2-1)))
|
|
|
|
ret
|
|
|
|
|
|
|
|
// x < 1 => NaN
|
|
|
|
.align ALIGNARG(4)
|
|
|
|
5: fldz
|
|
|
|
fdiv %st, %st(0)
|
|
|
|
ret
|
|
|
|
END(__ieee754_acoshl)
|
2011-10-12 15:27:51 +00:00
|
|
|
strong_alias (__ieee754_acoshl, __acoshl_finite)
|