mirror of
git://sourceware.org/git/newlib-cygwin.git
synced 2025-01-26 17:17:20 +08:00
dee5139131
* configure.host(stdio64_dir): New setting that is used to enable building of new stdio64 directory. * libc/Makefile.am[HAVE_STDIO64_DIR]: Add support for large files. (stmp-stdio64,stdio64.texi): New targets to optionally add in stdio64 info to info files. * libc/Makefile.in: Regenerated. * libc/configure: Ditto. * libc/configure.in: Add configuration variables that are set when stdio64 is selected as subdir in configure.host. * libc/libc.texinfo: Add optional menu item for Stdio64, based on whether STDIO64 flag is set or not. * libc/sys.tex: Add optional stdio64 syscalls based on whether STDIO64 flag is set or not. * libc/include/reent.h[__LARGE64_FILES]: Add new stdio64 _r sycall routines. * libc/include/stdio.h[__LARGE64_FILES]: Add new stdio64 prototypes. (FILE): Typedef'd to __FILE instead of struct __sFILE directly. (__SL64): New file flag indicating file is opened via fopen64. * libc/include/sys/_types.h(_off64_t): Added. * libc/include/sys/config.h: For x86-linux, define __LARGE64_FILES. * libc/include/sys/reent.h(struct __sFILE64): New file structure for 64-bit offset large file support. (__FILE): New intermediate type either set to struct __sFILE64 or struct __sFILE, depending on whether __LARGE64_FILES is set or not. * libc/reent/Makefile.am[HAVE_STDIO64_DIR]: Add new files. * libc/reent/Makefile.in: Regenerated. * libc/reent/fstat64r.c: New file. * libc/reent/lseek64r.c: Ditto. * libc/reent/open64r.c: Ditto. * libc/reent/reent.tex: Optionally add stdio64 reentrant syscalls based on whether STDIO64 flag is set. * libc/stdio/stdio.tex: Add blank line. * libc/stdio64/Makefile.am: New file. * libc/stdio64/Makefile.in: Ditto. * libc/stdio64/fgetpos64.c: Ditto. * libc/stdio64/fopen64.: Ditto. * libc/stdio64/freopen64.c: Ditto. * libc/stdio64/fseeko64.c: Ditto. * libc/stdio64/fsetpos64.c: Ditto. * libc/stdio64/ftello64.c: Ditto. * libc/stdio64/local64.h: Ditto. * libc/stdio64/stdio64.c: Ditto. * libc/stdio64/stdio64.tex: Ditto. * libc/stdio64/tmpfile64.c: Ditto. * libc/sys/linux/io64.c: Add weak aliases for lseek64, fstat64, and open64.
118 lines
4.0 KiB
TeX
118 lines
4.0 KiB
TeX
@node Reentrancy
|
|
@chapter Reentrancy
|
|
|
|
@cindex reentrancy
|
|
Reentrancy is a characteristic of library functions which allows multiple
|
|
processes to use the same address space with assurance that the values stored
|
|
in those spaces will remain constant between calls. Cygnus's implementation
|
|
of the library functions ensures that
|
|
whenever possible, these library functions are reentrant. However,
|
|
there are some functions that can not be trivially made reentrant.
|
|
Hooks have been provided to allow you to use these functions in a fully
|
|
reentrant fashion.
|
|
|
|
@findex _reent
|
|
@findex reent.h
|
|
@cindex reentrancy structure
|
|
These hooks use the structure @code{_reent} defined in @file{reent.h}.
|
|
A variable defined as @samp{struct _reent} is called a @dfn{reentrancy
|
|
structure}. All functions which must manipulate global information are
|
|
available in two versions. The first version has the usual name, and
|
|
uses a single global instance of the reentrancy structure. The second
|
|
has a different name, normally formed by prepending @samp{_} and
|
|
appending @samp{_r}, and takes a pointer to the particular reentrancy
|
|
structure to use.
|
|
|
|
For example, the function @code{fopen} takes two arguments, @var{file}
|
|
and @var{mode}, and uses the global reentrancy structure. The function
|
|
@code{_fopen_r} takes the arguments, @var{struct_reent}, which is a
|
|
pointer to an instance of the reentrancy structure, @var{file}
|
|
and @var{mode}.
|
|
|
|
There are two versions of @samp{struct _reent}, a normal one and one
|
|
for small memory systems, controlled by the @code{_REENT_SMALL}
|
|
definition from the (automatically included) @file{<sys/config.h>}.
|
|
|
|
@cindex global reentrancy structure
|
|
@findex _impure_ptr
|
|
Each function which uses the global reentrancy structure uses the global
|
|
variable @code{_impure_ptr}, which points to a reentrancy structure.
|
|
|
|
This means that you have two ways to achieve reentrancy. Both require
|
|
that each thread of execution control initialize a unique global
|
|
variable of type @samp{struct _reent}:
|
|
|
|
@enumerate
|
|
@item
|
|
@cindex extra argument, reentrant fns
|
|
Use the reentrant versions of the library functions, after initializing
|
|
a global reentrancy structure for each process. Use the pointer to this
|
|
structure as the extra argument for all library functions.
|
|
|
|
@item
|
|
Ensure that each thread of execution control has a pointer to its own
|
|
unique reentrancy structure in the global variable @code{_impure_ptr},
|
|
and call the standard library subroutines.
|
|
@end enumerate
|
|
|
|
@cindex list of reentrant functions
|
|
@cindex reentrant function list
|
|
The following functions are provided in both reentrant
|
|
and non-reentrant versions.
|
|
|
|
@example
|
|
@exdent @emph{Equivalent for errno variable:}
|
|
_errno_r
|
|
|
|
@exdent @emph{Locale functions:}
|
|
_localeconv_r _setlocale_r
|
|
|
|
@exdent @emph{Equivalents for stdio variables:}
|
|
_stdin_r _stdout_r _stderr_r
|
|
|
|
@page
|
|
@exdent @emph{Stdio functions:}
|
|
_fdopen_r _perror_r _tempnam_r
|
|
_fopen_r _putchar_r _tmpnam_r
|
|
_getchar_r _puts_r _tmpfile_r
|
|
_gets_r _remove_r _vfprintf_r
|
|
_iprintf_r _rename_r _vsnprintf_r
|
|
_mkstemp_r _snprintf_r _vsprintf_r
|
|
_mktemp_t _sprintf_r
|
|
|
|
@exdent @emph{Signal functions:}
|
|
_init_signal_r _signal_r
|
|
_kill_r __sigtramp_r
|
|
_raise_r
|
|
|
|
@exdent @emph{Stdlib functions:}
|
|
_calloc_r _mblen_r _setenv_r
|
|
_dtoa_r _mbstowcs_r _srand_r
|
|
_free_r _mbtowc_r _strtod_r
|
|
_getenv_r _memalign_r _strtol_r
|
|
_mallinfo_r _mstats_r _strtoul_r
|
|
_malloc_r _putenv_r _system_r
|
|
_malloc_r _rand_r _wcstombs_r
|
|
_malloc_stats_r _realloc_r _wctomb_r
|
|
|
|
@exdent @emph{String functions:}
|
|
_strdup_r _strtok_r
|
|
|
|
@exdent @emph{System functions:}
|
|
_close_r _link_r _unlink_r
|
|
_execve_r _lseek_r _wait_r
|
|
_fcntl_r _open_r _write_r
|
|
_fork_r _read_r
|
|
_fstat_r _sbrk_r
|
|
_gettimeofday_r _stat_r
|
|
_getpid_r _times_r
|
|
|
|
@ifset STDIO64
|
|
@exdent @emph{Additional 64-bit I/O System functions:}
|
|
_fstat64_r _lseek64_r _open64_r
|
|
@end ifset
|
|
|
|
@exdent @emph{Time function:}
|
|
_asctime_r
|
|
@end example
|