mirror of
				https://sourceware.org/git/glibc.git
				synced 2025-10-26 00:57:39 +03:00 
			
		
		
		
	update from main archive 970101
Wed Jan 1 15:15:00 1997 Ulrich Drepper <drepper@cygnus.com> * libio/Makefile (routines): Add fcloseall. * libio/fcloseall.c: New file. * libio/stdio.h [__USE_GNU]: Add prototype for fcloseall. * libio/iofclose.c: Don't close all streams when argument is NULL. * stdio/Makefile (routines): Add fcloseall. * stdio/fcloseall.c: New file. * stdio/stdio.h [__USE_GNU]: Add prototype for fcloseall. * stdio/fclose.c: Don't close all streams when argument is NULL. * manual/stdio.texi: Document fcloseall. * sysdeps/generic/abort.c: Call __fcloseall instead of fclose with NULL argument. * socket/sys/un.h (SUN_LEN): Add cast. * sunrpc/auth_unix.c (authunix_create): Change parameter types of uid, gid, and aup_gids to uid_t and gid_t respectively. (authunix_create_default): Likewise. (authunix_refresh): Correct cast for aup_gids assignment. * sunrpc/rpc/auth.h (authunix_create): Correct types in declaration. * sunrpc/rpc/auth_unix.h (struct authunix_parms): Correct field types to uid_t and gid_t respectively. (struct short_hand_verf): Likewise. Reported by Andreas Schwab. * sysdeps/ieee754/Makefile: New file. Make sure ieee754.h gets installed. * sysdeps/ieee754/ieee754.h: Protect against multiple inclusion and use in C++ programs. * sysdeps/libm-i387/e_pow.S: New file. Optimized ix87 assembler version of pow() function. * sysdeps/libm-i387/e_powf.S: New file. Float version. * sysdeps/libm-i387/e_powl.S: New file. Long double version. * sysdeps/libm-i387/s_expm1.S: New file. Optimized ix87 assembler version of expm1() function. * sysdeps/libm-i387/s_expm1f.S: New file. Float version. * sysdeps/libm-i387/s_expm1l.S: New file. Long double version. * sysdeps/libm-i387/e_exp.S: Optimize handling of +-Inf. Better handling of computation stack from current NetBSD sources. * sysdeps/libm-i387/e_expf.S: Likewise. * sysdeps/libm-i387/e_expl.S: Likewise. * sysdeps/libm-i387/e_log.S: Use fstp instead of fincstp. * sysdeps/libm-i387/e_logf.S: Likewise. * sysdeps/libm-i387/e_logl.S: Likewise. * sysdeps/libm-i387/e_log10.S: Likewise. * sysdeps/libm-i387/e_log10f.S: Likewise. * sysdeps/libm-i387/e_log10l.S: Likewise. * sysdeps/libm-i387/s_asinh.S: Likewise. * sysdeps/libm-i387/s_asinhf.S: Likewise. * sysdeps/libm-i387/s_asinhl.S: Likewise. * sysdeps/libm-i387/s_significandl.S: Likewise. * sysdeps/libm-i387/s_ceil.S: Don't create stack frame. Modify stack pointer directly. Use 32 bit instead of 16 bit operations. * sysdeps/libm-i387/s_ceilf.S: Likewise. * sysdeps/libm-i387/s_ceill.S: Likewise. * sysdeps/libm-i387/s_floor.S: Likewise. * sysdeps/libm-i387/s_floorf.S: Likewise. * sysdeps/libm-i387/s_floorl.S: Likewise. * sysdeps/libm-ieee754/e_coshf.c (huge): Don't declare volatile. * sysdeps/libm-ieee754/e_expf.c: Likewise. * sysdeps/libm-ieee754/e_powf.c: Likewise. From current NetBSD sources. * sysdeps/libm-ieee754/e_hypot.c (__ieee754_hypot): Don't initialize `a' and `b' in definition. * sysdeps/libm-ieee754/e_hypotf.c: Likewise. * sysdeps/libm-ieee754/e_hypotl.c: New file. Long double implementation. * sysdeps/libm-ieee754/e_sinhl.c: New file. Long double implementation. * sysdeps/stub/e_hypotl.c: Removed. We have a real version now. * sysdeps/stub/e_sinhl.c: Removed. * sysdeps/posix/sigpause.c (__sigpause): Use sigdelset instead of sigaddset. Reported by Andreas Schwab. (__default_sigpause): New function. Call __sigpause as BSD version. Make this the default function by providing alias sigpause. * sysdeps/stub/sigpause.c (__default_sigpause): New funciton. Simply fail. Provide alias sigpause. Wed Jan 1 12:34:54 1997 Ulrich Drepper <drepper@cygnus.com> * po/es.po: Update for glibc-1.98. * po/fr.po: Likewise. * po/sv.po: New file. Swedish translation. Wed Jan 1 12:18:07 1997 MacGyver <macgyver@tos.net> * values.h: Fix typos: use SHRT_MAX but SHORT_MAX and SHRT_MIN but SHORT_MIN. Tue Dec 24 23:10:21 1996 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de> * Makefile: Replace `stubs.h' by `gnu/stubs.h'. * features.h: Include <gnu/stubs.h> instead of <stubs.h>. Tue Dec 24 22:16:55 1996 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de> * Makefile (subdirs): Move `elf' last so that librtld.so isn't relinked in the `make others' pass if an add-on adds something to libc. Mon Dec 23 21:23:16 1996 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de> * sysdeps/m68k/abort-instr.h: New File. Mon Dec 23 21:16:38 1996 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de> * sysdeps/m68k/Makefile ($(subdir)=elf): Define CFLAGS-rtld.c to prevent warning. Mon Dec 23 21:14:22 1996 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de> * resolv/Makefile (subdirs-dirs): Define. Mon Dec 23 20:56:49 1996 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de> * sysdeps/gnu/utmpbits.h (struct utmp): Fix padding. Mon Dec 30 11:05:11 1996 Ulrich Drepper <drepper@cygnus.com> Update from ADO tzcode1996o. * time/difftime.c: De-ANSI-declfy. Simplify computation of hibit according to ADO version. * time/zic.c: Correct typo is message. Update from ADO tzdata1996n. * time/asia: Updated. * time/australasia: Likewise. * time/europe: Likewise. * time/northamerica: Likewise. * time/southamerica: Likewise.
This commit is contained in:
		
							
								
								
									
										144
									
								
								ChangeLog
									
									
									
									
									
								
							
							
						
						
									
										144
									
								
								ChangeLog
									
									
									
									
									
								
							| @@ -1,3 +1,147 @@ | |||||||
|  | Wed Jan  1 15:15:00 1997  Ulrich Drepper  <drepper@cygnus.com> | ||||||
|  |  | ||||||
|  | 	* libio/Makefile (routines): Add fcloseall. | ||||||
|  | 	* libio/fcloseall.c: New file. | ||||||
|  | 	* libio/stdio.h [__USE_GNU]: Add prototype for fcloseall. | ||||||
|  | 	* libio/iofclose.c: Don't close all streams when argument is NULL. | ||||||
|  |  | ||||||
|  | 	* stdio/Makefile (routines): Add fcloseall. | ||||||
|  | 	* stdio/fcloseall.c: New file. | ||||||
|  | 	* stdio/stdio.h [__USE_GNU]: Add prototype for fcloseall. | ||||||
|  | 	* stdio/fclose.c: Don't close all streams when argument is NULL. | ||||||
|  |  | ||||||
|  | 	* manual/stdio.texi: Document fcloseall. | ||||||
|  |  | ||||||
|  | 	* sysdeps/generic/abort.c: Call __fcloseall instead of fclose with | ||||||
|  | 	NULL argument. | ||||||
|  |  | ||||||
|  | 	* socket/sys/un.h (SUN_LEN): Add cast. | ||||||
|  |  | ||||||
|  | 	* sunrpc/auth_unix.c (authunix_create): Change parameter types | ||||||
|  | 	of uid, gid, and aup_gids to uid_t and gid_t respectively. | ||||||
|  | 	(authunix_create_default): Likewise. | ||||||
|  | 	(authunix_refresh): Correct cast for aup_gids assignment. | ||||||
|  | 	* sunrpc/rpc/auth.h (authunix_create): Correct types in declaration. | ||||||
|  | 	* sunrpc/rpc/auth_unix.h (struct authunix_parms): Correct field | ||||||
|  | 	types to uid_t and gid_t respectively. | ||||||
|  | 	(struct short_hand_verf): Likewise. | ||||||
|  | 	Reported by Andreas Schwab. | ||||||
|  |  | ||||||
|  | 	* sysdeps/ieee754/Makefile: New file.  Make sure ieee754.h gets | ||||||
|  | 	installed. | ||||||
|  | 	* sysdeps/ieee754/ieee754.h: Protect against multiple inclusion and | ||||||
|  | 	use in C++ programs. | ||||||
|  |  | ||||||
|  | 	* sysdeps/libm-i387/e_pow.S: New file.  Optimized ix87 assembler | ||||||
|  | 	version of pow() function. | ||||||
|  | 	* sysdeps/libm-i387/e_powf.S: New file.  Float version. | ||||||
|  | 	* sysdeps/libm-i387/e_powl.S: New file.  Long double version. | ||||||
|  |  | ||||||
|  | 	* sysdeps/libm-i387/s_expm1.S: New file.  Optimized ix87 assembler | ||||||
|  | 	version of expm1() function. | ||||||
|  | 	* sysdeps/libm-i387/s_expm1f.S: New file.  Float version. | ||||||
|  | 	* sysdeps/libm-i387/s_expm1l.S: New file.  Long double version. | ||||||
|  |  | ||||||
|  | 	* sysdeps/libm-i387/e_exp.S: Optimize handling of +-Inf. | ||||||
|  | 	Better handling of computation stack from current NetBSD sources. | ||||||
|  | 	* sysdeps/libm-i387/e_expf.S: Likewise. | ||||||
|  | 	* sysdeps/libm-i387/e_expl.S: Likewise. | ||||||
|  |  | ||||||
|  | 	* sysdeps/libm-i387/e_log.S: Use fstp instead of fincstp. | ||||||
|  | 	* sysdeps/libm-i387/e_logf.S: Likewise. | ||||||
|  | 	* sysdeps/libm-i387/e_logl.S: Likewise. | ||||||
|  | 	* sysdeps/libm-i387/e_log10.S: Likewise. | ||||||
|  | 	* sysdeps/libm-i387/e_log10f.S: Likewise. | ||||||
|  | 	* sysdeps/libm-i387/e_log10l.S: Likewise. | ||||||
|  | 	* sysdeps/libm-i387/s_asinh.S: Likewise. | ||||||
|  | 	* sysdeps/libm-i387/s_asinhf.S: Likewise. | ||||||
|  | 	* sysdeps/libm-i387/s_asinhl.S: Likewise. | ||||||
|  | 	* sysdeps/libm-i387/s_significandl.S: Likewise. | ||||||
|  |  | ||||||
|  | 	* sysdeps/libm-i387/s_ceil.S: Don't create stack frame.  Modify | ||||||
|  | 	stack pointer directly.  Use 32 bit instead of 16 bit operations. | ||||||
|  | 	* sysdeps/libm-i387/s_ceilf.S: Likewise. | ||||||
|  | 	* sysdeps/libm-i387/s_ceill.S: Likewise. | ||||||
|  | 	* sysdeps/libm-i387/s_floor.S: Likewise. | ||||||
|  | 	* sysdeps/libm-i387/s_floorf.S: Likewise. | ||||||
|  | 	* sysdeps/libm-i387/s_floorl.S: Likewise. | ||||||
|  |  | ||||||
|  | 	* sysdeps/libm-ieee754/e_coshf.c (huge): Don't declare volatile. | ||||||
|  | 	* sysdeps/libm-ieee754/e_expf.c: Likewise. | ||||||
|  | 	* sysdeps/libm-ieee754/e_powf.c: Likewise. | ||||||
|  | 	From current NetBSD sources. | ||||||
|  |  | ||||||
|  | 	* sysdeps/libm-ieee754/e_hypot.c (__ieee754_hypot): Don't initialize | ||||||
|  | 	`a' and `b' in definition. | ||||||
|  | 	* sysdeps/libm-ieee754/e_hypotf.c: Likewise. | ||||||
|  |  | ||||||
|  | 	* sysdeps/libm-ieee754/e_hypotl.c: New file.  Long double | ||||||
|  | 	implementation. | ||||||
|  | 	* sysdeps/libm-ieee754/e_sinhl.c: New file.  Long double | ||||||
|  | 	implementation. | ||||||
|  | 	* sysdeps/stub/e_hypotl.c: Removed.  We have a real version now. | ||||||
|  | 	* sysdeps/stub/e_sinhl.c: Removed. | ||||||
|  |  | ||||||
|  | 	* sysdeps/posix/sigpause.c (__sigpause): Use sigdelset instead of | ||||||
|  | 	sigaddset.  Reported by Andreas Schwab. | ||||||
|  | 	(__default_sigpause): New function.  Call __sigpause as BSD version. | ||||||
|  | 	Make this the default function by providing alias sigpause. | ||||||
|  | 	* sysdeps/stub/sigpause.c (__default_sigpause): New funciton. | ||||||
|  | 	Simply fail.  Provide alias sigpause. | ||||||
|  |  | ||||||
|  | Wed Jan  1 12:34:54 1997  Ulrich Drepper  <drepper@cygnus.com> | ||||||
|  |  | ||||||
|  | 	* po/es.po: Update for glibc-1.98. | ||||||
|  | 	* po/fr.po: Likewise. | ||||||
|  | 	* po/sv.po: New file.  Swedish translation. | ||||||
|  |  | ||||||
|  | Wed Jan  1 12:18:07 1997   MacGyver  <macgyver@tos.net> | ||||||
|  |  | ||||||
|  | 	* values.h: Fix typos: use SHRT_MAX but SHORT_MAX and SHRT_MIN but | ||||||
|  | 	SHORT_MIN. | ||||||
|  |  | ||||||
|  | Tue Dec 24 23:10:21 1996  Andreas Schwab  <schwab@issan.informatik.uni-dortmund.de> | ||||||
|  |  | ||||||
|  | 	* Makefile: Replace `stubs.h' by `gnu/stubs.h'. | ||||||
|  | 	* features.h: Include <gnu/stubs.h> instead of <stubs.h>. | ||||||
|  |  | ||||||
|  | Tue Dec 24 22:16:55 1996  Andreas Schwab  <schwab@issan.informatik.uni-dortmund.de> | ||||||
|  |  | ||||||
|  | 	* Makefile (subdirs): Move `elf' last so that librtld.so isn't | ||||||
|  | 	relinked in the `make others' pass if an add-on adds something to | ||||||
|  | 	libc. | ||||||
|  |  | ||||||
|  | Mon Dec 23 21:23:16 1996  Andreas Schwab  <schwab@issan.informatik.uni-dortmund.de> | ||||||
|  |  | ||||||
|  | 	* sysdeps/m68k/abort-instr.h: New File. | ||||||
|  |  | ||||||
|  | Mon Dec 23 21:16:38 1996  Andreas Schwab  <schwab@issan.informatik.uni-dortmund.de> | ||||||
|  |  | ||||||
|  | 	* sysdeps/m68k/Makefile ($(subdir)=elf): Define CFLAGS-rtld.c | ||||||
|  | 	to prevent warning. | ||||||
|  |  | ||||||
|  | Mon Dec 23 21:14:22 1996  Andreas Schwab  <schwab@issan.informatik.uni-dortmund.de> | ||||||
|  |  | ||||||
|  | 	* resolv/Makefile (subdirs-dirs): Define. | ||||||
|  |  | ||||||
|  | Mon Dec 23 20:56:49 1996  Andreas Schwab  <schwab@issan.informatik.uni-dortmund.de> | ||||||
|  |  | ||||||
|  | 	* sysdeps/gnu/utmpbits.h (struct utmp): Fix padding. | ||||||
|  |  | ||||||
|  | Mon Dec 30 11:05:11 1996  Ulrich Drepper  <drepper@cygnus.com> | ||||||
|  |  | ||||||
|  | 	Update from ADO tzcode1996o. | ||||||
|  | 	* time/difftime.c: De-ANSI-declfy.  Simplify computation of hibit | ||||||
|  | 	according to ADO version. | ||||||
|  | 	* time/zic.c: Correct typo is message. | ||||||
|  |  | ||||||
|  | 	Update from ADO tzdata1996n. | ||||||
|  | 	* time/asia: Updated. | ||||||
|  | 	* time/australasia: Likewise. | ||||||
|  | 	* time/europe: Likewise. | ||||||
|  | 	* time/northamerica: Likewise. | ||||||
|  | 	* time/southamerica: Likewise. | ||||||
|  |  | ||||||
| Mon Dec 30 01:32:59 1996  Ulrich Drepper  <drepper@cygnus.com> | Mon Dec 30 01:32:59 1996  Ulrich Drepper  <drepper@cygnus.com> | ||||||
|  |  | ||||||
| 	* tme/localtime.c: Rewrite so that localtime_r does not call tzset, | 	* tme/localtime.c: Rewrite so that localtime_r does not call tzset, | ||||||
|   | |||||||
							
								
								
									
										12
									
								
								Makefile
									
									
									
									
									
								
							
							
						
						
									
										12
									
								
								Makefile
									
									
									
									
									
								
							| @@ -54,8 +54,8 @@ endif | |||||||
