1996-12-30 01:47:46 +00:00
|
|
|
/* ix87 specific implementation of arcsinh.
|
2021-01-02 19:32:25 +00:00
|
|
|
Copyright (C) 1996-2021 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
|
Prefer https to http for gnu.org and fsf.org URLs
Also, change sources.redhat.com to sourceware.org.
This patch was automatically generated by running the following shell
script, which uses GNU sed, and which avoids modifying files imported
from upstream:
sed -ri '
s,(http|ftp)(://(.*\.)?(gnu|fsf|sourceware)\.org($|[^.]|\.[^a-z])),https\2,g
s,(http|ftp)(://(.*\.)?)sources\.redhat\.com($|[^.]|\.[^a-z]),https\2sourceware.org\4,g
' \
$(find $(git ls-files) -prune -type f \
! -name '*.po' \
! -name 'ChangeLog*' \
! -path COPYING ! -path COPYING.LIB \
! -path manual/fdl-1.3.texi ! -path manual/lgpl-2.1.texi \
! -path manual/texinfo.tex ! -path scripts/config.guess \
! -path scripts/config.sub ! -path scripts/install-sh \
! -path scripts/mkinstalldirs ! -path scripts/move-if-change \
! -path INSTALL ! -path locale/programs/charmap-kw.h \
! -path po/libc.pot ! -path sysdeps/gnu/errlist.c \
! '(' -name configure \
-execdir test -f configure.ac -o -f configure.in ';' ')' \
! '(' -name preconfigure \
-execdir test -f preconfigure.ac ';' ')' \
-print)
and then by running 'make dist-prepare' to regenerate files built
from the altered files, and then executing the following to cleanup:
chmod a+x sysdeps/unix/sysv/linux/riscv/configure
# Omit irrelevant whitespace and comment-only changes,
# perhaps from a slightly-different Autoconf version.
git checkout -f \
sysdeps/csky/configure \
sysdeps/hppa/configure \
sysdeps/riscv/configure \
sysdeps/unix/sysv/linux/csky/configure
# Omit changes that caused a pre-commit check to fail like this:
# remote: *** error: sysdeps/powerpc/powerpc64/ppc-mcount.S: trailing lines
git checkout -f \
sysdeps/powerpc/powerpc64/ppc-mcount.S \
sysdeps/unix/sysv/linux/s390/s390-64/syscall.S
# Omit change that caused a pre-commit check to fail like this:
# remote: *** error: sysdeps/sparc/sparc64/multiarch/memcpy-ultra3.S: last line does not end in newline
git checkout -f sysdeps/sparc/sparc64/multiarch/memcpy-ultra3.S
2019-09-07 05:40:42 +00:00
|
|
|
<https://www.gnu.org/licenses/>. */
|
1996-12-30 01:47:46 +00:00
|
|
|
|
|
|
|
#include <machine/asm.h>
|
2019-07-16 15:17:22 +00:00
|
|
|
#include <libm-alias-finite.h>
|
1996-12-30 01:47:46 +00:00
|
|
|
|
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)
|
2019-07-16 15:17:22 +00:00
|
|
|
libm_alias_finite (__ieee754_acoshl, __acoshl)
|