mirror of
https://sourceware.org/git/glibc.git
synced 2025-01-18 06:30:05 +00:00
update from main archive 960830
Fri Aug 30 19:55:27 1996 Ulrich Drepper <drepper@cygnus.com> * libio/genops.c: Make _cleanup an alias of _IO_cleanup. Reported by Erik Troan. Fri Aug 30 15:40:04 1996 Ulrich Drepper <drepper@cygnus.com> * sysdeps/unix/sysv/linux/Dist: Add sys/procfs.h and sys/sysmacros.h. Reported by Curtiss <1CMC3466@IBM.MTSAC.EDU>. Fri Aug 30 13:53:32 1996 Andreas Jaeger <aj@arthur.pfalz.de> * sysdeps/unix/mman/syscalls.list: `mmap' has 6 arguments, not 5. Fri Aug 30 13:01:10 1996 NIIBE Yutaka <gniibe@mri.co.jp> * sysdeps/i386/fpu/__math.h (tan): Pop 1.0 in ST to get real result. Fri Aug 30 03:33:33 1996 Ulrich Drepper <drepper@cygnus.com> * sysdeps/libm-ieee754/s_cbrtl.c: New file. `long double' implementation. * sysdeps/unix/sysv/linux/i386/Dist: Add clone.S.
This commit is contained in:
parent
924840c542
commit
adfa20781b
26
ChangeLog
26
ChangeLog
@ -1,3 +1,27 @@
|
|||||||
|
Fri Aug 30 19:55:27 1996 Ulrich Drepper <drepper@cygnus.com>
|
||||||
|
|
||||||
|
* libio/genops.c: Make _cleanup an alias of _IO_cleanup.
|
||||||
|
Reported by Erik Troan.
|
||||||
|
|
||||||
|
Fri Aug 30 15:40:04 1996 Ulrich Drepper <drepper@cygnus.com>
|
||||||
|
|
||||||
|
* sysdeps/unix/sysv/linux/Dist: Add sys/procfs.h and
|
||||||
|
sys/sysmacros.h. Reported by Curtiss <1CMC3466@IBM.MTSAC.EDU>.
|
||||||
|
|
||||||
|
Fri Aug 30 13:53:32 1996 Andreas Jaeger <aj@arthur.pfalz.de>
|
||||||
|
|
||||||
|
* sysdeps/unix/mman/syscalls.list: `mmap' has 6 arguments, not 5.
|
||||||
|
|
||||||
|
Fri Aug 30 13:01:10 1996 NIIBE Yutaka <gniibe@mri.co.jp>
|
||||||
|
|
||||||
|
* sysdeps/i386/fpu/__math.h (tan): Pop 1.0 in ST to get
|
||||||
|
real result.
|
||||||
|
|
||||||
|
Fri Aug 30 03:33:33 1996 Ulrich Drepper <drepper@cygnus.com>
|
||||||
|
|
||||||
|
* sysdeps/libm-ieee754/s_cbrtl.c: New file. `long double'
|
||||||
|
implementation.
|
||||||
|
|
||||||
Fri Aug 30 13:39:21 1996 Thomas Bushnell, n/BSG <thomas@gnu.ai.mit.edu>
|
Fri Aug 30 13:39:21 1996 Thomas Bushnell, n/BSG <thomas@gnu.ai.mit.edu>
|
||||||
|
|
||||||
* Makerules (BUILD_CFLAGS): Use @(common-objpfx) for config.h, not
|
* Makerules (BUILD_CFLAGS): Use @(common-objpfx) for config.h, not
|
||||||
@ -23,7 +47,7 @@ Fri Aug 30 13:39:21 1996 Thomas Bushnell, n/BSG <thomas@gnu.ai.mit.edu>
|
|||||||
|
|
||||||
Fri Aug 30 01:26:44 1996 Ulrich Drepper <drepper@cygnus.com>
|
Fri Aug 30 01:26:44 1996 Ulrich Drepper <drepper@cygnus.com>
|
||||||
|
|
||||||
* sysdeps/unix/sysv/linux/i386/Dist: Add close.S.
|
* sysdeps/unix/sysv/linux/i386/Dist: Add clone.S.
|
||||||
* sysdeps/unix/sysv/linux/m68k/Dist: Likewise.
|
* sysdeps/unix/sysv/linux/m68k/Dist: Likewise.
|
||||||
* sysdeps/unix/sysv/linux/alpha/Dist: Likewise.
|
* sysdeps/unix/sysv/linux/alpha/Dist: Likewise.
|
||||||
|
|
||||||
|
@ -25,7 +25,6 @@ k_sinl.c
|
|||||||
k_tanl.c
|
k_tanl.c
|
||||||
|
|
||||||
s_atanl.c
|
s_atanl.c
|
||||||
s_cbrtl.c
|
|
||||||
s_erfl.c
|
s_erfl.c
|
||||||
s_expm1l.c
|
s_expm1l.c
|
||||||
s_log1pl.c
|
s_log1pl.c
|
||||||
|
@ -5,7 +5,6 @@
|
|||||||
#undef _EXTERN_INLINE
|
#undef _EXTERN_INLINE
|
||||||
#define _EXTERN_INLINE /* Define the real function. */
|
#define _EXTERN_INLINE /* Define the real function. */
|
||||||
|
|
||||||
#include "hurd.h"
|
|
||||||
#include "hurd/fd.h"
|
#include "hurd/fd.h"
|
||||||
#include "hurd/signal.h"
|
#include "hurd/signal.h"
|
||||||
#include "hurd/userlink.h"
|
#include "hurd/userlink.h"
|
||||||
|
@ -857,3 +857,7 @@ __io_defs io_defs__;
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#endif /* TODO */
|
#endif /* TODO */
|
||||||
|
|
||||||
|
#ifdef weak_alias
|
||||||
|
weak_alias (_IO_cleanup, _cleanup)
|
||||||
|
#endif
|
||||||
|
@ -204,6 +204,15 @@ do { \
|
|||||||
(d) = iw_u.value; \
|
(d) = iw_u.value; \
|
||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
|
/* Get the more significant 32 bits of a long double mantissa. */
|
||||||
|
|
||||||
|
#define GET_LDOUBLE_MSW(v,d) \
|
||||||
|
do { \
|
||||||
|
ieee_long_double_shape_type sh_u; \
|
||||||
|
sh_u.value = (d); \
|
||||||
|
(v) = sh_u.parts.msw; \
|
||||||
|
} while (0)
|
||||||
|
|
||||||
/* Set the more significant 32 bits of a long double mantissa from an int. */
|
/* Set the more significant 32 bits of a long double mantissa from an int. */
|
||||||
|
|
||||||
#define SET_LDOUBLE_MSW(d,v) \
|
#define SET_LDOUBLE_MSW(d,v) \
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
/* Inline math functions for i387.
|
/* Inline math functions for i387.
|
||||||
Copyright (C) 1995, 1996 Free Software Foundation, Inc.
|
Copyright (C) 1995, 1996 Free Software Foundation, Inc.
|
||||||
Contributed by John C. Bowman <bowman@hagar.ph.utexas.edu>
|
Contributed by John C. Bowman <bowman@ipp-garching.mpg.de>
|
||||||
|
|
||||||
This file is part of the GNU C Library.
|
This file is part of the GNU C Library.
|
||||||
|
|
||||||
@ -119,7 +119,8 @@ tan (double __x)
|
|||||||
{
|
{
|
||||||
register double __value;
|
register double __value;
|
||||||
__asm __volatile__
|
__asm __volatile__
|
||||||
("fptan"
|
("fptan\n\t"
|
||||||
|
"fincstp"
|
||||||
: "=t" (__value) : "0" (__x));
|
: "=t" (__value) : "0" (__x));
|
||||||
|
|
||||||
return __value;
|
return __value;
|
||||||
|
123
sysdeps/libm-ieee754/s_cbrtl.c
Normal file
123
sysdeps/libm-ieee754/s_cbrtl.c
Normal file
@ -0,0 +1,123 @@
|
|||||||
|
/* s_cbrtl.c -- long double version of s_cbrt.c.
|
||||||
|
* Conversion to long double by Ulrich Drepper,
|
||||||
|
* Cygnus Support, drepper@cygnus.com.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* ====================================================
|
||||||
|
* Copyright (C) 1993 by Sun Microsystems, Inc. All rights reserved.
|
||||||
|
*
|
||||||
|
* Developed at SunPro, a Sun Microsystems, Inc. business.
|
||||||
|
* Permission to use, copy, modify, and distribute this
|
||||||
|
* software is freely granted, provided that this notice
|
||||||
|
* is preserved.
|
||||||
|
* ====================================================
|
||||||
|
*/
|
||||||
|
|
||||||
|
#if defined(LIBM_SCCS) && !defined(lint)
|
||||||
|
static char rcsid[] = "$NetBSD: $";
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include "math.h"
|
||||||
|
#include "math_private.h"
|
||||||
|
|
||||||
|
/* cbrtl(x)
|
||||||
|
* Return cube root of x
|
||||||
|
*/
|
||||||
|
#ifdef __STDC__
|
||||||
|
static const u_int32_t
|
||||||
|
#else
|
||||||
|
static u_int32_t
|
||||||
|
#endif
|
||||||
|
B1_EXP = 10921, /* = Int(B1) */
|
||||||
|
B1_MANT = 0x7bc4b064, /* = Int(1.0-0.03306235651)*2**31 */
|
||||||
|
|
||||||
|
B2_EXP = 10900,
|
||||||
|
B2_MANT = 0x7bc4b064; /* = Int(1.0-0.03306235651)*2**31 */
|
||||||
|
|
||||||
|
#ifdef __STDC__
|
||||||
|
static const long double
|
||||||
|
#else
|
||||||
|
static long double
|
||||||
|
#endif
|
||||||
|
C = 5.42857142857142815906e-01L, /* 19/35 */
|
||||||
|
D = -7.05306122448979611050e-01L, /* -864/1225 */
|
||||||
|
E = 1.41428571428571436819e+00L, /* 99/70 */
|
||||||
|
F = 1.60714285714285720630e+00L, /* 45/28 */
|
||||||
|
G = 3.57142857142857150787e-01L; /* 5/14 */
|
||||||
|
|
||||||
|
#ifdef __STDC__
|
||||||
|
long double __cbrtl(long double x)
|
||||||
|
#else
|
||||||
|
long double __cbrtl(x)
|
||||||
|
long double x;
|
||||||
|
#endif
|
||||||
|
{
|
||||||
|
int32_t hx;
|
||||||
|
long double r,s,t=0.0,w;
|
||||||
|
u_int32_t sign, se, x0, x1;
|
||||||
|
|
||||||
|
GET_LDOUBLE_WORDS(se,x0,x1,x);
|
||||||
|
sign=se&0x8000; /* sign= sign(x) */
|
||||||
|
se ^= sign;
|
||||||
|
if(se==0x7fff) return(x+x); /* cbrt(NaN,INF) is itself */
|
||||||
|
if((se|x0|x1)==0)
|
||||||
|
return(x); /* cbrt(0) is itself */
|
||||||
|
|
||||||
|
SET_LDOUBLE_EXP(x,se); /* x <- |x| */
|
||||||
|
|
||||||
|
/* XXX I don't know whether the numbers for correct are correct. The
|
||||||
|
precalculation is extended from 20 bits to 32 bits. This hopefully
|
||||||
|
gives us the needed bits to get us still along with one iteration
|
||||||
|
step. */
|
||||||
|
|
||||||
|
/* rough cbrt to 5 bits */
|
||||||
|
if(se==0) /* subnormal number */
|
||||||
|
{
|
||||||
|
u_int64_t xxl;
|
||||||
|
u_int32_t set,t0,t1;
|
||||||
|
SET_LDOUBLE_EXP(t,0x4035); /* set t= 2**54 */
|
||||||
|
SET_LDOUBLE_MSW(t,0x80000000);
|
||||||
|
t*=x;
|
||||||
|
GET_LDOUBLE_WORDS(set,t0,t1,t);
|
||||||
|
xxl = ((u_int64_t) set) << 32 | t0;
|
||||||
|
xxl /= 3;
|
||||||
|
xxl += B2_EXP << 16 | B2_MANT;
|
||||||
|
t0 = xxl & 0xffffffffu;
|
||||||
|
set = xxl >> 32;
|
||||||
|
SET_LDOUBLE_WORDS(t,set,t0,t1);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
u_int64_t xxl = ((u_int64_t) se) << 32 | x0;
|
||||||
|
xxl /= 3;
|
||||||
|
xxl += B1_EXP << 16 | B1_MANT;
|
||||||
|
SET_LDOUBLE_MSW(t,xxl&0xffffffffu);
|
||||||
|
xxl >>= 32;
|
||||||
|
SET_LDOUBLE_EXP(t,xxl);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* new cbrt to 23 bits, may be implemented in single precision */
|
||||||
|
r=t*t/x;
|
||||||
|
s=C+r*t;
|
||||||
|
t*=G+F/(s+E+D/s);
|
||||||
|
|
||||||
|
/* chopped to 32 bits and make it larger than cbrt(x) */
|
||||||
|
GET_LDOUBLE_WORDS(se,x0,x1,t);
|
||||||
|
SET_LDOUBLE_WORDS(t,se,x0+1,0);
|
||||||
|
|
||||||
|
|
||||||
|
/* one step newton iteration to 53 bits with error less than 0.667 ulps */
|
||||||
|
s=t*t; /* t*t is exact */
|
||||||
|
r=x/s;
|
||||||
|
w=t+t;
|
||||||
|
r=(r-t)/(w+r); /* r-s is exact */
|
||||||
|
t=t+t*r;
|
||||||
|
|
||||||
|
/* retore the sign bit */
|
||||||
|
GET_LDOUBLE_EXP(se,t);
|
||||||
|
SET_LDOUBLE_EXP(t,se|sign);
|
||||||
|
return(t);
|
||||||
|
}
|
||||||
|
weak_alias (__cbrtl, cbrtl)
|
@ -1,7 +1,7 @@
|
|||||||
# File name Caller Syscall name # args Strong name Weak names
|
# File name Caller Syscall name # args Strong name Weak names
|
||||||
|
|
||||||
madvise - madvise 3 madvise
|
madvise - madvise 3 madvise
|
||||||
mmap - mmap 5 __mmap mmap
|
mmap - mmap 6 __mmap mmap
|
||||||
mprotect - mprotect 3 __mprotect mprotect
|
mprotect - mprotect 3 __mprotect mprotect
|
||||||
msync - msync 2 msync
|
msync - msync 2 msync
|
||||||
munmap - munmap 2 __munmap munmap
|
munmap - munmap 2 __munmap munmap
|
||||||
|
@ -7,10 +7,12 @@ sys/kdaemon.h
|
|||||||
sys/klog.h
|
sys/klog.h
|
||||||
sys/module.h
|
sys/module.h
|
||||||
sys/mount.h
|
sys/mount.h
|
||||||
|
sys/procfs.h
|
||||||
sys/quota.h
|
sys/quota.h
|
||||||
sys/socketcall.h
|
sys/socketcall.h
|
||||||
sys/sysctl.h
|
sys/sysctl.h
|
||||||
sys/sysinfo.h
|
sys/sysinfo.h
|
||||||
|
sys/sysmacros.h
|
||||||
sys/timex.h
|
sys/timex.h
|
||||||
sys/user.h
|
sys/user.h
|
||||||
termio.h
|
termio.h
|
||||||
|
Loading…
Reference in New Issue
Block a user