| subdirs = csu assert ctype db locale intl catgets math setjmp signal stdlib \ | subdirs = csu assert ctype db locale intl catgets math setjmp signal stdlib \ | ||||||
| 	  stdio-common $(stdio) $(malloc) string wcsmbs time dirent grp pwd \ | 	  stdio-common $(stdio) $(malloc) string wcsmbs time dirent grp pwd \ | ||||||
| 	  posix io termios resource misc login socket sysvipc gmon gnulib \ | 	  posix io termios resource misc login socket sysvipc gmon gnulib \ | ||||||
| 	  wctype manual shadow md5-crypt nss $(sysdep-subdirs) elf po \ | 	  wctype manual shadow md5-crypt nss $(sysdep-subdirs) po \ | ||||||
| 	  $(add-ons) | 	  $(add-ons) elf | ||||||
| export subdirs := $(subdirs)	# Benign, useless in GNU make before 3.63. | export subdirs := $(subdirs)	# Benign, useless in GNU make before 3.63. | ||||||
|  |  | ||||||
| # The mach and hurd subdirectories have many generated header files which | # The mach and hurd subdirectories have many generated header files which | ||||||
| @@ -90,7 +90,7 @@ before-compile = $(objpfx)version-info.h | |||||||
| echo-headers: subdir_echo-headers | echo-headers: subdir_echo-headers | ||||||
|  |  | ||||||
| # What to install. | # What to install. | ||||||
| install-others = $(includedir)/stubs.h | install-others = $(includedir)/gnu/stubs.h | ||||||
| ifeq (yes,$(build-shared)) | ifeq (yes,$(build-shared)) | ||||||
| install-others += $(includedir)/gnu/lib-names.h | install-others += $(includedir)/gnu/lib-names.h | ||||||
| endif | endif | ||||||
| @@ -158,7 +158,7 @@ $(version.c-objects): $(objpfx)version-info.h | |||||||
|  |  | ||||||
| # Makerules creates a file `stub-$(subdir)' for each subdirectory, which | # Makerules creates a file `stub-$(subdir)' for each subdirectory, which | ||||||
| # contains `#define __stub_FUNCTION' for each function which is a stub. | # contains `#define __stub_FUNCTION' for each function which is a stub. | ||||||
| # Here we paste all of these together into <stubs.h>. | # Here we paste all of these together into <gnu/stubs.h>. | ||||||
|  |  | ||||||
| subdir-stubs := $(foreach dir,$(subdirs),$(common-objpfx)stub-$(dir)) | subdir-stubs := $(foreach dir,$(subdirs),$(common-objpfx)stub-$(dir)) | ||||||
|  |  | ||||||
| @@ -168,7 +168,7 @@ subdir-stubs := $(foreach dir,$(subdirs),$(common-objpfx)stub-$(dir)) | |||||||
| # iterates over all the subdirs; subdir_install in each subdir depends on | # iterates over all the subdirs; subdir_install in each subdir depends on | ||||||
| # the subdir's stubs file.  Having more direct dependencies would result in | # the subdir's stubs file.  Having more direct dependencies would result in | ||||||
| # extra iterations over the list for subdirs and many recursive makes. | # extra iterations over the list for subdirs and many recursive makes. | ||||||
| $(includedir)/stubs.h: subdir_install | $(includedir)/gnu/stubs.h: subdir_install | ||||||
| 	@rm -f $(objpfx)stubs.h | 	@rm -f $(objpfx)stubs.h | ||||||
| 	(echo '/* This file is automatically generated.';\ | 	(echo '/* This file is automatically generated.';\ | ||||||
| 	 echo '   It defines a symbol `__stub_FUNCTION'\'' for each function';\ | 	 echo '   It defines a symbol `__stub_FUNCTION'\'' for each function';\ | ||||||
| @@ -182,7 +182,7 @@ $(includedir)/stubs.h: subdir_install | |||||||
|  |  | ||||||
| ifeq (yes,$(build-shared)) | ifeq (yes,$(build-shared)) | ||||||
|  |  | ||||||
| # Like stubs.h the gnu/lib-names.h header is not used while building the | # Like gnu/stubs.h the gnu/lib-names.h header is not used while building the | ||||||
| # libc itself.  So we generate it while installing. | # libc itself.  So we generate it while installing. | ||||||
| $(includedir)/gnu/lib-names.h: $(common-objpfx)soversions.mk | $(includedir)/gnu/lib-names.h: $(common-objpfx)soversions.mk | ||||||
| 	@rm -f $(objpfx)lib-names.h | 	@rm -f $(objpfx)lib-names.h | ||||||
|   | |||||||
| @@ -208,15 +208,15 @@ | |||||||
| /* This is here only because every header file already includes this one.  */ | /* This is here only because every header file already includes this one.  */ | ||||||
| #ifndef _LIBC | #ifndef _LIBC | ||||||
| /* Get the definitions of all the appropriate `__stub_FUNCTION' symbols. | /* Get the definitions of all the appropriate `__stub_FUNCTION' symbols. | ||||||
|    <stubs.h> contains `#define __stub_FUNCTION' when FUNCTION is a stub |    <gnu/stubs.h> contains `#define __stub_FUNCTION' when FUNCTION is a stub | ||||||
|    which will always return failure (and set errno to ENOSYS). |    which will always return failure (and set errno to ENOSYS). | ||||||
|  |  | ||||||
|    We avoid including <stubs.h> when compiling the C library itself to |    We avoid including <gnu/stubs.h> when compiling the C library itself to | ||||||
|    avoid a dependency loop.  stubs.h depends on every object file.  If |    avoid a dependency loop.  stubs.h depends on every object file.  If | ||||||
|    this #include were done for the library source code, then every object |    this #include were done for the library source code, then every object | ||||||
|    file would depend on stubs.h.  */ |    file would depend on stubs.h.  */ | ||||||
|  |  | ||||||
| #include <stubs.h> | #include <gnu/stubs.h> | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #endif	/* features.h  */ | #endif	/* features.h  */ | ||||||
|   | |||||||
| @@ -32,7 +32,7 @@ routines	:=							      \ | |||||||
| 									      \ | 									      \ | ||||||
| 	clearerr feof ferror fgetc fileno fputc freopen fseek getc getchar    \ | 	clearerr feof ferror fgetc fileno fputc freopen fseek getc getchar    \ | ||||||
| 	memstream pclose putc putchar rewind setbuf setlinebuf vasprintf      \ | 	memstream pclose putc putchar rewind setbuf setlinebuf vasprintf      \ | ||||||
| 	vdprintf vscanf vsnprintf obprintf				      \ | 	vdprintf vscanf vsnprintf obprintf fcloseall			      \ | ||||||
| 									      \ | 									      \ | ||||||
| 	libc_fatal | 	libc_fatal | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										37
									
								
								libio/fcloseall.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										37
									
								
								libio/fcloseall.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,37 @@ | |||||||
|  | /* | ||||||
|  | Copyright (C) 1993, 1995, 1996 Free Software Foundation, Inc. | ||||||
|  |  | ||||||
|  | This file is part of the GNU IO Library.  This library is free | ||||||
|  | software; you can redistribute it and/or modify it under the | ||||||
|  | terms of the GNU General Public License as published by the | ||||||
|  | Free Software Foundation; either version 2, or (at your option) | ||||||
|  | any later version. | ||||||
|  |  | ||||||
|  | This 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 General Public License for more details. | ||||||
|  |  | ||||||
|  | You should have received a copy of the GNU General Public License | ||||||
|  | along with this library; see the file COPYING.  If not, write to the Free | ||||||
|  | Software Foundation, 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA. | ||||||
|  |  | ||||||
|  | As a special exception, if you link this library with files | ||||||
|  | compiled with a GNU compiler to produce an executable, this does not cause | ||||||
|  | the resulting executable to be covered by the GNU General Public License. | ||||||
|  | This exception does not however invalidate any other reasons why | ||||||
|  | the executable file might be covered by the GNU General Public License. */ | ||||||
|  |  | ||||||
|  | #include "libioP.h" | ||||||
|  | #ifdef __STDC__ | ||||||
|  | #include <stdlib.h> | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | int | ||||||
|  | __fcloseall () | ||||||
|  | { | ||||||
|  |   /* Close all streams.  */ | ||||||
|  |   _IO_cleanup (); | ||||||
|  |   return 0; | ||||||
|  | } | ||||||
|  | weak_alias (__fcloseall, fcloseall) | ||||||
| @@ -33,14 +33,6 @@ _IO_fclose (fp) | |||||||
| { | { | ||||||
|   int status; |   int status; | ||||||
|  |  | ||||||
|   if (fp == NULL) |  | ||||||
|     { |  | ||||||
|       /* Close all streams.  */ |  | ||||||
|       _IO_cleanup (); |  | ||||||
|       status = 0; |  | ||||||
|     } |  | ||||||
|   else |  | ||||||
|     { |  | ||||||
|   CHECK_FILE(fp, EOF); |   CHECK_FILE(fp, EOF); | ||||||
|  |  | ||||||
|   _IO_cleanup_region_start ((void (*) __P ((void *))) _IO_funlockfile, fp); |   _IO_cleanup_region_start ((void (*) __P ((void *))) _IO_funlockfile, fp); | ||||||
| @@ -56,7 +48,6 @@ _IO_fclose (fp) | |||||||
|       fp->_IO_file_flags = 0; |       fp->_IO_file_flags = 0; | ||||||
|       free(fp); |       free(fp); | ||||||
|     } |     } | ||||||
|     } |  | ||||||
|  |  | ||||||
|   return status; |   return status; | ||||||
| } | } | ||||||
|   | |||||||
| @@ -166,6 +166,9 @@ extern int __vsscanf __P ((__const char *, __const char *, _G_va_list)); | |||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #ifdef __USE_GNU | #ifdef __USE_GNU | ||||||
|  | extern int __fcloseall __P ((void)); | ||||||
|  | extern int fcloseall __P ((void)); | ||||||
|  |  | ||||||
| struct obstack; | struct obstack; | ||||||
| extern int obstack_vprintf __P ((struct obstack *__obstack, | extern int obstack_vprintf __P ((struct obstack *__obstack, | ||||||
| 				 __const char *__fmt, _G_va_list)); | 				 __const char *__fmt, _G_va_list)); | ||||||
|   | |||||||
| @@ -279,6 +279,27 @@ you are using NFS. | |||||||
| The function @code{fclose} is declared in @file{stdio.h}. | The function @code{fclose} is declared in @file{stdio.h}. | ||||||
| @end deftypefun | @end deftypefun | ||||||
|  |  | ||||||
|  | To close all streams currently available the GNU C Library provides | ||||||
|  | another function. | ||||||
|  |  | ||||||
|  | @comment stdio.h | ||||||
|  | @comment GNU | ||||||
|  | @deftypefun int fcloseall (void) | ||||||
|  | This function causes all open streams of the process to be closed and | ||||||
|  | the connection to corresponding files to be broken.  All buffered data | ||||||
|  | is written and any buffered inputis discarded.  The @code{fcloseall} | ||||||
|  | function returns a value of @code{0} if all the files were closed | ||||||
|  | successfully, and @code{EOF} if an error was detected. | ||||||
|  |  | ||||||
|  | This function should be used in only in special situation, e.g., when an | ||||||
|  | error occurred and the program must be aborted.  Normally each single | ||||||
|  | stream should be closed separately so that problems with one stream can | ||||||
|  | be identifier.  It is also problematic since the standard streams | ||||||
|  | (@pxref{Standard Streams}) will also be closed. | ||||||
|  |  | ||||||
|  | The function @code{fcloseall} is declared in @file{stdio.h}. | ||||||
|  | @end deftypefun | ||||||
|  |  | ||||||
| If the @code{main} function to your program returns, or if you call the | If the @code{main} function to your program returns, or if you call the | ||||||
| @code{exit} function (@pxref{Normal Termination}), all open streams are | @code{exit} function (@pxref{Normal Termination}), all open streams are | ||||||
| automatically closed properly.  If your program terminates in any other | automatically closed properly.  If your program terminates in any other | ||||||
|   | |||||||
| @@ -33,6 +33,7 @@ libresolv-routines := gethnamaddr res_comp res_debug	\ | |||||||
| 		      res_data res_mkquery res_query res_send		\ | 		      res_data res_mkquery res_query res_send		\ | ||||||
| 		      inet_net_ntop inet_net_pton inet_neta base64 | 		      inet_net_ntop inet_net_pton inet_neta base64 | ||||||
|  |  | ||||||
|  | subdirs-dirs = nss_dns | ||||||
| vpath %.c nss_dns | vpath %.c nss_dns | ||||||
|  |  | ||||||
| libnss_dns-routines	:= dns-host dns-network | libnss_dns-routines	:= dns-host dns-network | ||||||
|   | |||||||
| @@ -37,7 +37,7 @@ struct sockaddr_un | |||||||
|  |  | ||||||
|  |  | ||||||
| /* Evaluate to actual length of the `sockaddr_un' structure.  */ | /* Evaluate to actual length of the `sockaddr_un' structure.  */ | ||||||
| #define SUN_LEN(ptr) (((struct sockaddr_un *) 0)->sun_path		      \ | #define SUN_LEN(ptr) ((size_t) (((struct sockaddr_un *) 0)->sun_path)	      \ | ||||||
| 		      + strlen ((ptr)->sun_path)) | 		      + strlen ((ptr)->sun_path)) | ||||||
|  |  | ||||||
| __END_DECLS | __END_DECLS | ||||||
|   | |||||||
| @@ -12,9 +12,9 @@ | |||||||
| # Library General Public License for more details. | # Library General Public License for more details. | ||||||
|  |  | ||||||
| # You should have received a copy of the GNU Library General Public | # 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 | # License along with the GNU C Library; see the file COPYING.LIB.  If not, | ||||||
| # not, write to the Free Software Foundation, Inc., 675 Mass Ave, | # write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330, | ||||||
| # Cambridge, MA 02139, USA. | # Boston, MA 02111-1307, USA. | ||||||
|  |  | ||||||
| # | # | ||||||
| #	Specific makefile for stdio. | #	Specific makefile for stdio. | ||||||
| @@ -34,7 +34,7 @@ routines	:=							      \ | |||||||
| 	fputc putc putchar						      \ | 	fputc putc putchar						      \ | ||||||
| 	fgets gets fputs puts						      \ | 	fgets gets fputs puts						      \ | ||||||
| 	getdelim							      \ | 	getdelim							      \ | ||||||
| 	fclose fflush							      \ | 	fclose fcloseall fflush						      \ | ||||||
| 	vdprintf vsnprintf vsprintf vasprintf vsscanf vscanf		      \ | 	vdprintf vsnprintf vsprintf vasprintf vsscanf vscanf		      \ | ||||||
| 	memstream obstream linewrap					      \ | 	memstream obstream linewrap					      \ | ||||||
| 	internals sysd-stdio pipestream stdio_init libc_fatal | 	internals sysd-stdio pipestream stdio_init libc_fatal | ||||||
|   | |||||||
| @@ -26,21 +26,11 @@ | |||||||
| /* Close a stream.  */ | /* Close a stream.  */ | ||||||
| int | int | ||||||
| fclose (stream) | fclose (stream) | ||||||
|      register FILE *stream; |      FILE *stream; | ||||||
| { | { | ||||||
|   int status; |   int status; | ||||||
|  |  | ||||||
|   if (stream == NULL) |   if (!__validfp (stream)) | ||||||
|     { |  | ||||||
|       /* Close all streams.  */ |  | ||||||
|       register FILE *f; |  | ||||||
|       for (f = __stdio_head; f != NULL; f = f->__next) |  | ||||||
| 	if (__validfp(f)) |  | ||||||
| 	  (void) fclose(f); |  | ||||||
|       return 0; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|   if (!__validfp(stream)) |  | ||||||
|     { |     { | ||||||
|       __set_errno (EINVAL); |       __set_errno (EINVAL); | ||||||
|       return EOF; |       return EOF; | ||||||
| @@ -53,18 +43,18 @@ fclose (stream) | |||||||
|  |  | ||||||
|   /* Free the buffer's storage.  */ |   /* Free the buffer's storage.  */ | ||||||
|   if (stream->__buffer != NULL && !stream->__userbuf) |   if (stream->__buffer != NULL && !stream->__userbuf) | ||||||
|     free(stream->__buffer); |     free (stream->__buffer); | ||||||
|  |  | ||||||
|   /* Close the system file descriptor.  */ |   /* Close the system file descriptor.  */ | ||||||
|   if (stream->__io_funcs.__close != NULL) |   if (stream->__io_funcs.__close != NULL) | ||||||
|     status = (*stream->__io_funcs.__close)(stream->__cookie); |     status = (*stream->__io_funcs.__close) (stream->__cookie); | ||||||
|   else if (!stream->__seen && stream->__cookie != NULL) |   else if (!stream->__seen && stream->__cookie != NULL) | ||||||
|     status = __stdio_close(stream->__cookie); |     status = __stdio_close (stream->__cookie); | ||||||
|   else |   else | ||||||
|     status = 0; |     status = 0; | ||||||
|  |  | ||||||
|   /* Nuke the stream, making it available for re-use.  */ |   /* Nuke the stream, making it available for re-use.  */ | ||||||
|   __invalidate(stream); |   __invalidate (stream); | ||||||
|  |  | ||||||
|   return status < 0 ? EOF : 0; |   return status < 0 ? EOF : 0; | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										37
									
								
								stdio/fcloseall.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										37
									
								
								stdio/fcloseall.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,37 @@ | |||||||
|  | /* Copyright (C) 1991, 1995, 1996 Free Software Foundation, Inc. | ||||||
|  |    This file is part of the GNU C Library. | ||||||
|  |  | ||||||
|  |    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.  */ | ||||||
|  |  | ||||||
|  | #include <stddef.h> | ||||||
|  | #include <stdio.h> | ||||||
|  | #include <stdlib.h> | ||||||
|  | #include <string.h> | ||||||
|  | #include <errno.h> | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /* Close a stream.  */ | ||||||
|  | int | ||||||
|  | __fcloseall () | ||||||
|  | { | ||||||
|  |   /* Close all streams.  */ | ||||||
|  |   register FILE *f; | ||||||
|  |   for (f = __stdio_head; f != NULL; f = f->__next) | ||||||
|  |     if (__validfp(f)) | ||||||
|  |       (void) fclose(f); | ||||||
|  |   return 0; | ||||||
|  | } | ||||||
|  | weak_alias (__fcloseall, fcloseall) | ||||||
| @@ -324,11 +324,17 @@ extern char *tempnam __P ((__const char *__dir, __const char *__pfx)); | |||||||
| extern int __flshfp __P ((FILE *__stream, int __c)); | extern int __flshfp __P ((FILE *__stream, int __c)); | ||||||
|  |  | ||||||
|  |  | ||||||
| /* Close STREAM, or all streams if STREAM is NULL.  */ | /* Close STREAM.  */ | ||||||
| extern int fclose __P ((FILE *__stream)); | extern int fclose __P ((FILE *__stream)); | ||||||
| /* Flush STREAM, or all streams if STREAM is NULL.  */ | /* Flush STREAM, or all streams if STREAM is NULL.  */ | ||||||
| extern int fflush __P ((FILE *__stream)); | extern int fflush __P ((FILE *__stream)); | ||||||
|  |  | ||||||
|  | #ifdef __USE_GNU | ||||||
|  | /* Close all streams.  */ | ||||||
|  | extern int __fcloseall __P ((void)); | ||||||
|  | extern int fcloseall __P ((void)); | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| /* Open a file and create a new stream for it.  */ | /* Open a file and create a new stream for it.  */ | ||||||
| extern FILE *fopen __P ((__const char *__filename, __const char *__modes)); | extern FILE *fopen __P ((__const char *__filename, __const char *__modes)); | ||||||
|   | |||||||
| @@ -92,10 +92,10 @@ static bool_t marshal_new_auth(); | |||||||
| AUTH * | AUTH * | ||||||
| authunix_create(machname, uid, gid, len, aup_gids) | authunix_create(machname, uid, gid, len, aup_gids) | ||||||
| 	char *machname; | 	char *machname; | ||||||
| 	int uid; | 	uid_t uid; | ||||||
| 	int gid; | 	gid_t gid; | ||||||
| 	register int len; | 	register int len; | ||||||
| 	int *aup_gids; | 	gid_t *aup_gids; | ||||||
| { | { | ||||||
| 	struct authunix_parms aup; | 	struct authunix_parms aup; | ||||||
| 	char mymem[MAX_AUTH_BYTES]; | 	char mymem[MAX_AUTH_BYTES]; | ||||||
| @@ -172,8 +172,8 @@ authunix_create_default() | |||||||
| { | { | ||||||
| 	register int len; | 	register int len; | ||||||
| 	char machname[MAX_MACHINE_NAME + 1]; | 	char machname[MAX_MACHINE_NAME + 1]; | ||||||
| 	register int uid; | 	register uid_t uid; | ||||||
| 	register int gid; | 	register gid_t gid; | ||||||
| 	int max_nr_groups = sysconf (_SC_NGROUPS_MAX); | 	int max_nr_groups = sysconf (_SC_NGROUPS_MAX); | ||||||
| 	gid_t gids[max_nr_groups]; | 	gid_t gids[max_nr_groups]; | ||||||
|  |  | ||||||
| @@ -260,7 +260,7 @@ authunix_refresh(auth) | |||||||
|  |  | ||||||
| 	/* first deserialize the creds back into a struct authunix_parms */ | 	/* first deserialize the creds back into a struct authunix_parms */ | ||||||
| 	aup.aup_machname = NULL; | 	aup.aup_machname = NULL; | ||||||
| 	aup.aup_gids = (int *)NULL; | 	aup.aup_gids = (gid_t *)NULL; | ||||||
| 	xdrmem_create(&xdrs, au->au_origcred.oa_base, | 	xdrmem_create(&xdrs, au->au_origcred.oa_base, | ||||||
| 	    au->au_origcred.oa_length, XDR_DECODE); | 	    au->au_origcred.oa_length, XDR_DECODE); | ||||||
| 	stat = xdr_authunix_parms(&xdrs, &aup); | 	stat = xdr_authunix_parms(&xdrs, &aup); | ||||||
|   | |||||||
| @@ -155,8 +155,9 @@ extern struct opaque_auth _null_auth; | |||||||
|  *	int len; |  *	int len; | ||||||
|  *	int *aup_gids; |  *	int *aup_gids; | ||||||
|  */ |  */ | ||||||
| extern AUTH *authunix_create __P ((char *__machname, int __uid, int __gid, | extern AUTH *authunix_create __P ((char *__machname, __uid_t __uid, | ||||||
| 				   int __len, int *__aup_gids)); | 				   __gid_t __gid, int __len, | ||||||
|  | 				   __gid_t *__aup_gids)); | ||||||
| extern AUTH *authunix_create_default __P ((void)); | extern AUTH *authunix_create_default __P ((void)); | ||||||
| extern AUTH *authnone_create __P ((void)); | extern AUTH *authnone_create __P ((void)); | ||||||
| extern AUTH *authdes_create(); | extern AUTH *authdes_create(); | ||||||
|   | |||||||
| @@ -58,14 +58,15 @@ __BEGIN_DECLS | |||||||
| /* | /* | ||||||
|  * Unix style credentials. |  * Unix style credentials. | ||||||
|  */ |  */ | ||||||
| struct authunix_parms { | struct authunix_parms | ||||||
|  |   { | ||||||
|     u_long aup_time; |     u_long aup_time; | ||||||
|     char *aup_machname; |     char *aup_machname; | ||||||
| 	int	 aup_uid; |     __uid_t aup_uid; | ||||||
| 	int	 aup_gid; |     __gid_t aup_gid; | ||||||
|     u_int aup_len; |     u_int aup_len; | ||||||
| 	int	*aup_gids; |     __gid_t *aup_gids; | ||||||
| }; |   }; | ||||||
|  |  | ||||||
| extern bool_t xdr_authunix_parms __P ((XDR *__xdrs, | extern bool_t xdr_authunix_parms __P ((XDR *__xdrs, | ||||||
| 				       struct authunix_parms *__p)); | 				       struct authunix_parms *__p)); | ||||||
| @@ -75,9 +76,10 @@ extern bool_t xdr_authunix_parms __P ((XDR *__xdrs, | |||||||
|  * then the body of the response verifier encapsulates the following structure; |  * then the body of the response verifier encapsulates the following structure; | ||||||
|  * again it is serialized in the obvious fashion. |  * again it is serialized in the obvious fashion. | ||||||
|  */ |  */ | ||||||
| struct short_hand_verf { | struct short_hand_verf | ||||||
|  |   { | ||||||
|     struct opaque_auth new_cred; |     struct opaque_auth new_cred; | ||||||
| }; |   }; | ||||||
|  |  | ||||||
| __END_DECLS | __END_DECLS | ||||||
|  |  | ||||||
|   | |||||||
| @@ -90,7 +90,7 @@ abort (void) | |||||||
|   if (stage == 4) |   if (stage == 4) | ||||||
|     { |     { | ||||||
|       ++stage; |       ++stage; | ||||||
|       fclose (NULL); |       __fcloseall (); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|   /* Try again.  */ |   /* Try again.  */ | ||||||
|   | |||||||
| @@ -96,7 +96,7 @@ struct utmp | |||||||
|   long ut_session;		/* Session ID, used for windowing.  */ |   long ut_session;		/* Session ID, used for windowing.  */ | ||||||
|   struct timeval ut_tv;		/* Time entry was made.  */ |   struct timeval ut_tv;		/* Time entry was made.  */ | ||||||
|   int32_t ut_addr_v6[4];	/* Internet address of remote host.  */ |   int32_t ut_addr_v6[4];	/* Internet address of remote host.  */ | ||||||
|   char pad[18];			/* Reserved for future use.  */ |   char pad[20];			/* Reserved for future use.  */ | ||||||
| }; | }; | ||||||
|  |  | ||||||
| /* Backwards compatibility hacks.  */ | /* Backwards compatibility hacks.  */ | ||||||
|   | |||||||
							
								
								
									
										3
									
								
								sysdeps/ieee754/Makefile
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										3
									
								
								sysdeps/ieee754/Makefile
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,3 @@ | |||||||
|  | ifeq ($(subdir),math) | ||||||
|  | sysdep_headers += ieee754.h | ||||||
|  | endif | ||||||
| @@ -16,8 +16,15 @@ | |||||||
|    write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330, |    write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330, | ||||||
|    Boston, MA 02111-1307, USA.  */ |    Boston, MA 02111-1307, USA.  */ | ||||||
|  |  | ||||||
|  | #ifndef _IEEE754_H | ||||||
|  |  | ||||||
|  | #define _IEEE754_H 1 | ||||||
|  | #include <features.h> | ||||||
|  |  | ||||||
| #include <endian.h> | #include <endian.h> | ||||||
|  |  | ||||||
|  | __BEGIN_DECLS | ||||||
|  |  | ||||||
| union ieee754_float | union ieee754_float | ||||||
|   { |   { | ||||||
|     float f; |     float f; | ||||||
| @@ -153,3 +160,7 @@ union ieee854_long_double | |||||||
|   }; |   }; | ||||||
|  |  | ||||||
| #define IEEE854_LONG_DOUBLE_BIAS 0x3fff | #define IEEE854_LONG_DOUBLE_BIAS 0x3fff | ||||||
|  |  | ||||||
|  | __END_DECLS | ||||||
|  |  | ||||||
|  | #endif /* ieee754.h */ | ||||||
|   | |||||||
| @@ -5,7 +5,7 @@ | |||||||
|  |  | ||||||
| #include <machine/asm.h> | #include <machine/asm.h> | ||||||
|  |  | ||||||
| RCSID("$NetBSD: e_exp.S,v 1.4 1995/05/08 23:47:04 jtc Exp $") | RCSID("$NetBSD: e_exp.S,v 1.7 1996/07/03 17:31:28 jtc Exp $") | ||||||
|  |  | ||||||
| /* e^x = 2^(x * log2(e)) */ | /* e^x = 2^(x * log2(e)) */ | ||||||
| ENTRY(__ieee754_exp) | ENTRY(__ieee754_exp) | ||||||
| @@ -16,16 +16,16 @@ ENTRY(__ieee754_exp) | |||||||
|    -- drepper@cygnus.com.  */ |    -- drepper@cygnus.com.  */ | ||||||
| 	fxam				/* Is NaN or +-Inf?  */ | 	fxam				/* Is NaN or +-Inf?  */ | ||||||
| 	fstsw	%ax | 	fstsw	%ax | ||||||
| 	sahf | 	movb	$0x45, %dh | ||||||
| 	jnc	.LnoInfNaN		/* No, jump.   */ | 	andb	%ah, %dh | ||||||
| 	jp	.LisInf			/* Is +-Inf, jump.  */ | 	cmpb	$0x05, %dh | ||||||
| .LnoInfNaN: | 	je	1f			/* Is +-Inf, jump.  */ | ||||||
| 	fldl2e | 	fldl2e | ||||||
| 	fmulp				/* x * log2(e) */ | 	fmulp				/* x * log2(e) */ | ||||||
| 	fstl	%st(1) | 	fstl	%st(1) | ||||||
| 	frndint				/* int(x * log2(e)) */ | 	frndint				/* int(x * log2(e)) */ | ||||||
| 	fstl	%st(2) | 	fsub	%st,%st(1)		/* fract(x * log2(e)) */ | ||||||
| 	fsubrp				/* fract(x * log2(e)) */ | 	fxch | ||||||
| 	f2xm1				/* 2^(fract(x * log2(e))) - 1 */ | 	f2xm1				/* 2^(fract(x * log2(e))) - 1 */ | ||||||
| 	fld1 | 	fld1 | ||||||
| 	faddp				/* 2^(fract(x * log2(e))) */ | 	faddp				/* 2^(fract(x * log2(e))) */ | ||||||
| @@ -33,9 +33,8 @@ ENTRY(__ieee754_exp) | |||||||
| 	fstp	%st(1) | 	fstp	%st(1) | ||||||
| 	ret | 	ret | ||||||
|  |  | ||||||
| .LisInf: | 1:	testl	$0x200, %eax		/* Test sign.  */ | ||||||
| 	andb	$2, %ah			/* Test sign.  */ | 	jz	2f			/* If positive, jump.  */ | ||||||
| 	jz	.LpInf			/* If positive, jump.  */ |  | ||||||
| 	fldz				/* Set result to 0.  */ | 	fldz				/* Set result to 0.  */ | ||||||
| .LpInf:	ret | 2:	ret | ||||||
| END (__ieee754_exp) | END (__ieee754_exp) | ||||||
|   | |||||||
| @@ -17,16 +17,16 @@ ENTRY(__ieee754_expf) | |||||||
|    -- drepper@cygnus.com.  */ |    -- drepper@cygnus.com.  */ | ||||||
| 	fxam				/* Is NaN or +-Inf?  */ | 	fxam				/* Is NaN or +-Inf?  */ | ||||||
| 	fstsw	%ax | 	fstsw	%ax | ||||||
| 	sahf | 	movb	$0x45, %dh | ||||||
| 	jnc	.LnoInfNaN		/* No, jump.   */ | 	andb	%ah, %dh | ||||||
| 	jp	.LisInf			/* Is +-Inf, jump.  */ | 	cmpb	$0x05, %dh | ||||||
| .LnoInfNaN: | 	je	1f			/* Is +-Inf, jump.  */ | ||||||
| 	fldl2e | 	fldl2e | ||||||
| 	fmulp				/* x * log2(e) */ | 	fmulp				/* x * log2(e) */ | ||||||
| 	fstl	%st(1) | 	fstl	%st(1) | ||||||
| 	frndint				/* int(x * log2(e)) */ | 	frndint				/* int(x * log2(e)) */ | ||||||
| 	fstl	%st(2) | 	fsub	%st,%st(1)		/* fract(x * log2(e)) */ | ||||||
| 	fsubrp				/* fract(x * log2(e)) */ | 	fxch | ||||||
| 	f2xm1				/* 2^(fract(x * log2(e))) - 1 */ | 	f2xm1				/* 2^(fract(x * log2(e))) - 1 */ | ||||||
| 	fld1 | 	fld1 | ||||||
| 	faddp				/* 2^(fract(x * log2(e))) */ | 	faddp				/* 2^(fract(x * log2(e))) */ | ||||||
| @@ -34,9 +34,8 @@ ENTRY(__ieee754_expf) | |||||||
| 	fstp	%st(1) | 	fstp	%st(1) | ||||||
| 	ret | 	ret | ||||||
|  |  | ||||||
| .LisInf: | 1:	testl	$0x200, %eax		/* Test sign.  */ | ||||||
| 	andb	$2, %ah			/* Test sign.  */ | 	jz	2f			/* If positive, jump.  */ | ||||||
| 	jz	.LpInf			/* If positive, jump.  */ |  | ||||||
| 	fldz				/* Set result to 0.  */ | 	fldz				/* Set result to 0.  */ | ||||||
| .LpInf:	ret | 2:	ret | ||||||
| END (__ieee754_expf) | END (__ieee754_expf) | ||||||
|   | |||||||
| @@ -18,16 +18,16 @@ ENTRY(__ieee754_expl) | |||||||
|    -- drepper@cygnus.com.  */ |    -- drepper@cygnus.com.  */ | ||||||
| 	fxam				/* Is NaN or +-Inf?  */ | 	fxam				/* Is NaN or +-Inf?  */ | ||||||
| 	fstsw	%ax | 	fstsw	%ax | ||||||
| 	sahf | 	movb	$0x45, %dh | ||||||
| 	jnc	.LnoInfNaN		/* No, jump.   */ | 	andb	%ah, %dh | ||||||
| 	jp	.LisInf			/* Is +-Inf, jump.  */ | 	cmpb	$0x05, %dh | ||||||
| .LnoInfNaN: | 	je	1f			/* Is +-Inf, jump.  */ | ||||||
| 	fldl2e | 	fldl2e | ||||||
| 	fmulp				/* x * log2(e) */ | 	fmulp				/* x * log2(e) */ | ||||||
| 	fstl	%st(1) | 	fstl	%st(1) | ||||||
| 	frndint				/* int(x * log2(e)) */ | 	frndint				/* int(x * log2(e)) */ | ||||||
| 	fstl	%st(2) | 	fsub	%st,%st(1)		/* fract(x * log2(e)) */ | ||||||
| 	fsubrp				/* fract(x * log2(e)) */ | 	fxch | ||||||
| 	f2xm1				/* 2^(fract(x * log2(e))) - 1 */ | 	f2xm1				/* 2^(fract(x * log2(e))) - 1 */ | ||||||
| 	fld1 | 	fld1 | ||||||
| 	faddp				/* 2^(fract(x * log2(e))) */ | 	faddp				/* 2^(fract(x * log2(e))) */ | ||||||
| @@ -35,9 +35,8 @@ ENTRY(__ieee754_expl) | |||||||
| 	fstp	%st(1) | 	fstp	%st(1) | ||||||
| 	ret | 	ret | ||||||
|  |  | ||||||
| .LisInf: | 1:	testl	$0x200, %eax		/* Test sign.  */ | ||||||
| 	andb	$2, %ah			/* Test sign.  */ | 	jz	2f			/* If positive, jump.  */ | ||||||
| 	jz	.LpInf			/* If positive, jump.  */ |  | ||||||
| 	fldz				/* Set result to 0.  */ | 	fldz				/* Set result to 0.  */ | ||||||
| .LpInf:	ret | 2:	ret | ||||||
| END (__ieee754_expl) | END (__ieee754_expl) | ||||||
|   | |||||||
| @@ -53,7 +53,7 @@ ENTRY(__ieee754_log) | |||||||
| 	fyl2xp1			// log(x) | 	fyl2xp1			// log(x) | ||||||
| 	ret | 	ret | ||||||
|  |  | ||||||
| 2:	fincstp			// x : log(2) | 2:	fstp	%st(0)		// x : log(2) | ||||||
| 	fyl2x			// log(x) | 	fyl2x			// log(x) | ||||||
| 	ret | 	ret | ||||||
| END (__ieee754_log) | END (__ieee754_log) | ||||||
|   | |||||||
| @@ -53,7 +53,7 @@ ENTRY(__ieee754_log10) | |||||||
| 	fyl2xp1			// log10(x) | 	fyl2xp1			// log10(x) | ||||||
| 	ret | 	ret | ||||||
|  |  | ||||||
| 2:	fincstp			// x : log10(2) | 2:	fstp	%st(0)		// x : log10(2) | ||||||
| 	fyl2x			// log10(x) | 	fyl2x			// log10(x) | ||||||
| 	ret | 	ret | ||||||
| END (__ieee754_log10) | END (__ieee754_log10) | ||||||
|   | |||||||
| @@ -54,7 +54,7 @@ ENTRY(__ieee754_log10f) | |||||||
| 	fyl2xp1			// log10(x) | 	fyl2xp1			// log10(x) | ||||||
| 	ret | 	ret | ||||||
|  |  | ||||||
| 2:	fincstp			// x : log10(2) | 2:	fstp	%st(0)		// x : log10(2) | ||||||
| 	fyl2x			// log10(x) | 	fyl2x			// log10(x) | ||||||
| 	ret | 	ret | ||||||
| END (__ieee754_log10f) | END (__ieee754_log10f) | ||||||
|   | |||||||
| @@ -55,7 +55,7 @@ ENTRY(__ieee754_log10l) | |||||||
| 	fyl2xp1			// log10(x) | 	fyl2xp1			// log10(x) | ||||||
| 	ret | 	ret | ||||||
|  |  | ||||||
| 2:	fincstp			// x : log10(2) | 2:	fstp	%st(0)		// x : log10(2) | ||||||
| 	fyl2x			// log10(x) | 	fyl2x			// log10(x) | ||||||
| 	ret | 	ret | ||||||
| END(__ieee754_log10l) | END(__ieee754_log10l) | ||||||
|   | |||||||
| @@ -54,7 +54,7 @@ ENTRY(__ieee754_logf) | |||||||
| 	fyl2xp1			// log(x) | 	fyl2xp1			// log(x) | ||||||
| 	ret | 	ret | ||||||
|  |  | ||||||
| 2:	fincstp			// x : log(2) | 2:	fstp	%st(0)		// x : log(2) | ||||||
| 	fyl2x			// log(x) | 	fyl2x			// log(x) | ||||||
| 	ret | 	ret | ||||||
| END (__ieee754_logf) | END (__ieee754_logf) | ||||||
|   | |||||||
| @@ -54,7 +54,7 @@ ENTRY(__ieee754_logl) | |||||||
| 	fyl2xp1			// log(x) | 	fyl2xp1			// log(x) | ||||||
| 	ret | 	ret | ||||||
|  |  | ||||||
| 2:	fincstp			// x : log(2) | 2:	fstp	%st(0)		// x : log(2) | ||||||
| 	fyl2x			// log(x) | 	fyl2x			// log(x) | ||||||
| 	ret | 	ret | ||||||
| END (__ieee754_logl) | END (__ieee754_logl) | ||||||
|   | |||||||
							
								
								
									
										120
									
								
								sysdeps/libm-i387/e_pow.S
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										120
									
								
								sysdeps/libm-i387/e_pow.S
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,120 @@ | |||||||
|  | /* ix87 specific implementation of pow function. | ||||||
|  |    Copyright (C) 1996 Free Software Foundation, Inc. | ||||||
|  |    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 | ||||||
|  |    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.  */ | ||||||
|  |  | ||||||
|  | #include <machine/asm.h> | ||||||
|  |  | ||||||
|  | #ifdef __ELF__ | ||||||
|  | 	.section .rodata | ||||||
|  | #else | ||||||
|  | 	.text | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | 	.align ALIGNARG(4) | ||||||
|  | 	ASM_TYPE_DIRECTIVE(one,@object) | ||||||
|  | one:	.double 1.0 | ||||||
|  | 	ASM_SIZE_DIRECTIVE(one) | ||||||
|  | 	ASM_TYPE_DIRECTIVE(limit,@object) | ||||||
|  | limit:	.double 0.29 | ||||||
|  | 	ASM_SIZE_DIRECTIVE(limit) | ||||||
|  |  | ||||||
|  | #ifdef PIC | ||||||
|  | #define MO(op) op##@GOTOFF(%ecx) | ||||||
|  | #else | ||||||
|  | #define MO(op) op | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | 	.text | ||||||
|  | ENTRY(__ieee754_pow) | ||||||
|  | 	fldl	4(%esp)		// x | ||||||
|  | 	fldl	12(%esp)	// y : x | ||||||
|  |  | ||||||
|  | #ifdef	PIC | ||||||
|  | 	call	1f | ||||||
|  | 1:	popl	%ecx | ||||||
|  | 	addl	$_GLOBAL_OFFSET_TABLE_+[.-1b], %ecx | ||||||
|  | #endif | ||||||
|  | 	subl	$8,%esp | ||||||
|  |  | ||||||
|  | 	/* First see whether `y' is a natural number.  In this case we | ||||||
|  | 	   can use a more precise algorithm.  */ | ||||||
|  | 	fld	%st		// y : y : x | ||||||
|  | 	fistpll	(%esp)		// y : x | ||||||
|  | 	fildll	(%esp)		// int(y) : y : x | ||||||
|  | 	fucomp	%st(1)		// y : x | ||||||
|  | 	fnstsw | ||||||
|  | 	sahf | ||||||
|  | 	jne	2f | ||||||
|  |  | ||||||
|  | 	/* OK, we have an integer value for y.  */ | ||||||
|  | 	ftst			// y : x | ||||||
|  | 	fstp	%st(0)		// x | ||||||
|  | 	fnstsw | ||||||
|  | 	sahf | ||||||
|  | 	popl	%eax | ||||||
|  | 	popl	%edx | ||||||
|  | 	jnc	4f		// y >= 0, jump | ||||||
|  | 	fdivrl	MO(one)		// 1/x		(now referred to as x) | ||||||
|  | 	negl	%eax | ||||||
|  | 	adcl	$0, %edx | ||||||
|  | 	negl	%edx | ||||||
|  | 4:	fldl	MO(one)		// 1 : x | ||||||
|  | 	fxch | ||||||
|  |  | ||||||
|  | 6:	shrdl	$1, %edx, %eax | ||||||
|  | 	jnc	5f | ||||||
|  | 	fxch | ||||||
|  | 	fmul	%st(1)		// x : ST*x | ||||||
|  | 	fxch | ||||||
|  | 5:	fmul	%st(0), %st	// x*x : ST*x | ||||||
|  | 	movl	%eax, %ecx | ||||||
|  | 	orl	%edx, %ecx | ||||||
|  | 	jnz	6b | ||||||
|  | 	fstp	%st(0)		// ST*x | ||||||
|  | 	ret | ||||||
|  |  | ||||||
|  | 	.align ALIGNARG(4) | ||||||
|  | 2:	/* y is a real number.  */ | ||||||
|  | 	fxch			// x : y | ||||||
|  | 	fldl	MO(one)		// 1.0 : x : y | ||||||
|  | 	fld	%st(1)		// x : 1.0 : x : y | ||||||
|  | 	fsub	%st(1)		// x-1 : 1.0 : x : y | ||||||
|  | 	fabs			// |x-1| : 1.0 : x : y | ||||||
|  | 	fcompl	MO(limit)	// 1.0 : x : y | ||||||
|  | 	fnstsw | ||||||
|  | 	fxch			// x : 1.0 : y | ||||||
|  | 	sahf | ||||||
|  | 	ja	7f | ||||||
|  | 	fsub	%st(1)		// x-1 : 1.0 : y | ||||||
|  | 	fyl2xp1			// log2(x) : y | ||||||
|  | 	jmp	8f | ||||||
|  |  | ||||||
|  | 7:	fyl2x			// log2(x) : y | ||||||
|  | 8:	fmul	%st(1)		// y*log2(x) : y | ||||||
|  | 	fst	%st(1)		// y*log2(x) : y*log2(x) | ||||||
|  | 	frndint			// int(y*log2(x)) : y*log2(x) | ||||||
|  | 	fsubr	%st, %st(1)	// int(y*log2(x)) : fract(y*log2(x)) | ||||||
|  | 	fxch			// fract(y*log2(x)) : int(y*log2(x)) | ||||||
|  | 	f2xm1			// 2^fract(y*log2(x))-1 : int(y*log2(x)) | ||||||
|  | 	faddl	MO(one)		// 2^fract(y*log2(x)) : int(y*log2(x)) | ||||||
|  | 	fscale			// 2^fract(y*log2(x))*2^int(y*log2(x)) : int(y*log2(x)) | ||||||
|  | 	addl	$8, %esp | ||||||
|  | 	fstp	%st(1)		// 2^fract(y*log2(x))*2^int(y*log2(x)) | ||||||
|  | 	ret | ||||||
|  | END(__ieee754_pow) | ||||||
							
								
								
									
										120
									
								
								sysdeps/libm-i387/e_powf.S
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										120
									
								
								sysdeps/libm-i387/e_powf.S
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,120 @@ | |||||||
|  | /* ix87 specific implementation of pow function. | ||||||
|  |    Copyright (C) 1996 Free Software Foundation, Inc. | ||||||
|  |    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 | ||||||
|  |    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.  */ | ||||||
|  |  | ||||||
|  | #include <machine/asm.h> | ||||||
|  |  | ||||||
|  | #ifdef __ELF__ | ||||||
|  | 	.section .rodata | ||||||
|  | #else | ||||||
|  | 	.text | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | 	.align ALIGNARG(4) | ||||||
|  | 	ASM_TYPE_DIRECTIVE(one,@object) | ||||||
|  | one:	.double 1.0 | ||||||
|  | 	ASM_SIZE_DIRECTIVE(one) | ||||||
|  | 	ASM_TYPE_DIRECTIVE(limit,@object) | ||||||
|  | limit:	.double 0.29 | ||||||
|  | 	ASM_SIZE_DIRECTIVE(limit) | ||||||
|  |  | ||||||
|  | #ifdef PIC | ||||||
|  | #define MO(op) op##@GOTOFF(%ecx) | ||||||
|  | #else | ||||||
|  | #define MO(op) op | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | 	.text | ||||||
|  | ENTRY(__ieee754_powf) | ||||||
|  | 	flds	4(%esp)		// x | ||||||
|  | 	flds	8(%esp)		// y : x | ||||||
|  |  | ||||||
|  | #ifdef	PIC | ||||||
|  | 	call	1f | ||||||
|  | 1:	popl	%ecx | ||||||
|  | 	addl	$_GLOBAL_OFFSET_TABLE_+[.-1b], %ecx | ||||||
|  | #endif | ||||||
|  | 	subl	$8,%esp | ||||||
|  |  | ||||||
|  | 	/* First see whether `y' is a natural number.  In this case we | ||||||
|  | 	   can use a more precise algorithm.  */ | ||||||
|  | 	fld	%st		// y : y : x | ||||||
|  | 	fistpll	(%esp)		// y : x | ||||||
|  | 	fildll	(%esp)		// int(y) : y : x | ||||||
|  | 	fucomp	%st(1)		// y : x | ||||||
|  | 	fnstsw | ||||||
|  | 	sahf | ||||||
|  | 	jne	2f | ||||||
|  |  | ||||||
|  | 	/* OK, we have an integer value for y.  */ | ||||||
|  | 	ftst			// y : x | ||||||
|  | 	fstp	%st(0)		// x | ||||||
|  | 	fnstsw | ||||||
|  | 	sahf | ||||||
|  | 	popl	%eax | ||||||
|  | 	popl	%edx | ||||||
|  | 	jnc	4f		// y >= 0, jump | ||||||
|  | 	fdivrl	MO(one)		// 1/x		(now referred to as x) | ||||||
|  | 	negl	%eax | ||||||
|  | 	adcl	$0, %edx | ||||||
|  | 	negl	%edx | ||||||
|  | 4:	fldl	MO(one)		// 1 : x | ||||||
|  | 	fxch | ||||||
|  |  | ||||||
|  | 6:	shrdl	$1, %edx, %eax | ||||||
|  | 	jnc	5f | ||||||
|  | 	fxch | ||||||
|  | 	fmul	%st(1)		// x : ST*x | ||||||
|  | 	fxch | ||||||
|  | 5:	fmul	%st(0), %st	// x*x : ST*x | ||||||
|  | 	movl	%eax, %ecx | ||||||
|  | 	orl	%edx, %ecx | ||||||
|  | 	jnz	6b | ||||||
|  | 	fstp	%st(0)		// ST*x | ||||||
|  | 	ret | ||||||
|  |  | ||||||
|  | 	.align ALIGNARG(4) | ||||||
|  | 2:	/* y is a real number.  */ | ||||||
|  | 	fxch			// x : y | ||||||
|  | 	fldl	MO(one)		// 1.0 : x : y | ||||||
|  | 	fld	%st(1)		// x : 1.0 : x : y | ||||||
|  | 	fsub	%st(1)		// x-1 : 1.0 : x : y | ||||||
|  | 	fabs			// |x-1| : 1.0 : x : y | ||||||
|  | 	fcompl	MO(limit)	// 1.0 : x : y | ||||||
|  | 	fnstsw | ||||||
|  | 	fxch			// x : 1.0 : y | ||||||
|  | 	sahf | ||||||
|  | 	ja	7f | ||||||
|  | 	fsub	%st(1)		// x-1 : 1.0 : y | ||||||
|  | 	fyl2xp1			// log2(x) : y | ||||||
|  | 	jmp	8f | ||||||
|  |  | ||||||
|  | 7:	fyl2x			// log2(x) : y | ||||||
|  | 8:	fmul	%st(1)		// y*log2(x) : y | ||||||
|  | 	fst	%st(1)		// y*log2(x) : y*log2(x) | ||||||
|  | 	frndint			// int(y*log2(x)) : y*log2(x) | ||||||
|  | 	fsubr	%st, %st(1)	// int(y*log2(x)) : fract(y*log2(x)) | ||||||
|  | 	fxch			// fract(y*log2(x)) : int(y*log2(x)) | ||||||
|  | 	f2xm1			// 2^fract(y*log2(x))-1 : int(y*log2(x)) | ||||||
|  | 	faddl	MO(one)		// 2^fract(y*log2(x)) : int(y*log2(x)) | ||||||
|  | 	fscale			// 2^fract(y*log2(x))*2^int(y*log2(x)) : int(y*log2(x)) | ||||||
|  | 	addl	$8, %esp | ||||||
|  | 	fstp	%st(1)		// 2^fract(y*log2(x))*2^int(y*log2(x)) | ||||||
|  | 	ret | ||||||
|  | END(__ieee754_powf) | ||||||
							
								
								
									
										120
									
								
								sysdeps/libm-i387/e_powl.S
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										120
									
								
								sysdeps/libm-i387/e_powl.S
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,120 @@ | |||||||
|  | /* ix87 specific implementation of pow function. | ||||||
|  |    Copyright (C) 1996 Free Software Foundation, Inc. | ||||||
|  |    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 | ||||||
|  |    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.  */ | ||||||
|  |  | ||||||
|  | #include <machine/asm.h> | ||||||
|  |  | ||||||
|  | #ifdef __ELF__ | ||||||
|  | 	.section .rodata | ||||||
|  | #else | ||||||
|  | 	.text | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | 	.align ALIGNARG(4) | ||||||
|  | 	ASM_TYPE_DIRECTIVE(one,@object) | ||||||
|  | one:	.double 1.0 | ||||||
|  | 	ASM_SIZE_DIRECTIVE(one) | ||||||
|  | 	ASM_TYPE_DIRECTIVE(limit,@object) | ||||||
|  | limit:	.double 0.29 | ||||||
|  | 	ASM_SIZE_DIRECTIVE(limit) | ||||||
|  |  | ||||||
|  | #ifdef PIC | ||||||
|  | #define MO(op) op##@GOTOFF(%ecx) | ||||||
|  | #else | ||||||
|  | #define MO(op) op | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | 	.text | ||||||
|  | ENTRY(__ieee754_powl) | ||||||
|  | 	fldt	4(%esp)		// x | ||||||
|  | 	fldt	16(%esp)	// y : x | ||||||
|  |  | ||||||
|  | #ifdef	PIC | ||||||
|  | 	call	1f | ||||||
|  | 1:	popl	%ecx | ||||||
|  | 	addl	$_GLOBAL_OFFSET_TABLE_+[.-1b], %ecx | ||||||
|  | #endif | ||||||
|  | 	subl	$8,%esp | ||||||
|  |  | ||||||
|  | 	/* First see whether `y' is a natural number.  In this case we | ||||||
|  | 	   can use a more precise algorithm.  */ | ||||||
|  | 	fld	%st		// y : y : x | ||||||
|  | 	fistpll	(%esp)		// y : x | ||||||
|  | 	fildll	(%esp)		// int(y) : y : x | ||||||
|  | 	fucomp	%st(1)		// y : x | ||||||
|  | 	fnstsw | ||||||
|  | 	sahf | ||||||
|  | 	jne	2f | ||||||
|  |  | ||||||
|  | 	/* OK, we have an integer value for y.  */ | ||||||
|  | 	ftst			// y : x | ||||||
|  | 	fstp	%st(0)		// x | ||||||
|  | 	fnstsw | ||||||
|  | 	sahf | ||||||
|  | 	popl	%eax | ||||||
|  | 	popl	%edx | ||||||
|  | 	jnc	4f		// y >= 0, jump | ||||||
|  | 	fdivrl	MO(one)		// 1/x		(now referred to as x) | ||||||
|  | 	negl	%eax | ||||||
|  | 	adcl	$0, %edx | ||||||
|  | 	negl	%edx | ||||||
|  | 4:	fldl	MO(one)		// 1 : x | ||||||
|  | 	fxch | ||||||
|  |  | ||||||
|  | 6:	shrdl	$1, %edx, %eax | ||||||
|  | 	jnc	5f | ||||||
|  | 	fxch | ||||||
|  | 	fmul	%st(1)		// x : ST*x | ||||||
|  | 	fxch | ||||||
|  | 5:	fmul	%st(0), %st	// x*x : ST*x | ||||||
|  | 	movl	%eax, %ecx | ||||||
|  | 	orl	%edx, %ecx | ||||||
|  | 	jnz	6b | ||||||
|  | 	fstp	%st(0)		// ST*x | ||||||
|  | 	ret | ||||||
|  |  | ||||||
|  | 	.align ALIGNARG(4) | ||||||
|  | 2:	/* y is a real number.  */ | ||||||
|  | 	fxch			// x : y | ||||||
|  | 	fldl	MO(one)		// 1.0 : x : y | ||||||
|  | 	fld	%st(1)		// x : 1.0 : x : y | ||||||
|  | 	fsub	%st(1)		// x-1 : 1.0 : x : y | ||||||
|  | 	fabs			// |x-1| : 1.0 : x : y | ||||||
|  | 	fcompl	MO(limit)	// 1.0 : x : y | ||||||
|  | 	fnstsw | ||||||
|  | 	fxch			// x : 1.0 : y | ||||||
|  | 	sahf | ||||||
|  | 	ja	7f | ||||||
|  | 	fsub	%st(1)		// x-1 : 1.0 : y | ||||||
|  | 	fyl2xp1			// log2(x) : y | ||||||
|  | 	jmp	8f | ||||||
|  |  | ||||||
|  | 7:	fyl2x			// log2(x) : y | ||||||
|  | 8:	fmul	%st(1)		// y*log2(x) : y | ||||||
|  | 	fst	%st(1)		// y*log2(x) : y*log2(x) | ||||||
|  | 	frndint			// int(y*log2(x)) : y*log2(x) | ||||||
|  | 	fsubr	%st, %st(1)	// int(y*log2(x)) : fract(y*log2(x)) | ||||||
|  | 	fxch			// fract(y*log2(x)) : int(y*log2(x)) | ||||||
|  | 	f2xm1			// 2^fract(y*log2(x))-1 : int(y*log2(x)) | ||||||
|  | 	faddl	MO(one)		// 2^fract(y*log2(x)) : int(y*log2(x)) | ||||||
|  | 	fscale			// 2^fract(y*log2(x))*2^int(y*log2(x)) : int(y*log2(x)) | ||||||
|  | 	addl	$8, %esp | ||||||
|  | 	fstp	%st(1)		// 2^fract(y*log2(x))*2^int(y*log2(x)) | ||||||
|  | 	ret | ||||||
|  | END(__ieee754_powl) | ||||||
| @@ -101,7 +101,7 @@ ENTRY(__asinh) | |||||||
| 	fchs				// x | 	fchs				// x | ||||||
| 4:	fld	%st			// x : x | 4:	fld	%st			// x : x | ||||||
| 	faddl	MO(huge)		// huge+x : x | 	faddl	MO(huge)		// huge+x : x | ||||||
| 	fincstp				// x | 	fstp	%st(0)			// x | ||||||
| 	ret | 	ret | ||||||
|  |  | ||||||
| 	// |x| > 2^28 => y = sign(x) * (log(|x|) + log(2)) | 	// |x| > 2^28 => y = sign(x) * (log(|x|) + log(2)) | ||||||
|   | |||||||
| @@ -101,7 +101,7 @@ ENTRY(__asinhf) | |||||||
| 	fchs				// x | 	fchs				// x | ||||||
| 4:	fld	%st			// x : x | 4:	fld	%st			// x : x | ||||||
| 	faddl	MO(huge)		// huge+x : x | 	faddl	MO(huge)		// huge+x : x | ||||||
| 	fincstp				// x | 	fstp	%st(0)			// x | ||||||
| 	ret | 	ret | ||||||
|  |  | ||||||
| 	// |x| > 2^14 => y = sign(x) * (log(|x|) + log(2)) | 	// |x| > 2^14 => y = sign(x) * (log(|x|) + log(2)) | ||||||
|   | |||||||
| @@ -109,7 +109,7 @@ ENTRY(__asinhl) | |||||||
| 4:	fld	%st			// x : x | 4:	fld	%st			// x : x | ||||||
| 	fldt	MO(huge)		// huge : x : x | 	fldt	MO(huge)		// huge : x : x | ||||||
| 	faddp				// huge+x : x | 	faddp				// huge+x : x | ||||||
| 	fincstp				// x | 	fstp	%st(0)			// x | ||||||
| 	ret | 	ret | ||||||
|  |  | ||||||
| 	// |x| > 2^34 => y = sign(x) * (log(|x|) + log(2)) | 	// |x| > 2^34 => y = sign(x) * (log(|x|) + log(2)) | ||||||
|   | |||||||
| @@ -8,27 +8,25 @@ | |||||||
| RCSID("$NetBSD: s_ceil.S,v 1.4 1995/05/08 23:52:13 jtc Exp $") | RCSID("$NetBSD: s_ceil.S,v 1.4 1995/05/08 23:52:13 jtc Exp $") | ||||||
|  |  | ||||||
| ENTRY(__ceil) | ENTRY(__ceil) | ||||||
| 	pushl	%ebp | 	fldl	4(%esp) | ||||||
| 	movl	%esp,%ebp |  | ||||||
| 	subl	$8,%esp | 	subl	$8,%esp | ||||||
|  |  | ||||||
| 	fstcw	-4(%ebp)		/* store fpu control word */ | 	fstcw	4(%esp)			/* store fpu control word */ | ||||||
|  |  | ||||||
| 	/* We use here %edx although only the low 1 bits are defined. | 	/* We use here %edx although only the low 1 bits are defined. | ||||||
| 	   But none of the operations should care and they are faster | 	   But none of the operations should care and they are faster | ||||||
| 	   than the 16 bit operations.  */ | 	   than the 16 bit operations.  */ | ||||||
| 	movl	-4(%ebp),%edx | 	movl	$0x0800,%edx		/* round towards +oo */ | ||||||
| 	orl	$0x0800,%edx		/* round towards +oo */ | 	orl	4(%esp),%edx | ||||||
| 	andl	$0xfbff,%edx | 	andl	$0xfbff,%edx | ||||||
| 	movl	%edx,-8(%ebp) | 	movl	%edx,(%esp) | ||||||
| 	fldcw	-8(%ebp)		/* load modified control word */ | 	fldcw	(%esp)			/* load modified control word */ | ||||||
|  |  | ||||||
| 	fldl	8(%ebp);		/* round */ | 	frndint				/* round */ | ||||||
| 	frndint |  | ||||||
|  |  | ||||||
| 	fldcw	-4(%ebp)		/* restore original control word */ | 	fldcw	4(%esp)			/* restore original control word */ | ||||||
|  |  | ||||||
| 	leave | 	addl	$8,%esp | ||||||
| 	ret | 	ret | ||||||
| END (__ceil) | END (__ceil) | ||||||
| weak_alias (__ceil, ceil) | weak_alias (__ceil, ceil) | ||||||
|   | |||||||
| @@ -8,27 +8,25 @@ | |||||||
| RCSID("$NetBSD: s_ceilf.S,v 1.3 1995/05/08 23:52:44 jtc Exp $") | RCSID("$NetBSD: s_ceilf.S,v 1.3 1995/05/08 23:52:44 jtc Exp $") | ||||||
|  |  | ||||||
| ENTRY(__ceilf) | ENTRY(__ceilf) | ||||||
| 	pushl	%ebp | 	flds	4(%esp) | ||||||
| 	movl	%esp,%ebp |  | ||||||
| 	subl	$8,%esp | 	subl	$8,%esp | ||||||
|  |  | ||||||
| 	fstcw	-4(%ebp)		/* store fpu control word */ | 	fstcw	4(%esp)			/* store fpu control word */ | ||||||
|  |  | ||||||
| 	/* We use here %edx although only the low 1 bits are defined. | 	/* We use here %edx although only the low 1 bits are defined. | ||||||
| 	   But none of the operations should care and they are faster | 	   But none of the operations should care and they are faster | ||||||
| 	   than the 16 bit operations.  */ | 	   than the 16 bit operations.  */ | ||||||
| 	movl	-4(%ebp),%edx | 	movl	$0x0800,%edx		/* round towards +oo */ | ||||||
| 	orl	$0x0800,%edx		/* round towards +oo */ | 	orl	4(%esp),%edx | ||||||
| 	andl	$0xfbff,%edx | 	andl	$0xfbff,%edx | ||||||
| 	movl	%edx,-8(%ebp) | 	movl	%edx,(%esp) | ||||||
| 	fldcw	-8(%ebp)		/* load modified control word */ | 	fldcw	(%esp)			/* load modified control word */ | ||||||
|  |  | ||||||
| 	flds	8(%ebp);		/* round */ | 	frndint				/* round */ | ||||||
| 	frndint |  | ||||||
|  |  | ||||||
| 	fldcw	-4(%ebp)		/* restore original control word */ | 	fldcw	4(%esp)			/* restore original control word */ | ||||||
|  |  | ||||||
| 	leave | 	addl	$8,%esp | ||||||
| 	ret | 	ret | ||||||
| END (__ceilf) | END (__ceilf) | ||||||
| weak_alias (__ceilf, ceilf) | weak_alias (__ceilf, ceilf) | ||||||
|   | |||||||
| @@ -9,27 +9,25 @@ | |||||||
| RCSID("$NetBSD: $") | RCSID("$NetBSD: $") | ||||||
|  |  | ||||||
| ENTRY(__ceill) | ENTRY(__ceill) | ||||||
| 	pushl	%ebp | 	fldt	4(%esp) | ||||||
| 	movl	%esp,%ebp |  | ||||||
| 	subl	$8,%esp | 	subl	$8,%esp | ||||||
|  |  | ||||||
| 	fstcw	-4(%ebp)		/* store fpu control word */ | 	fstcw	4(%esp)			/* store fpu control word */ | ||||||
|  |  | ||||||
| 	/* We use here %edx although only the low 1 bits are defined. | 	/* We use here %edx although only the low 1 bits are defined. | ||||||
| 	   But none of the operations should care and they are faster | 	   But none of the operations should care and they are faster | ||||||
| 	   than the 16 bit operations.  */ | 	   than the 16 bit operations.  */ | ||||||
| 	movl	-4(%ebp),%edx | 	movl	$0x0800,%edx		/* round towards +oo */ | ||||||
| 	orl	$0x0800,%edx		/* round towards +oo */ | 	orl	4(%esp),%edx | ||||||
| 	andl	$0xfbff,%edx | 	andl	$0xfbff,%edx | ||||||
| 	movl	%edx,-8(%ebp) | 	movl	%edx,(%esp) | ||||||
| 	fldcw	-8(%ebp)		/* load modified control word */ | 	fldcw	(%esp)			/* load modified control word */ | ||||||
|  |  | ||||||
| 	fldt	8(%ebp);		/* round */ | 	frndint				/* round */ | ||||||
| 	frndint |  | ||||||
|  |  | ||||||
| 	fldcw	-4(%ebp)		/* restore original control word */ | 	fldcw	4(%esp)			/* restore original control word */ | ||||||
|  |  | ||||||
| 	leave | 	addl	$8,%esp | ||||||
| 	ret | 	ret | ||||||
| END (__ceill) | END (__ceill) | ||||||
| weak_alias (__ceill, ceill) | weak_alias (__ceill, ceill) | ||||||
|   | |||||||
							
								
								
									
										83
									
								
								sysdeps/libm-i387/s_expm1.S
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										83
									
								
								sysdeps/libm-i387/s_expm1.S
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,83 @@ | |||||||
|  | /* ix87 specific implementation of exp(x)-1. | ||||||
|  |    Copyright (C) 1996 Free Software Foundation, Inc. | ||||||
|  |    This file is part of the GNU C Library. | ||||||
|  |    Contributed by Ulrich Drepper <drepper@cygnus.com>, 1996. | ||||||
|  |    Based on code by John C. Bowman <bowman@ipp-garching.mpg.de>. | ||||||
|  |  | ||||||
|  |    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.  */ | ||||||
|  |  | ||||||
|  | 	/* Using: e^x - 1 = 2^(x * log2(e)) - 1 */ | ||||||
|  |  | ||||||
|  | #include <machine/asm.h> | ||||||
|  |  | ||||||
|  | #ifdef __ELF__ | ||||||
|  | 	.section .rodata | ||||||
|  | #else | ||||||
|  | 	.text | ||||||
|  | #endif | ||||||
|  | 	.align ALIGNARG(4) | ||||||
|  | 	ASM_TYPE_DIRECTIVE(zero,@object) | ||||||
|  | zero:	.double 0.0 | ||||||
|  | 	ASM_SIZE_DIRECTIVE(zero) | ||||||
|  | 	ASM_TYPE_DIRECTIVE(one,@object) | ||||||
|  | one:	.double 1.0 | ||||||
|  | 	ASM_SIZE_DIRECTIVE(one) | ||||||
|  | 	ASM_TYPE_DIRECTIVE(l2e,@object) | ||||||
|  | l2e:	.tfloat 1.442695040888963407359924681002 | ||||||
|  | 	ASM_SIZE_DIRECTIVE(l2e) | ||||||
|  |  | ||||||
|  | #ifdef PIC | ||||||
|  | #define MO(op) op##@GOTOFF(%edx) | ||||||
|  | #else | ||||||
|  | #define MO(op) op | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | 	.text | ||||||
|  | ENTRY(__expm1) | ||||||
|  | 	fldl	4(%esp)		// x | ||||||
|  | 	fxam			// Is NaN or +-Inf? | ||||||
|  | 	fstsw	%ax | ||||||
|  | #ifdef	PIC | ||||||
|  | 	call	1f | ||||||
|  | 1:	popl	%edx | ||||||
|  | 	addl	$_GLOBAL_OFFSET_TABLE_+[.-1b], %edx | ||||||
|  | #endif | ||||||
|  | 	movb	$0x45, %ch | ||||||
|  | 	andb	%ah, %ch | ||||||
|  | 	cmpb	$0x05, %ch | ||||||
|  | 	je	2f		// Is +-Inf, jump. | ||||||
|  |  | ||||||
|  | 	fldt	MO(l2e)		// log2(e) : x | ||||||
|  | 	fmulp			// log2(e)*x | ||||||
|  | 	fld	%st		// log2(e)*x : log2(e)*x | ||||||
|  | 	frndint			// int(log2(e)*x) : log2(e)*x | ||||||
|  | 	fsub	%st, %st(1)	// int(log2(e)*x) : fract(log2(e)*x) | ||||||
|  | 	fxch			// fract(log2(e)*x) : int(log2(e)*x) | ||||||
|  | 	f2xm1			// 2^fract(log2(e)*x)-1 : int(log2(e)*x) | ||||||
|  | 	fscale			// 2^(log2(e)*x)-2^int(log2(e)*x) : int(log2(e)*x) | ||||||
|  | 	fxch			// int(log2(e)*x) : 2^(log2(e)*x)-2^int(log2(e)*x) | ||||||
|  | 	fldl	MO(one)		// 1 : int(log2(e)*x) : 2^(log2(e)*x)-2^int(log2(e)*x) | ||||||
|  | 	fscale			// 2^int(log2(e)*x) : 2^(log2(e)*x)-2^int(log2(e)*x) | ||||||
|  | 	faddp			// 2^(log2(e)*x) | ||||||
|  | 	fsubl	MO(one) | ||||||
|  | 	ret | ||||||
|  |  | ||||||
|  | 2:	testl	$0x200, %eax	// Test sign. | ||||||
|  | 	jz	3f		// If positive, jump. | ||||||
|  | 	fldl	MO(zero)	// Set result to 0. | ||||||
|  | 3:	ret | ||||||
|  | END(__expm1) | ||||||
|  | weak_alias (__expm1, expm1) | ||||||
							
								
								
									
										83
									
								
								sysdeps/libm-i387/s_expm1f.S
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										83
									
								
								sysdeps/libm-i387/s_expm1f.S
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,83 @@ | |||||||
|  | /* ix87 specific implementation of exp(x)-1. | ||||||
|  |    Copyright (C) 1996 Free Software Foundation, Inc. | ||||||
|  |    This file is part of the GNU C Library. | ||||||
|  |    Contributed by Ulrich Drepper <drepper@cygnus.com>, 1996. | ||||||
|  |    Based on code by John C. Bowman <bowman@ipp-garching.mpg.de>. | ||||||
|  |  | ||||||
|  |    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.  */ | ||||||
|  |  | ||||||
|  | 	/* Using: e^x - 1 = 2^(x * log2(e)) - 1 */ | ||||||
|  |  | ||||||
|  | #include <machine/asm.h> | ||||||
|  |  | ||||||
|  | #ifdef __ELF__ | ||||||
|  | 	.section .rodata | ||||||
|  | #else | ||||||
|  | 	.text | ||||||
|  | #endif | ||||||
|  | 	.align ALIGNARG(4) | ||||||
|  | 	ASM_TYPE_DIRECTIVE(zero,@object) | ||||||
|  | zero:	.double 0.0 | ||||||
|  | 	ASM_SIZE_DIRECTIVE(zero) | ||||||
|  | 	ASM_TYPE_DIRECTIVE(one,@object) | ||||||
|  | one:	.double 1.0 | ||||||
|  | 	ASM_SIZE_DIRECTIVE(one) | ||||||
|  | 	ASM_TYPE_DIRECTIVE(l2e,@object) | ||||||
|  | l2e:	.tfloat 1.442695040888963407359924681002 | ||||||
|  | 	ASM_SIZE_DIRECTIVE(l2e) | ||||||
|  |  | ||||||
|  | #ifdef PIC | ||||||
|  | #define MO(op) op##@GOTOFF(%edx) | ||||||
|  | #else | ||||||
|  | #define MO(op) op | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | 	.text | ||||||
|  | ENTRY(__expm1f) | ||||||
|  | 	flds	4(%esp)		// x | ||||||
|  | 	fxam			// Is NaN or +-Inf? | ||||||
|  | 	fstsw	%ax | ||||||
|  | #ifdef	PIC | ||||||
|  | 	call	1f | ||||||
|  | 1:	popl	%edx | ||||||
|  | 	addl	$_GLOBAL_OFFSET_TABLE_+[.-1b], %edx | ||||||
|  | #endif | ||||||
|  | 	movb	$0x45, %ch | ||||||
|  | 	andb	%ah, %ch | ||||||
|  | 	cmpb	$0x05, %ch | ||||||
|  | 	je	2f		// Is +-Inf, jump. | ||||||
|  |  | ||||||
|  | 	fldt	MO(l2e)		// log2(e) : x | ||||||
|  | 	fmulp			// log2(e)*x | ||||||
|  | 	fld	%st		// log2(e)*x : log2(e)*x | ||||||
|  | 	frndint			// int(log2(e)*x) : log2(e)*x | ||||||
|  | 	fsub	%st, %st(1)	// int(log2(e)*x) : fract(log2(e)*x) | ||||||
|  | 	fxch			// fract(log2(e)*x) : int(log2(e)*x) | ||||||
|  | 	f2xm1			// 2^fract(log2(e)*x)-1 : int(log2(e)*x) | ||||||
|  | 	fscale			// 2^(log2(e)*x)-2^int(log2(e)*x) : int(log2(e)*x) | ||||||
|  | 	fxch			// int(log2(e)*x) : 2^(log2(e)*x)-2^int(log2(e)*x) | ||||||
|  | 	fldl	MO(one)		// 1 : int(log2(e)*x) : 2^(log2(e)*x)-2^int(log2(e)*x) | ||||||
|  | 	fscale			// 2^int(log2(e)*x) : 2^(log2(e)*x)-2^int(log2(e)*x) | ||||||
|  | 	faddp			// 2^(log2(e)*x) | ||||||
|  | 	fsubl	MO(one) | ||||||
|  | 	ret | ||||||
|  |  | ||||||
|  | 2:	testl	$0x200, %eax	// Test sign. | ||||||
|  | 	jz	3f		// If positive, jump. | ||||||
|  | 	fldl	MO(zero)	// Set result to 0. | ||||||
|  | 3:	ret | ||||||
|  | END(__expm1f) | ||||||
|  | weak_alias (__expm1f, expm1f) | ||||||
							
								
								
									
										83
									
								
								sysdeps/libm-i387/s_expm1l.S
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										83
									
								
								sysdeps/libm-i387/s_expm1l.S
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,83 @@ | |||||||
|  | /* ix87 specific implementation of exp(x)-1. | ||||||
|  |    Copyright (C) 1996 Free Software Foundation, Inc. | ||||||
|  |    This file is part of the GNU C Library. | ||||||
|  |    Contributed by Ulrich Drepper <drepper@cygnus.com>, 1996. | ||||||
|  |    Based on code by John C. Bowman <bowman@ipp-garching.mpg.de>. | ||||||
|  |  | ||||||
|  |    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.  */ | ||||||
|  |  | ||||||
|  | 	/* Using: e^x - 1 = 2^(x * log2(e)) - 1 */ | ||||||
|  |  | ||||||
|  | #include <machine/asm.h> | ||||||
|  |  | ||||||
|  | #ifdef __ELF__ | ||||||
|  | 	.section .rodata | ||||||
|  | #else | ||||||
|  | 	.text | ||||||
|  | #endif | ||||||
|  | 	.align ALIGNARG(4) | ||||||
|  | 	ASM_TYPE_DIRECTIVE(zero,@object) | ||||||
|  | zero:	.double 0.0 | ||||||
|  | 	ASM_SIZE_DIRECTIVE(zero) | ||||||
|  | 	ASM_TYPE_DIRECTIVE(one,@object) | ||||||
|  | one:	.double 1.0 | ||||||
|  | 	ASM_SIZE_DIRECTIVE(one) | ||||||
|  | 	ASM_TYPE_DIRECTIVE(l2e,@object) | ||||||
|  | l2e:	.tfloat 1.442695040888963407359924681002 | ||||||
|  | 	ASM_SIZE_DIRECTIVE(l2e) | ||||||
|  |  | ||||||
|  | #ifdef PIC | ||||||
|  | #define MO(op) op##@GOTOFF(%edx) | ||||||
|  | #else | ||||||
|  | #define MO(op) op | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | 	.text | ||||||
|  | ENTRY(__expm1l) | ||||||
|  | 	fldt	4(%esp)		// x | ||||||
|  | 	fxam			// Is NaN or +-Inf? | ||||||
|  | 	fstsw	%ax | ||||||
|  | #ifdef	PIC | ||||||
|  | 	call	1f | ||||||
|  | 1:	popl	%edx | ||||||
|  | 	addl	$_GLOBAL_OFFSET_TABLE_+[.-1b], %edx | ||||||
|  | #endif | ||||||
|  | 	movb	$0x45, %ch | ||||||
|  | 	andb	%ah, %ch | ||||||
|  | 	cmpb	$0x05, %ch | ||||||
|  | 	je	2f		// Is +-Inf, jump. | ||||||
|  |  | ||||||
|  | 	fldt	MO(l2e)		// log2(e) : x | ||||||
|  | 	fmulp			// log2(e)*x | ||||||
|  | 	fld	%st		// log2(e)*x : log2(e)*x | ||||||
|  | 	frndint			// int(log2(e)*x) : log2(e)*x | ||||||
|  | 	fsub	%st, %st(1)	// int(log2(e)*x) : fract(log2(e)*x) | ||||||
|  | 	fxch			// fract(log2(e)*x) : int(log2(e)*x) | ||||||
|  | 	f2xm1			// 2^fract(log2(e)*x)-1 : int(log2(e)*x) | ||||||
|  | 	fscale			// 2^(log2(e)*x)-2^int(log2(e)*x) : int(log2(e)*x) | ||||||
|  | 	fxch			// int(log2(e)*x) : 2^(log2(e)*x)-2^int(log2(e)*x) | ||||||
|  | 	fldl	MO(one)		// 1 : int(log2(e)*x) : 2^(log2(e)*x)-2^int(log2(e)*x) | ||||||
|  | 	fscale			// 2^int(log2(e)*x) : 2^(log2(e)*x)-2^int(log2(e)*x) | ||||||
|  | 	faddp			// 2^(log2(e)*x) | ||||||
|  | 	fsubl	MO(one) | ||||||
|  | 	ret | ||||||
|  |  | ||||||
|  | 2:	testl	$0x200, %eax	// Test sign. | ||||||
|  | 	jz	3f		// If positive, jump. | ||||||
|  | 	fldl	MO(zero)	// Set result to 0. | ||||||
|  | 3:	ret | ||||||
|  | END(__expm1l) | ||||||
|  | weak_alias (__expm1l, expm1l) | ||||||
| @@ -8,23 +8,25 @@ | |||||||
| RCSID("$NetBSD: s_floor.S,v 1.4 1995/05/09 00:01:59 jtc Exp $") | RCSID("$NetBSD: s_floor.S,v 1.4 1995/05/09 00:01:59 jtc Exp $") | ||||||
|  |  | ||||||
| ENTRY(__floor) | ENTRY(__floor) | ||||||
| 	pushl	%ebp | 	fldl	4(%esp) | ||||||
| 	movl	%esp,%ebp |  | ||||||
| 	subl	$8,%esp | 	subl	$8,%esp | ||||||
|  |  | ||||||
| 	fstcw	-4(%ebp)		/* store fpu control word */ | 	fstcw	4(%esp)			/* store fpu control word */ | ||||||
| 	movw	-4(%ebp),%dx |  | ||||||
| 	orw	$0x0400,%dx		/* round towards -oo */ |  | ||||||
| 	andw	$0xf7ff,%dx |  | ||||||
| 	movw	%dx,-8(%ebp) |  | ||||||
| 	fldcw	-8(%ebp)		/* load modified control word */ |  | ||||||
|  |  | ||||||
| 	fldl	8(%ebp);		/* round */ | 	/* We use here %edx although only the low 1 bits are defined. | ||||||
| 	frndint | 	   But none of the operations should care and they are faster | ||||||
|  | 	   than the 16 bit operations.  */ | ||||||
|  | 	movl	$0x400,%edx		/* round towards -oo */ | ||||||
|  | 	orl	4(%esp),%edx | ||||||
|  | 	andl	$0xf7ff,%edx | ||||||
|  | 	movl	%edx,(%esp) | ||||||
|  | 	fldcw	(%esp)			/* load modified control word */ | ||||||
|  |  | ||||||
| 	fldcw	-4(%ebp)		/* restore original control word */ | 	frndint				/* round */ | ||||||
|  |  | ||||||
| 	leave | 	fldcw	4(%esp)			/* restore original control word */ | ||||||
|  |  | ||||||
|  | 	addl	$8,%esp | ||||||
| 	ret | 	ret | ||||||
| END (__floor) | END (__floor) | ||||||
| weak_alias (__floor, floor) | weak_alias (__floor, floor) | ||||||
|   | |||||||
| @@ -8,23 +8,25 @@ | |||||||
| RCSID("$NetBSD: s_floorf.S,v 1.3 1995/05/09 00:04:32 jtc Exp $") | RCSID("$NetBSD: s_floorf.S,v 1.3 1995/05/09 00:04:32 jtc Exp $") | ||||||
|  |  | ||||||
| ENTRY(__floorf) | ENTRY(__floorf) | ||||||
| 	pushl	%ebp | 	flds	4(%esp) | ||||||
| 	movl	%esp,%ebp |  | ||||||
| 	subl	$8,%esp | 	subl	$8,%esp | ||||||
|  |  | ||||||
| 	fstcw	-4(%ebp)		/* store fpu control word */ | 	fstcw	4(%esp)			/* store fpu control word */ | ||||||
| 	movw	-4(%ebp),%dx |  | ||||||
| 	orw	$0x0400,%dx		/* round towards -oo */ |  | ||||||
| 	andw	$0xf7ff,%dx |  | ||||||
| 	movw	%dx,-8(%ebp) |  | ||||||
| 	fldcw	-8(%ebp)		/* load modified control word */ |  | ||||||
|  |  | ||||||
| 	flds	8(%ebp);		/* round */ | 	/* We use here %edx although only the low 1 bits are defined. | ||||||
| 	frndint | 	   But none of the operations should care and they are faster | ||||||
|  | 	   than the 16 bit operations.  */ | ||||||
|  | 	movl	$0x400,%edx		/* round towards -oo */ | ||||||
|  | 	orl	4(%esp),%edx | ||||||
|  | 	andl	$0xf7ff,%edx | ||||||
|  | 	movl	%edx,(%esp) | ||||||
|  | 	fldcw	(%esp)			/* load modified control word */ | ||||||
|  |  | ||||||
| 	fldcw	-4(%ebp)		/* restore original control word */ | 	frndint				/* round */ | ||||||
|  |  | ||||||
| 	leave | 	fldcw	4(%esp)			/* restore original control word */ | ||||||
|  |  | ||||||
|  | 	addl	$8,%esp | ||||||
| 	ret | 	ret | ||||||
| END (__floorf) | END (__floorf) | ||||||
| weak_alias (__floorf, floorf) | weak_alias (__floorf, floorf) | ||||||
|   | |||||||
| @@ -9,23 +9,25 @@ | |||||||
| RCSID("$NetBSD: $") | RCSID("$NetBSD: $") | ||||||
|  |  | ||||||
| ENTRY(__floorl) | ENTRY(__floorl) | ||||||
| 	pushl	%ebp | 	fldt	4(%esp) | ||||||
| 	movl	%esp,%ebp |  | ||||||
| 	subl	$8,%esp | 	subl	$8,%esp | ||||||
|  |  | ||||||
| 	fstcw	-4(%ebp)		/* store fpu control word */ | 	fstcw	4(%esp)			/* store fpu control word */ | ||||||
| 	movw	-4(%ebp),%dx |  | ||||||
| 	orw	$0x0400,%dx		/* round towards -oo */ |  | ||||||
| 	andw	$0xf7ff,%dx |  | ||||||
| 	movw	%dx,-8(%ebp) |  | ||||||
| 	fldcw	-8(%ebp)		/* load modified control word */ |  | ||||||
|  |  | ||||||
| 	fldt	8(%ebp)			/* round */ | 	/* We use here %edx although only the low 1 bits are defined. | ||||||
| 	frndint | 	   But none of the operations should care and they are faster | ||||||
|  | 	   than the 16 bit operations.  */ | ||||||
|  | 	movl	$0x400,%edx		/* round towards -oo */ | ||||||
|  | 	orl	4(%esp),%edx | ||||||
|  | 	andl	$0xf7ff,%edx | ||||||
|  | 	movl	%edx,(%esp) | ||||||
|  | 	fldcw	(%esp)			/* load modified control word */ | ||||||
|  |  | ||||||
| 	fldcw	-4(%ebp)		/* restore original control word */ | 	frndint				/* round */ | ||||||
|  |  | ||||||
| 	leave | 	fldcw	4(%esp)			/* restore original control word */ | ||||||
|  |  | ||||||
|  | 	addl	$8,%esp | ||||||
| 	ret | 	ret | ||||||
| END (__floorl) | END (__floorl) | ||||||
| weak_alias (__floorl, floorl) | weak_alias (__floorl, floorl) | ||||||
|   | |||||||
| @@ -11,7 +11,7 @@ RCSID("$NetBSD: $") | |||||||
| ENTRY(__significandl) | ENTRY(__significandl) | ||||||
| 	fldt	4(%esp) | 	fldt	4(%esp) | ||||||
| 	fxtract | 	fxtract | ||||||
| 	fincstp | 	fstp	%st(0) | ||||||
| 	ret | 	ret | ||||||
| END (__significandl) | END (__significandl) | ||||||
| weak_alias (__significandl, significandl) | weak_alias (__significandl, significandl) | ||||||
|   | |||||||
| @@ -14,14 +14,14 @@ | |||||||
|  */ |  */ | ||||||
|  |  | ||||||
| #if defined(LIBM_SCCS) && !defined(lint) | #if defined(LIBM_SCCS) && !defined(lint) | ||||||
| static char rcsid[] = "$NetBSD: e_coshf.c,v 1.5 1995/05/10 20:45:01 jtc Exp $"; | static char rcsid[] = "$NetBSD: e_coshf.c,v 1.6 1996/04/08 15:43:41 phil Exp $"; | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #include "math.h" | #include "math.h" | ||||||
| #include "math_private.h" | #include "math_private.h" | ||||||
|  |  | ||||||
| #ifdef __STDC__ | #ifdef __STDC__ | ||||||
| static const volatile float huge = 1.0e30; | static const float huge = 1.0e30; | ||||||
| static const float one = 1.0, half=0.5; | static const float one = 1.0, half=0.5; | ||||||
| #else | #else | ||||||
| static float one = 1.0, half=0.5, huge = 1.0e30; | static float one = 1.0, half=0.5, huge = 1.0e30; | ||||||
|   | |||||||
| @@ -14,13 +14,13 @@ | |||||||
|  */ |  */ | ||||||
|  |  | ||||||
| #if defined(LIBM_SCCS) && !defined(lint) | #if defined(LIBM_SCCS) && !defined(lint) | ||||||
| static char rcsid[] = "$NetBSD: e_expf.c,v 1.5 1995/05/10 20:45:05 jtc Exp $"; | static char rcsid[] = "$NetBSD: e_expf.c,v 1.6 1996/04/08 15:43:43 phil Exp $"; | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #include "math.h" | #include "math.h" | ||||||
| #include "math_private.h" | #include "math_private.h" | ||||||
|  |  | ||||||
| static const volatile float huge = 1.0e+30; | static const float huge = 1.0e+30; | ||||||
|  |  | ||||||
| #ifdef __STDC__ | #ifdef __STDC__ | ||||||
| static const float | static const float | ||||||
|   | |||||||
| @@ -56,7 +56,7 @@ static char rcsid[] = "$NetBSD: e_hypot.c,v 1.9 1995/05/12 04:57:27 jtc Exp $"; | |||||||
| 	double x, y; | 	double x, y; | ||||||
| #endif | #endif | ||||||
| { | { | ||||||
| 	double a=x,b=y,t1,t2,y1,y2,w; | 	double a,b,t1,t2,y1,y2,w; | ||||||
| 	int32_t j,k,ha,hb; | 	int32_t j,k,ha,hb; | ||||||
|  |  | ||||||
| 	GET_HIGH_WORD(ha,x); | 	GET_HIGH_WORD(ha,x); | ||||||
|   | |||||||
| @@ -27,7 +27,7 @@ static char rcsid[] = "$NetBSD: e_hypotf.c,v 1.5 1995/05/12 04:57:30 jtc Exp $"; | |||||||
| 	float x, y; | 	float x, y; | ||||||
| #endif | #endif | ||||||
| { | { | ||||||
| 	float a=x,b=y,t1,t2,y1,y2,w; | 	float a,b,t1,t2,y1,y2,w; | ||||||
| 	int32_t j,k,ha,hb; | 	int32_t j,k,ha,hb; | ||||||
|  |  | ||||||
| 	GET_FLOAT_WORD(ha,x); | 	GET_FLOAT_WORD(ha,x); | ||||||
|   | |||||||
							
								
								
									
										133
									
								
								sysdeps/libm-ieee754/e_hypotl.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										133
									
								
								sysdeps/libm-ieee754/e_hypotl.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,133 @@ | |||||||
|  | /* e_hypotl.c -- long double version of e_hypot.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 | ||||||
|  |  | ||||||
|  | /* __ieee754_hypotl(x,y) | ||||||
|  |  * | ||||||
|  |  * Method : | ||||||
|  |  *	If (assume round-to-nearest) z=x*x+y*y | ||||||
|  |  *	has error less than sqrt(2)/2 ulp, than | ||||||
|  |  *	sqrt(z) has error less than 1 ulp (exercise). | ||||||
|  |  * | ||||||
|  |  *	So, compute sqrt(x*x+y*y) with some care as | ||||||
|  |  *	follows to get the error below 1 ulp: | ||||||
|  |  * | ||||||
|  |  *	Assume x>y>0; | ||||||
|  |  *	(if possible, set rounding to round-to-nearest) | ||||||
|  |  *	1. if x > 2y  use | ||||||
|  |  *		x1*x1+(y*y+(x2*(x+x1))) for x*x+y*y | ||||||
|  |  *	where x1 = x with lower 32 bits cleared, x2 = x-x1; else | ||||||
|  |  *	2. if x <= 2y use | ||||||
|  |  *		t1*y1+((x-y)*(x-y)+(t1*y2+t2*y)) | ||||||
|  |  *	where t1 = 2x with lower 32 bits cleared, t2 = 2x-t1, | ||||||
|  |  *	y1= y with lower 32 bits chopped, y2 = y-y1. | ||||||
|  |  * | ||||||
|  |  *	NOTE: scaling may be necessary if some argument is too | ||||||
|  |  *	      large or too tiny | ||||||
|  |  * | ||||||
|  |  * Special cases: | ||||||
|  |  *	hypot(x,y) is INF if x or y is +INF or -INF; else | ||||||
|  |  *	hypot(x,y) is NAN if x or y is NAN. | ||||||
|  |  * | ||||||
|  |  * Accuracy: | ||||||
|  |  * 	hypot(x,y) returns sqrt(x^2+y^2) with error less | ||||||
|  |  * 	than 1 ulps (units in the last place) | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | #include "math.h" | ||||||
|  | #include "math_private.h" | ||||||
|  |  | ||||||
|  | #ifdef __STDC__ | ||||||
|  | 	long double __ieee754_hypotl(long double x, long double y) | ||||||
|  | #else | ||||||
|  | 	long double __ieee754_hypotl(x,y) | ||||||
|  | 	long double x, y; | ||||||
|  | #endif | ||||||
|  | { | ||||||
|  | 	long double a,b,t1,t2,y1,y2,w; | ||||||
|  | 	u_int32_t j,k,ea,eb; | ||||||
|  |  | ||||||
|  | 	GET_LDOUBLE_EXP(ea,x); | ||||||
|  | 	ea &= 0x7fff; | ||||||
|  | 	GET_LDOUBLE_EXP(eb,y); | ||||||
|  | 	eb &= 0x7fff; | ||||||
|  | 	if(eb > ea) {a=y;b=x;j=ea; ea=eb;eb=j;} else {a=x;b=y;} | ||||||
|  | 	SET_LDOUBLE_EXP(a,ea);	/* a <- |a| */ | ||||||
|  | 	SET_LDOUBLE_EXP(b,eb);	/* b <- |b| */ | ||||||
|  | 	if((ea-eb)>0x46) {return a+b;} /* x/y > 2**70 */ | ||||||
|  | 	k=0; | ||||||
|  | 	if(ea > 0x5f3f) {	/* a>2**8000 */ | ||||||
|  | 	   if(ea == 0x7fff) {	/* Inf or NaN */ | ||||||
|  | 	       u_int32_t exp,high,low; | ||||||
|  | 	       w = a+b;			/* for sNaN */ | ||||||
|  | 	       GET_LDOUBLE_WORDS(exp,high,low,a); | ||||||
|  | 	       if(((high&0x7fffffff)|low)==0) w = a; | ||||||
|  | 	       GET_LDOUBLE_WORDS(exp,high,low,b); | ||||||
|  | 	       if(((eb^0x7fff)|(high&0x7fffffff)|low)==0) w = b; | ||||||
|  | 	       return w; | ||||||
|  | 	   } | ||||||
|  | 	   /* scale a and b by 2**-9600 */ | ||||||
|  | 	   ea -= 0x2580; eb -= 0x2580;	k += 9600; | ||||||
|  | 	   SET_LDOUBLE_EXP(a,ea); | ||||||
|  | 	   SET_LDOUBLE_EXP(b,eb); | ||||||
|  | 	} | ||||||
|  | 	if(eb < 0x20bf) {	/* b < 2**-8000 */ | ||||||
|  | 	    if(eb == 0) {	/* subnormal b or 0 */ | ||||||
|  | 	        u_int32_t exp,high,low; | ||||||
|  | 		GET_LDOUBLE_WORDS(exp,high,low,b); | ||||||
|  | 		if((high|low)==0) return a; | ||||||
|  | 		SET_LDOUBLE_WORDS(t1, 0x7ffd, 0, 0);	/* t1=2^16382 */ | ||||||
|  | 		b *= t1; | ||||||
|  | 		a *= t1; | ||||||
|  | 		k -= 16382; | ||||||
|  | 	    } else {		/* scale a and b by 2^9600 */ | ||||||
|  | 	        ea += 0x2580; 	/* a *= 2^9600 */ | ||||||
|  | 		eb += 0x2580;	/* b *= 2^9600 */ | ||||||
|  | 		k -= 9600; | ||||||
|  | 		SET_LDOUBLE_EXP(a,ea); | ||||||
|  | 		SET_LDOUBLE_EXP(b,eb); | ||||||
|  | 	    } | ||||||
|  | 	} | ||||||
|  |     /* medium size a and b */ | ||||||
|  | 	w = a-b; | ||||||
|  | 	if (w>b) { | ||||||
|  | 	    u_int32_t high; | ||||||
|  | 	    GET_LDOUBLE_MSW(high,a); | ||||||
|  | 	    SET_LDOUBLE_WORDS(t1,ea,high,0); | ||||||
|  | 	    t2 = a-t1; | ||||||
|  | 	    w  = __ieee754_sqrtl(t1*t1-(b*(-b)-t2*(a+t1))); | ||||||
|  | 	} else { | ||||||
|  | 	    u_int32_t high; | ||||||
|  | 	    GET_LDOUBLE_MSW(high,b); | ||||||
|  | 	    a  = a+a; | ||||||
|  | 	    SET_LDOUBLE_WORDS(y1,eb,high,0); | ||||||
|  | 	    y2 = b - y1; | ||||||
|  | 	    GET_LDOUBLE_MSW(high,a); | ||||||
|  | 	    SET_LDOUBLE_WORDS(t1,ea+1,high,0); | ||||||
|  | 	    t2 = a - t1; | ||||||
|  | 	    w  = __ieee754_sqrtl(t1*y1-(w*(-w)-(t1*y2+t2*b))); | ||||||
|  | 	} | ||||||
|  | 	if(k!=0) { | ||||||
|  | 	    u_int32_t exp; | ||||||
|  | 	    t1 = 1.0; | ||||||
|  | 	    GET_LDOUBLE_EXP(exp,t1); | ||||||
|  | 	    SET_LDOUBLE_EXP(t1,exp+k); | ||||||
|  | 	    return t1*w; | ||||||
|  | 	} else return w; | ||||||
|  | } | ||||||
| @@ -14,13 +14,13 @@ | |||||||
|  */ |  */ | ||||||
|  |  | ||||||
| #if defined(LIBM_SCCS) && !defined(lint) | #if defined(LIBM_SCCS) && !defined(lint) | ||||||
| static char rcsid[] = "$NetBSD: e_powf.c,v 1.6 1995/05/12 04:57:35 jtc Exp $"; | static char rcsid[] = "$NetBSD: e_powf.c,v 1.7 1996/04/08 15:43:44 phil Exp $"; | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #include "math.h" | #include "math.h" | ||||||
| #include "math_private.h" | #include "math_private.h" | ||||||
|  |  | ||||||
| static const volatile float huge = 1.0e+30, tiny = 1.0e-30; | static const float huge = 1.0e+30, tiny = 1.0e-30; | ||||||
|  |  | ||||||
| #ifdef __STDC__ | #ifdef __STDC__ | ||||||
| static const float | static const float | ||||||
|   | |||||||
							
								
								
									
										91
									
								
								sysdeps/libm-ieee754/e_sinhl.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										91
									
								
								sysdeps/libm-ieee754/e_sinhl.c
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,91 @@ | |||||||
|  | /* e_asinhl.c -- long double version of e_asinh.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 | ||||||
|  |  | ||||||
|  | /* __ieee754_sinhl(x) | ||||||
|  |  * Method : | ||||||
|  |  * mathematically sinh(x) if defined to be (exp(x)-exp(-x))/2 | ||||||
|  |  *	1. Replace x by |x| (sinhl(-x) = -sinhl(x)). | ||||||
|  |  *	2. | ||||||
|  |  *		                                     E + E/(E+1) | ||||||
|  |  *	    0        <= x <= 25     :  sinhl(x) := --------------, E=expm1l(x) | ||||||
|  |  *			       			         2 | ||||||
|  |  * | ||||||
|  |  *	    25       <= x <= lnovft :  sinhl(x) := expl(x)/2 | ||||||
|  |  *	    lnovft   <= x <= ln2ovft:  sinhl(x) := expl(x/2)/2 * expl(x/2) | ||||||
|  |  *	    ln2ovft  <  x	    :  sinhl(x) := x*shuge (overflow) | ||||||
|  |  * | ||||||
|  |  * Special cases: | ||||||
|  |  *	sinhl(x) is |x| if x is +INF, -INF, or NaN. | ||||||
|  |  *	only sinhl(0)=0 is exact for finite x. | ||||||
|  |  */ | ||||||
|  |  | ||||||
|  | #include "math.h" | ||||||
|  | #include "math_private.h" | ||||||
|  |  | ||||||
|  | #ifdef __STDC__ | ||||||
|  | static const long double one = 1.0, shuge = 1.0e4931L; | ||||||
|  | #else | ||||||
|  | static long double one = 1.0, shuge = 1.0e4931L; | ||||||
|  | #endif | ||||||
|  |  | ||||||
|  | #ifdef __STDC__ | ||||||
|  | 	long double __ieee754_sinhl(long double x) | ||||||
|  | #else | ||||||
|  | 	long double __ieee754_sinhl(x) | ||||||
|  | 	long double x; | ||||||
|  | #endif | ||||||
|  | { | ||||||
|  | 	long double t,w,h; | ||||||
|  | 	u_int32_t jx,ix,i0,i1; | ||||||
|  |  | ||||||
|  |     /* Words of |x|. */ | ||||||
|  | 	GET_LDOUBLE_WORDS(jx,i0,i1,x); | ||||||
|  | 	ix = jx&0x7fff; | ||||||
|  |  | ||||||
|  |     /* x is INF or NaN */ | ||||||
|  | 	if(ix==0x7fff) return x+x; | ||||||
|  |  | ||||||
|  | 	h = 0.5; | ||||||
|  | 	if (jx<0) h = -h; | ||||||
|  |     /* |x| in [0,25], return sign(x)*0.5*(E+E/(E+1))) */ | ||||||
|  | 	if (ix < 0x4003 || (ix == 0x4003 && i0 <= 0xc8000000)) { /* |x|<25 */ | ||||||
|  | 	    if (ix<0x3fe3) 		/* |x|<2**-28 */ | ||||||
|  | 		if(shuge+x>one) return x;/* sinh(tiny) = tiny with inexact */ | ||||||
|  | 	    t = __expm1l(fabsl(x)); | ||||||
|  | 	    if(ix<0x3fff) return h*(2.0*t-t*t/(t+one)); | ||||||
|  | 	    return h*(t+t/(t+one)); | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  |     /* |x| in [25, log(maxdouble)] return 0.5*exp(|x|) */ | ||||||
|  | 	if (ix < 0x400c || (ix == 0x400c && i0 < 0xb17217f7)) | ||||||
|  | 		return h*__ieee754_expl(fabsl(x)); | ||||||
|  |  | ||||||
|  |     /* |x| in [log(maxdouble), overflowthresold] */ | ||||||
|  | 	if (ix<0x400c || (ix == 0x400c && (i0 < 0xb174ddc0 | ||||||
|  | 					   || (i0 == 0xb174ddc0 | ||||||
|  | 					       && i1 <= 0x31aec0ea)))) { | ||||||
|  | 	    w = __ieee754_expl(0.5*fabsl(x)); | ||||||
|  | 	    t = h*w; | ||||||
|  | 	    return t*w; | ||||||
|  | 	} | ||||||
|  |  | ||||||
|  |     /* |x| > overflowthresold, sinhl(x) overflow */ | ||||||
|  | 	return x*shuge; | ||||||
|  | } | ||||||
| @@ -12,9 +12,9 @@ | |||||||
| # Library General Public License for more details. | # Library General Public License for more details. | ||||||
|  |  | ||||||
| # You should have received a copy of the GNU Library General Public | # 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 | # License along with the GNU C Library; see the file COPYING.LIB.  If not, | ||||||
| # not, write to the Free Software Foundation, Inc., 675 Mass Ave, | # write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330, | ||||||
| # Cambridge, MA 02139, USA. | # Boston, MA 02111-1307, USA. | ||||||
|  |  | ||||||
| # The mpn functions need this.  All existing 68k ports use MIT syntax.  If | # The mpn functions need this.  All existing 68k ports use MIT syntax.  If | ||||||
| # a new port wants to use Motorola or Sony syntax, it can redefine this | # a new port wants to use Motorola or Sony syntax, it can redefine this | ||||||
| @@ -30,3 +30,7 @@ CFLAGS-setjmp.c := -fno-omit-frame-pointer | |||||||
|  |  | ||||||
| # The 68k `long double' is a distinct type we support. | # The 68k `long double' is a distinct type we support. | ||||||
| long-double-fcts = yes | long-double-fcts = yes | ||||||
|  |  | ||||||
|  | ifeq ($(subdir),elf) | ||||||
|  | CFLAGS-rtld.c += -Wno-uninitialized | ||||||
|  | endif | ||||||
|   | |||||||
| @@ -34,7 +34,7 @@ __sigpause (sig_or_mask, is_sig) | |||||||
|       /* The modern X/Open implementation is requested.  */ |       /* The modern X/Open implementation is requested.  */ | ||||||
|       if (sigprocmask (0, NULL, &set) < 0 |       if (sigprocmask (0, NULL, &set) < 0 | ||||||
| 	  /* Yes, we call `sigaddset' and not `__sigaddset'.  */ | 	  /* Yes, we call `sigaddset' and not `__sigaddset'.  */ | ||||||
| 	  || sigaddset (&set, sig_or_mask) < 0) | 	  || sigdelset (&set, sig_or_mask) < 0) | ||||||
| 	return -1; | 	return -1; | ||||||
|     } |     } | ||||||
|   else |   else | ||||||
| @@ -54,3 +54,16 @@ __sigpause (sig_or_mask, is_sig) | |||||||
|  |  | ||||||
|   return sigsuspend (&set); |   return sigsuspend (&set); | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | /* We have to provide a default version of this function since the | ||||||
|  |    standards demand it.  The version which is a bit more reasonable is | ||||||
|  |    the BSD version.  So make this the default.  */ | ||||||
|  | int __default_sigpause __P ((int mask)); | ||||||
|  | int | ||||||
|  | __default_sigpause (mask) | ||||||
|  |      int mask; | ||||||
|  | { | ||||||
|  |   return __sigpause (mask, 0); | ||||||
|  | } | ||||||
|  | weak_alias (__default_sigpause, sigpause) | ||||||
|   | |||||||
| @@ -1,11 +0,0 @@ | |||||||
| #include <math.h> |  | ||||||
| #include <stdio.h> |  | ||||||
|  |  | ||||||
| long double |  | ||||||
| __ieee754_hypotl (long double x, long double y) |  | ||||||
| { |  | ||||||
|   fputs ("__ieee754_hypotl not implemented\n", stderr); |  | ||||||
|   return 0.0; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| stub_warning (__ieee754_hypotl) |  | ||||||
| @@ -1,11 +0,0 @@ | |||||||
| #include <math.h> |  | ||||||
| #include <stdio.h> |  | ||||||
|  |  | ||||||
| long double |  | ||||||
| __ieee754_sinhl (long double x) |  | ||||||
| { |  | ||||||
|   fputs ("__ieee754_sinhl not implemented\n", stderr); |  | ||||||
|   return 0.0; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| stub_warning (__ieee754_sinhl) |  | ||||||
							
								
								
									
										73
									
								
								time/asia
									
									
									
									
									
								
							
							
						
						
									
										73
									
								
								time/asia
									
									
									
									
									
								
							| @@ -1,4 +1,4 @@ | |||||||
| # @(#)asia	7.26 | # @(#)asia	7.27 | ||||||
|  |  | ||||||
| # This data is by no means authoritative; if you think you know better, | # This data is by no means authoritative; if you think you know better, | ||||||
| # go ahead and edit the file (and please send any changes to | # go ahead and edit the file (and please send any changes to | ||||||
| @@ -354,6 +354,26 @@ Zone Asia/Jayapura	9:22:48 -	LMT	1932 Nov | |||||||
| 			9:00	-	JAYT | 			9:00	-	JAYT | ||||||
|  |  | ||||||
| # Iran | # Iran | ||||||
|  | # From Paul Eggert (1996-12-17), following up a suggestion by Rich Wales: | ||||||
|  | # Ahmad Alavi <URL:http://tehran.stanford.edu/Iran_Lib/Calendar/taghveem.txt> | ||||||
|  | # (1993-08-04) writes ``Daylight saving time in Iran starts from the first day | ||||||
|  | # of Farvardin and ends the first day of Mehr.''  This disagrees with the SSIM: | ||||||
|  | # | ||||||
|  | #		   DST start	   DST end | ||||||
|  | #	year	SSIM	Alavi	SSIM	Alavi | ||||||
|  | #	1991	05-03!=	03-21	09-20!=	09-23 | ||||||
|  | #	1992	03-22!=	03-21	09-23	09-23 | ||||||
|  | #	1993	03-21	03-21	09-23	09-23 | ||||||
|  | #	1994	03-21	03-21	09-22!= 09-23 | ||||||
|  | #	1995	03-21	03-21	09-22!= 09-23 | ||||||
|  | #	1996	03-21!=	03-20	09-21!= 09-22 | ||||||
|  | #	1997	03-21	03-21	09-21!= 09-23 | ||||||
|  | # | ||||||
|  | # Go with Alavi starting with 1992. | ||||||
|  | # I used Ed Reingold's cal-persia in GNU Emacs 19.34 to compute Persian dates. | ||||||
|  | # The Persian calendar is based on the sun, and dates after around 2050 | ||||||
|  | # are approximate; stop after 2037 when 32-bit time_t's overflow. | ||||||
|  | # | ||||||
| # Rule	NAME	FROM	TO	TYPE	IN	ON	AT	SAVE	LETTER/S | # Rule	NAME	FROM	TO	TYPE	IN	ON	AT	SAVE	LETTER/S | ||||||
| Rule	Iran	1978	1980	-	Mar	21	0:00	1:00	S | Rule	Iran	1978	1980	-	Mar	21	0:00	1:00	S | ||||||
| Rule	Iran	1978	only	-	Oct	21	0:00	0	- | Rule	Iran	1978	only	-	Oct	21	0:00	0	- | ||||||
| @@ -361,11 +381,50 @@ Rule	Iran	1979	only	-	Sep	19	0:00	0	- | |||||||
| Rule	Iran	1980	only	-	Sep	23	0:00	0	- | Rule	Iran	1980	only	-	Sep	23	0:00	0	- | ||||||
| Rule	Iran	1991	only	-	May	 3	0:00s	1:00	S | Rule	Iran	1991	only	-	May	 3	0:00s	1:00	S | ||||||
| Rule	Iran	1991	only	-	Sep	20	0:00s	0	- | Rule	Iran	1991	only	-	Sep	20	0:00s	0	- | ||||||
| Rule	Iran	1992	only	-	Mar	22	0:00	1:00	S | Rule	Iran	1992	1995	-	Mar	21	0:00	1:00	S | ||||||
| Rule	Iran	1992	1993	-	Sep	23	0:00	0	- | Rule	Iran	1992	1995	-	Sep	23	0:00	0	- | ||||||
| Rule	Iran	1993	max	-	Mar	21	0:00	1:00	S | Rule	Iran	1996	only	-	Mar	20	0:00	1:00	S | ||||||
| Rule	Iran	1994	1995	-	Sep	22	0:00	0	- | Rule	Iran	1996	only	-	Sep	22	0:00	0	- | ||||||
| Rule	Iran	1996	max	-	Sep	21	0:00	0	- | Rule	Iran	1997	1999	-	Mar	21	0:00	1:00	S | ||||||
|  | Rule	Iran	1997	1999	-	Sep	23	0:00	0	- | ||||||
|  | Rule	Iran	2000	only	-	Mar	20	0:00	1:00	S | ||||||
|  | Rule	Iran	2000	only	-	Sep	22	0:00	0	- | ||||||
|  | Rule	Iran	2001	2003	-	Mar	21	0:00	1:00	S | ||||||
|  | Rule	Iran	2001	2003	-	Sep	23	0:00	0	- | ||||||
|  | Rule	Iran	2004	only	-	Mar	20	0:00	1:00	S | ||||||
|  | Rule	Iran	2004	only	-	Sep	22	0:00	0	- | ||||||
|  | Rule	Iran	2005	2007	-	Mar	21	0:00	1:00	S | ||||||
|  | Rule	Iran	2005	2007	-	Sep	23	0:00	0	- | ||||||
|  | Rule	Iran	2008	only	-	Mar	20	0:00	1:00	S | ||||||
|  | Rule	Iran	2008	only	-	Sep	22	0:00	0	- | ||||||
|  | Rule	Iran	2009	2011	-	Mar	21	0:00	1:00	S | ||||||
|  | Rule	Iran	2009	2011	-	Sep	23	0:00	0	- | ||||||
|  | Rule	Iran	2012	only	-	Mar	20	0:00	1:00	S | ||||||
|  | Rule	Iran	2012	only	-	Sep	22	0:00	0	- | ||||||
|  | Rule	Iran	2013	2015	-	Mar	21	0:00	1:00	S | ||||||
|  | Rule	Iran	2013	2015	-	Sep	23	0:00	0	- | ||||||
|  | Rule	Iran	2016	only	-	Mar	20	0:00	1:00	S | ||||||
|  | Rule	Iran	2016	only	-	Sep	22	0:00	0	- | ||||||
|  | Rule	Iran	2017	2019	-	Mar	21	0:00	1:00	S | ||||||
|  | Rule	Iran	2017	2019	-	Sep	23	0:00	0	- | ||||||
|  | Rule	Iran	2020	only	-	Mar	20	0:00	1:00	S | ||||||
|  | Rule	Iran	2020	only	-	Sep	22	0:00	0	- | ||||||
|  | Rule	Iran	2021	2023	-	Mar	21	0:00	1:00	S | ||||||
|  | Rule	Iran	2021	2023	-	Sep	23	0:00	0	- | ||||||
|  | Rule	Iran	2024	2025	-	Mar	20	0:00	1:00	S | ||||||
|  | Rule	Iran	2024	2025	-	Sep	22	0:00	0	- | ||||||
|  | Rule	Iran	2026	2027	-	Mar	21	0:00	1:00	S | ||||||
|  | Rule	Iran	2026	2027	-	Sep	23	0:00	0	- | ||||||
|  | Rule	Iran	2028	2029	-	Mar	20	0:00	1:00	S | ||||||
|  | Rule	Iran	2028	2029	-	Sep	22	0:00	0	- | ||||||
|  | Rule	Iran	2030	2031	-	Mar	21	0:00	1:00	S | ||||||
|  | Rule	Iran	2030	2031	-	Sep	23	0:00	0	- | ||||||
|  | Rule	Iran	2032	2033	-	Mar	20	0:00	1:00	S | ||||||
|  | Rule	Iran	2032	2033	-	Sep	22	0:00	0	- | ||||||
|  | Rule	Iran	2034	2035	-	Mar	21	0:00	1:00	S | ||||||
|  | Rule	Iran	2034	2035	-	Sep	23	0:00	0	- | ||||||
|  | Rule	Iran	2036	2037	-	Mar	20	0:00	1:00	S | ||||||
|  | Rule	Iran	2036	2037	-	Sep	22	0:00	0	- | ||||||
| # Zone	NAME		GMTOFF	RULES	FORMAT	[UNTIL] | # Zone	NAME		GMTOFF	RULES	FORMAT	[UNTIL] | ||||||
| Zone	Asia/Tehran	3:25:44	-	LMT	1916 | Zone	Asia/Tehran	3:25:44	-	LMT	1916 | ||||||
| 			3:25:44	-	TMT	1946	# Tehran Mean Time | 			3:25:44	-	TMT	1946	# Tehran Mean Time | ||||||
| @@ -492,7 +551,7 @@ Rule	Zion	1995	only	-	Sep	 3	0:00	0	S | |||||||
| # | # | ||||||
| #   ftp://ftp.huji.ac.il/pub/misc/timezones/announcements/1996-1998.ps.gz | #   ftp://ftp.huji.ac.il/pub/misc/timezones/announcements/1996-1998.ps.gz | ||||||
| # | # | ||||||
| # Emptor Caveat: The dates for the years 1996-1998 were originally announced | # Caveat emptor: The dates for the years 1996-1998 were originally announced | ||||||
| # on 1995-08-31, by the previous Minister of Interior.  The new Minister | # on 1995-08-31, by the previous Minister of Interior.  The new Minister | ||||||
| # of Interior changed the dates on 1996-01-01, to take into account the | # of Interior changed the dates on 1996-01-01, to take into account the | ||||||
| # desires of certain portions of Israeli society (the next election is in the | # desires of certain portions of Israeli society (the next election is in the | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| # @(#)australasia	7.30 | # @(#)australasia	7.31 | ||||||
| # This file also includes Pacific islands. | # This file also includes Pacific islands. | ||||||
|  |  | ||||||
| # Notes are at the end of this file | # Notes are at the end of this file | ||||||
| @@ -48,15 +48,15 @@ Zone Australia/Perth	 7:43:24 -	LMT	1895 Dec | |||||||
| # so use Lindeman. | # so use Lindeman. | ||||||
| # | # | ||||||
| # Rule	NAME	FROM	TO	TYPE	IN	ON	AT	SAVE	LETTER/S | # Rule	NAME	FROM	TO	TYPE	IN	ON	AT	SAVE	LETTER/S | ||||||
| Rule	QL	1989	1991	-	Oct	lastSun	2:00s	1:00	- | Rule	AQ	1989	1991	-	Oct	lastSun	2:00s	1:00	- | ||||||
| Rule	QL	1990	1992	-	Mar	Sun>=1	2:00s	0	- | Rule	AQ	1990	1992	-	Mar	Sun>=1	2:00s	0	- | ||||||
| Rule	Holiday	1989	1993	-	Oct	lastSun	2:00s	1:00	- | Rule	Holiday	1989	1993	-	Oct	lastSun	2:00s	1:00	- | ||||||
| Rule	Holiday	1990	1994	-	Mar	Sun>=1	2:00s	0	- | Rule	Holiday	1990	1994	-	Mar	Sun>=1	2:00s	0	- | ||||||
| Zone Australia/Brisbane	10:12:08 -	LMT	1895 | Zone Australia/Brisbane	10:12:08 -	LMT	1895 | ||||||
| 			10:00	-	EST	1917 Jan 1 0:01 | 			10:00	-	EST	1917 Jan 1 0:01 | ||||||
| 			10:00	Aus	EST	1971 Oct lastSun 2:00s | 			10:00	Aus	EST	1971 Oct lastSun 2:00s | ||||||
| 			10:00	1:00	EST	1972 Feb lastSun 2:00s | 			10:00	1:00	EST	1972 Feb lastSun 2:00s | ||||||
| 			10:00	QL	EST | 			10:00	AQ	EST | ||||||
| Zone Australia/Lindeman  9:55:56 -	LMT	1895 | Zone Australia/Lindeman  9:55:56 -	LMT	1895 | ||||||
| 			10:00	-	EST	1917 Jan 1 0:01 | 			10:00	-	EST	1917 Jan 1 0:01 | ||||||
| 			10:00	Aus	EST	1971 Oct lastSun 2:00s | 			10:00	Aus	EST	1971 Oct lastSun 2:00s | ||||||
| @@ -339,7 +339,7 @@ Zone Pacific/Palau	8:57:56 -	LMT	1901		# Koror | |||||||
| 			9:00	-	PWT	# Palau Time | 			9:00	-	PWT	# Palau Time | ||||||
|  |  | ||||||
| # Palmyra | # Palmyra | ||||||
| # uninhabited since World War II; was probably like Pacific/Kiritmati | # uninhabited since World War II; was probably like Pacific/Kiritimati | ||||||
|  |  | ||||||
| # Papua New Guinea | # Papua New Guinea | ||||||
| # Zone	NAME		GMTOFF	RULES	FORMAT	[UNTIL] | # Zone	NAME		GMTOFF	RULES	FORMAT	[UNTIL] | ||||||
|   | |||||||
| @@ -1,28 +1,30 @@ | |||||||
| /* Copyright (C) 1991, 1994 Free Software Foundation, Inc. | /* Copyright (C) 1991, 1994, 1996 Free Software Foundation, Inc. | ||||||
| This file is part of the GNU C Library. |    This file is part of the GNU C Library. | ||||||
|  |  | ||||||
| The GNU C Library is free software; you can redistribute it and/or |    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 |    modify it under the terms of the GNU Library General Public License as | ||||||
| published by the Free Software Foundation; either version 2 of the |    published by the Free Software Foundation; either version 2 of the | ||||||
| License, or (at your option) any later version. |    License, or (at your option) any later version. | ||||||
|  |  | ||||||
| The GNU C Library is distributed in the hope that it will be useful, |    The GNU C Library is distributed in the hope that it will be useful, | ||||||
| but WITHOUT ANY WARRANTY; without even the implied warranty of |    but WITHOUT ANY WARRANTY; without even the implied warranty of | ||||||
| MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU |    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU | ||||||
| Library General Public License for more details. |    Library General Public License for more details. | ||||||
|  |  | ||||||
| You should have received a copy of the GNU Library General Public |    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 |    License along with the GNU C Library; see the file COPYING.LIB.  If not, | ||||||
| not, write to the Free Software Foundation, Inc., 675 Mass Ave, |    write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330, | ||||||
| Cambridge, MA 02139, USA.  */ |    Boston, MA 02111-1307, USA.  */ | ||||||
|  |  | ||||||
| #include <ansidecl.h> |  | ||||||
| #include <time.h> | #include <time.h> | ||||||
|  | #include <values.h> | ||||||
|  |  | ||||||
|  |  | ||||||
| /* Return the difference between TIME1 and TIME0.  */ | /* Return the difference between TIME1 and TIME0.  */ | ||||||
| double | double | ||||||
| DEFUN(difftime, (time1, time0), time_t time1 AND time_t time0) | difftime (time1, time0) | ||||||
|  |      time_t time1; | ||||||
|  |      time_t time0; | ||||||
| { | { | ||||||
|   /* Algorithm courtesy Paul Eggert (eggert@twinsun.com).  */ |   /* Algorithm courtesy Paul Eggert (eggert@twinsun.com).  */ | ||||||
|  |  | ||||||
| @@ -30,8 +32,8 @@ DEFUN(difftime, (time1, time0), time_t time1 AND time_t time0) | |||||||
|  |  | ||||||
|   if (sizeof (time_t) < sizeof (double)) |   if (sizeof (time_t) < sizeof (double)) | ||||||
|     return (double) time1 - (double) time0; |     return (double) time1 - (double) time0; | ||||||
|   if (sizeof (time_t) < sizeof (LONG_DOUBLE)) |   if (sizeof (time_t) < sizeof (long double)) | ||||||
|     return (LONG_DOUBLE) time1 - (LONG_DOUBLE) time0; |     return (long double) time1 - (long double) time0; | ||||||
|  |  | ||||||
|   if (time1 < time0) |   if (time1 < time0) | ||||||
|     return - difftime (time0, time1); |     return - difftime (time0, time1); | ||||||
| @@ -43,9 +45,7 @@ DEFUN(difftime, (time1, time0), time_t time1 AND time_t time0) | |||||||
|     return delta; |     return delta; | ||||||
|  |  | ||||||
|   /* Repair delta overflow.  */ |   /* Repair delta overflow.  */ | ||||||
|   hibit = 1; |   hibit = (~ (time_t) 0) << (_TYPEBITS (time_t) - 1); | ||||||
|   while ((hibit <<= 1) > 0) |  | ||||||
|     continue; |  | ||||||
|  |  | ||||||
|   /* The following expression rounds twice, which means the result may not |   /* The following expression rounds twice, which means the result may not | ||||||
|      be the closest to the true answer.  For example, suppose time_t is |      be the closest to the true answer.  For example, suppose time_t is | ||||||
| @@ -62,5 +62,5 @@ DEFUN(difftime, (time1, time0), time_t time1 AND time_t time0) | |||||||
|      round twice when converting large unsigned types to small floating |      round twice when converting large unsigned types to small floating | ||||||
|      types, so if time_t is unsigned the "return delta" above has the same |      types, so if time_t is unsigned the "return delta" above has the same | ||||||
|      double-rounding problem.  */ |      double-rounding problem.  */ | ||||||
|   return delta - 2 * (LONG_DOUBLE) hibit; |   return delta - 2 * (long double) hibit; | ||||||
| } | } | ||||||
|   | |||||||
							
								
								
									
										30
									
								
								time/europe
									
									
									
									
									
								
							
							
						
						
									
										30
									
								
								time/europe
									
									
									
									
									
								
							| @@ -1,4 +1,4 @@ | |||||||
| # @(#)europe	7.41 | # @(#)europe	7.42 | ||||||
|  |  | ||||||
| # This data is by no means authoritative; if you think you know better, | # This data is by no means authoritative; if you think you know better, | ||||||
| # go ahead and edit the file (and please send any changes to | # go ahead and edit the file (and please send any changes to | ||||||
| @@ -78,7 +78,7 @@ | |||||||
| # of the text said: | # of the text said: | ||||||
| # | # | ||||||
| # `An old stone obelisk marking a forgotten terrestrial meridian stands | # `An old stone obelisk marking a forgotten terrestrial meridian stands | ||||||
| # beside the river at Kew. In the 18th century, before time and longditude | # beside the river at Kew. In the 18th century, before time and longitude | ||||||
| # was standardised by the Royal Observatory in Greenwich, scholars observed | # was standardised by the Royal Observatory in Greenwich, scholars observed | ||||||
| # this stone and the movement of stars from Kew Observatory nearby. They | # this stone and the movement of stars from Kew Observatory nearby. They | ||||||
| # made their calculations and set the time for the Horse Guards and Parliament, | # made their calculations and set the time for the Horse Guards and Parliament, | ||||||
| @@ -86,7 +86,7 @@ | |||||||
| # along the towpath within a few yards of it.' | # along the towpath within a few yards of it.' | ||||||
| # | # | ||||||
| # I have a one inch to one mile map of London and my estimate of the stone's | # I have a one inch to one mile map of London and my estimate of the stone's | ||||||
| # position is 51 deg. 28' 30" N, 0 deg. 18' 45" W. The longditude should | # position is 51 deg. 28' 30" N, 0 deg. 18' 45" W. The longitude should | ||||||
| # be within about +-2". The Ordnance Survey grid reference is TQ172761. | # be within about +-2". The Ordnance Survey grid reference is TQ172761. | ||||||
| # | # | ||||||
| # [This yields GMTOFF = -0:01:15 for London LMT in the 18th century.] | # [This yields GMTOFF = -0:01:15 for London LMT in the 18th century.] | ||||||
| @@ -167,7 +167,7 @@ | |||||||
| # It ends at 02:00 GMT on the morning of the day after the fourth Saturday | # It ends at 02:00 GMT on the morning of the day after the fourth Saturday | ||||||
| # in October. (All the redundant `morning of the day ...' is in the Act.) | # in October. (All the redundant `morning of the day ...' is in the Act.) | ||||||
| # This is only of passing interest now as it will always be overridden by | # This is only of passing interest now as it will always be overridden by | ||||||
| # an Order in Council (a Statutary Instrument, the SI thing mentioned above) | # an Order in Council (a Statutory Instrument, the SI thing mentioned above) | ||||||
| # to specify the EC specified dates. | # to specify the EC specified dates. | ||||||
|  |  | ||||||
| # From Peter Ilieve <peter@memex.co.uk> (1993-10-18): | # From Peter Ilieve <peter@memex.co.uk> (1993-10-18): | ||||||
| @@ -327,7 +327,7 @@ | |||||||
| # so that part of the 1922 Act will still apply. | # so that part of the 1922 Act will still apply. | ||||||
| # | # | ||||||
| # - The Defence (Summer Time) Regulations, 1939, SR&O 1939 No. 1379 | # - The Defence (Summer Time) Regulations, 1939, SR&O 1939 No. 1379 | ||||||
| #   [SR&O == Statutary Regulation and Order] | #   [SR&O == Statutory Regulation and Order] | ||||||
| # | # | ||||||
| # These were made under the Emergency Powers (Defence) Act, 1939. | # These were made under the Emergency Powers (Defence) Act, 1939. | ||||||
| # It changes the end date to be the day after the third Saturday in November. | # It changes the end date to be the day after the third Saturday in November. | ||||||
| @@ -403,7 +403,7 @@ | |||||||
| # harmonise with the EC since 1981. The major change is that the time changes | # harmonise with the EC since 1981. The major change is that the time changes | ||||||
| # to 01:00 GMT.) | # to 01:00 GMT.) | ||||||
| # | # | ||||||
| # - The Summer Time Order, 1992, SI 1992/1729 [SI == Statutary Instrument] | # - The Summer Time Order, 1992, SI 1992/1729 [SI == Statutory Instrument] | ||||||
| # | # | ||||||
| # This specifies dates of: | # This specifies dates of: | ||||||
| #       Start       End | #       Start       End | ||||||
| @@ -1298,7 +1298,7 @@ Zone	Europe/Athens	1:34:52 -	LMT	1895 Sep 14 | |||||||
| 			1:00	Greece	CE%sT	1944 Apr  4 | 			1:00	Greece	CE%sT	1944 Apr  4 | ||||||
| 			2:00	Greece	EE%sT	1981 | 			2:00	Greece	EE%sT	1981 | ||||||
| 			# Shanks says they switched to C-Eur in 1981; | 			# Shanks says they switched to C-Eur in 1981; | ||||||
| 			# go with EU intead, since Greece joined it on Jan 1. | 			# go with EU instead, since Greece joined it on Jan 1. | ||||||
| 			2:00	EU	EE%sT | 			2:00	EU	EE%sT | ||||||
|  |  | ||||||
| # Hungary | # Hungary | ||||||
| @@ -1819,9 +1819,15 @@ Zone Europe/Bucharest	1:44:24 -	LMT	1891 Oct | |||||||
| 			2:00	E-Eur	EE%sT | 			2:00	E-Eur	EE%sT | ||||||
|  |  | ||||||
| # Russia | # Russia | ||||||
| # From Shanks (1991): |  | ||||||
| # In 1929 the Soviet Union instituted a 5 day week; in 1932 it instituted | # From Chris Carrier <72157.3334@CompuServe.COM> (1996-12-02): | ||||||
| # a 6 day week; on 1940-06-27 it returned to the Gregorian week. | # On 1929-10-01 the Soviet Union instituted an ``Eternal Calendar'' | ||||||
|  | # with 30-day months plus 5 holidays, with a 5-day week. | ||||||
|  | # On 1931-12-01 it changed to a 6-day week; in 1934 it reverted to the | ||||||
|  | # Gregorian calendar while retaining the 6-day week; on 1940-06-27 it | ||||||
|  | # reverted to the 7-day week.  With the 6-day week the usual days | ||||||
|  | # off were the 6th, 12th, 18th, 24th and 30th of the month. | ||||||
|  | # (Source: Evitiar Zerubavel, _The Seven Day Circle_) | ||||||
| # | # | ||||||
| # From Paul Eggert <eggert@twinsun.com> (1996-11-22): | # From Paul Eggert <eggert@twinsun.com> (1996-11-22): | ||||||
| # Except for Moscow after 1919-07-01, I invented the time zone abbreviations, | # Except for Moscow after 1919-07-01, I invented the time zone abbreviations, | ||||||
| @@ -1882,7 +1888,7 @@ Zone Asia/Omsk		 4:53:36 -	LMT	1924 May  2 | |||||||
| # as far as I remember it was done exactly during winter->summer switching | # as far as I remember it was done exactly during winter->summer switching | ||||||
| # so we (Novosibirsk) simply did not switch. | # so we (Novosibirsk) simply did not switch. | ||||||
| Zone Asia/Novosibirsk	 5:31:40 -	LMT	1924 May  2 | Zone Asia/Novosibirsk	 5:31:40 -	LMT	1924 May  2 | ||||||
| 			 6:00	-	NOVT	1957 Mar # Novosibirsk TIme | 			 6:00	-	NOVT	1957 Mar # Novosibirsk Time | ||||||
| 			 7:00	Russia	NOV%sT	1991 Mar 31 2:00s | 			 7:00	Russia	NOV%sT	1991 Mar 31 2:00s | ||||||
| 			 6:00	1:00	NOVST	1991 Sep 29 2:00s | 			 6:00	1:00	NOVST	1991 Sep 29 2:00s | ||||||
| 			 6:00	-	NOVT	1992 Jan 19 2:00s | 			 6:00	-	NOVT	1992 Jan 19 2:00s | ||||||
| @@ -2134,7 +2140,7 @@ Link	Europe/Istanbul	Asia/Istanbul	# Istanbul is in both continents. | |||||||
| # Ukraine | # Ukraine | ||||||
| # Rule	NAME	FROM	TO	TYPE	IN	ON	AT	SAVE	LETTER/S | # Rule	NAME	FROM	TO	TYPE	IN	ON	AT	SAVE	LETTER/S | ||||||
| Rule	Ukraine	1917	only	-	Jul	 1	23:00	1:00	UST	# Ukrainian Summer Time | Rule	Ukraine	1917	only	-	Jul	 1	23:00	1:00	UST	# Ukrainian Summer Time | ||||||
| Rule	Ukraine	1917	only	-	Dec	28	 0:00	0	KMT	# Kiev Mean TIme | Rule	Ukraine	1917	only	-	Dec	28	 0:00	0	KMT	# Kiev Mean Time | ||||||
| Rule	Ukraine	1918	only	-	May	31	22:00	2:00	UDST	# Ukrainian Double Summer Time | Rule	Ukraine	1918	only	-	May	31	22:00	2:00	UDST	# Ukrainian Double Summer Time | ||||||
| Rule	Ukraine	1918	only	-	Sep	17	 0:00	1:00	UST | Rule	Ukraine	1918	only	-	Sep	17	 0:00	1:00	UST | ||||||
| Rule	Ukraine	1919	only	-	May	31	23:00	2:00	UDST | Rule	Ukraine	1919	only	-	May	31	23:00	2:00	UDST | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| # @(#)northamerica	7.29 | # @(#)northamerica	7.30 | ||||||
| # also includes Central America and the Caribbean | # also includes Central America and the Caribbean | ||||||
|  |  | ||||||
| # This data is by no means authoritative; if you think you know better, | # This data is by no means authoritative; if you think you know better, | ||||||
| @@ -920,9 +920,9 @@ Zone America/Dawson	-9:17:40 -	LMT	1900 Aug 20 | |||||||
| # MEXICO BAJA CAL N   7 H  BEHIND UTC    BAJA CALIFORNIA SUR AND | # MEXICO BAJA CAL N   7 H  BEHIND UTC    BAJA CALIFORNIA SUR AND | ||||||
| # MEXICO BAJA CAL N                      N. PACIFIC COAST (STATES | # MEXICO BAJA CAL N                      N. PACIFIC COAST (STATES | ||||||
| # MEXICO BAJA CAL N                      OF SINALOA AND SONORA) | # MEXICO BAJA CAL N                      OF SINALOA AND SONORA) | ||||||
| # MEXICO BAJA CAL N   8 H  BEHIND UTC    ABOVE 28TH PARALLAL APR 3 | # MEXICO BAJA CAL N   8 H  BEHIND UTC    ABOVE 28TH PARALLEL APR 3 | ||||||
| # MEXICO BAJA CAL N                      - OCT 29 | # MEXICO BAJA CAL N                      - OCT 29 | ||||||
| # MEXICO BAJA CAL N   7 H  BEHIND UTC    ABOVE 28TH PARALLAL APR 3 | # MEXICO BAJA CAL N   7 H  BEHIND UTC    ABOVE 28TH PARALLEL APR 3 | ||||||
| # MEXICO BAJA CAL N                      - 0CT 29 | # MEXICO BAJA CAL N                      - 0CT 29 | ||||||
| # MEXICO              6 H  BEHIND UTC    STATES OF DURANGO, | # MEXICO              6 H  BEHIND UTC    STATES OF DURANGO, | ||||||
| # MEXICO                                 COAHUILA, NUEVO LEON, | # MEXICO                                 COAHUILA, NUEVO LEON, | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| # @(#)southamerica	7.15 | # @(#)southamerica	7.16 | ||||||
|  |  | ||||||
| # This data is by no means authoritative; if you think you know better, | # This data is by no means authoritative; if you think you know better, | ||||||
| # go ahead and edit the file (and please send any changes to | # go ahead and edit the file (and please send any changes to | ||||||
| @@ -61,7 +61,7 @@ | |||||||
| # ARGENTINA           3 H BEHIND   UTC | # ARGENTINA           3 H BEHIND   UTC | ||||||
|  |  | ||||||
| # From Hernan G. Otero <hernan@isoft.com.ar> (1995-06-26): | # From Hernan G. Otero <hernan@isoft.com.ar> (1995-06-26): | ||||||
| # I am sending modifications to the Argentinian time zone table... | # I am sending modifications to the Argentine time zone table... | ||||||
| # AR was chosen because they are the ISO letters that represent Argentina. | # AR was chosen because they are the ISO letters that represent Argentina. | ||||||
|  |  | ||||||
| # Rule	NAME	FROM	TO	TYPE	IN	ON	AT	SAVE	LETTER/S | # Rule	NAME	FROM	TO	TYPE	IN	ON	AT	SAVE	LETTER/S | ||||||
| @@ -99,7 +99,7 @@ Rule	Arg	1988	only	-	Dec	 1	0:00	1:00	S | |||||||
| # These corrections were contributed by InterSoft Argentina S.A., | # These corrections were contributed by InterSoft Argentina S.A., | ||||||
| # obtaining the data from the: | # obtaining the data from the: | ||||||
| # Talleres de Hidrografia Naval Argentina | # Talleres de Hidrografia Naval Argentina | ||||||
| # (Argentinian Naval Hydrography Institute) | # (Argentine Naval Hydrography Institute) | ||||||
| # | # | ||||||
| # Shanks gives 1989 Mar 16 and stops after 1990 Mar 4; go with Otero. | # Shanks gives 1989 Mar 16 and stops after 1990 Mar 4; go with Otero. | ||||||
| Rule	Arg	1989	1993	-	Mar	Sun>=1	0:00	0	- | Rule	Arg	1989	1993	-	Mar	Sun>=1	0:00	0	- | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| #ifndef lint | #ifndef lint | ||||||
| #ifndef NOID | #ifndef NOID | ||||||
| static char	elsieid[] = "@(#)zic.c	7.79"; | static char	elsieid[] = "@(#)zic.c	7.80"; | ||||||
| #endif /* !defined NOID */ | #endif /* !defined NOID */ | ||||||
| #endif /* !defined lint */ | #endif /* !defined lint */ | ||||||
|  |  | ||||||
| @@ -1697,7 +1697,7 @@ const int			zonecount; | |||||||
| 					(void) strcpy(startbuf, zp->z_format); | 					(void) strcpy(startbuf, zp->z_format); | ||||||
| 			eat(zp->z_filename, zp->z_linenum); | 			eat(zp->z_filename, zp->z_linenum); | ||||||
| 			if (*startbuf == '\0') | 			if (*startbuf == '\0') | ||||||
| error(_("can't determine time zone abbrevation to use just after until time")); | error(_("can't determine time zone abbreviation to use just after until time")); | ||||||
| 			else	addtt(starttime, | 			else	addtt(starttime, | ||||||
| 					addtype(startoff, startbuf, | 					addtype(startoff, startbuf, | ||||||
| 						startoff != zp->z_gmtoff, | 						startoff != zp->z_gmtoff, | ||||||
|   | |||||||
							
								
								
									
										4
									
								
								values.h
									
									
									
									
									
								
							
							
						
						
									
										4
									
								
								values.h
									
									
									
									
									
								
							| @@ -35,11 +35,11 @@ | |||||||
| #define DOUBLEBITS	_TYPEBITS (double) | #define DOUBLEBITS	_TYPEBITS (double) | ||||||
| #define FLOATBITS	_TYPEBITS (float) | #define FLOATBITS	_TYPEBITS (float) | ||||||
|  |  | ||||||
| #define MINSHORT	SHORT_MIN | #define MINSHORT	SHRT_MIN | ||||||
| #define	MININT		INT_MIN | #define	MININT		INT_MIN | ||||||
| #define	MINLONG		LONG_MIN | #define	MINLONG		LONG_MIN | ||||||
|  |  | ||||||
| #define	MAXSHORT	SHORT_MAX | #define	MAXSHORT	SHRT_MAX | ||||||
| #define	MAXINT		INT_MAX | #define	MAXINT		INT_MAX | ||||||
| #define	MAXLONG		LONG_MAX | #define	MAXLONG		LONG_MAX | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user