diff options
Diffstat (limited to 'manual')
-rw-r--r-- | manual/arith.texi | 10 | ||||
-rw-r--r-- | manual/conf.texi | 593 | ||||
-rw-r--r-- | manual/creature.texi | 65 | ||||
-rw-r--r-- | manual/llio.texi | 216 | ||||
-rw-r--r-- | manual/maint.texi | 135 | ||||
-rw-r--r-- | manual/math.texi | 27 | ||||
-rw-r--r-- | manual/process.texi | 24 | ||||
-rw-r--r-- | manual/signal.texi | 8 | ||||
-rw-r--r-- | manual/stdio.texi | 29 | ||||
-rw-r--r-- | manual/terminal.texi | 8 | ||||
-rw-r--r-- | manual/time.texi | 36 |
11 files changed, 1124 insertions, 27 deletions
diff --git a/manual/arith.texi b/manual/arith.texi index 7f8c205..2e41883 100644 --- a/manual/arith.texi +++ b/manual/arith.texi @@ -414,13 +414,19 @@ This function returns the absolute value of the floating-point number @deftypefunx float cabsf (complex float @var{z}) @deftypefunx {long double} cabsl (complex long double @var{z}) These functions return the absolute value of the complex number @var{z}. -The compiler must support complex numbers to use these functions. (See -also the function @code{hypot} in @ref{Exponents and Logarithms}.) The +The compiler must support complex numbers to use these functions. The value is: @smallexample sqrt (creal (@var{z}) * creal (@var{z}) + cimag (@var{z}) * cimag (@var{z})) @end smallexample + +This function should always be used instead of the direct formula since +using the simple straight-forward method can mean to loose accuracy. If +one of the squared values is neglectable in size compared to the other +value the result should be the same as the larger value. But squaring +the value and afterwards using the square root function leads to +unaccuracy. See @code{hypot} in @xref{Exponents and Logarithms}. @end deftypefun @node Normalization Functions diff --git a/manual/conf.texi b/manual/conf.texi index 4f9326e..64591ee 100644 --- a/manual/conf.texi +++ b/manual/conf.texi @@ -236,7 +236,7 @@ always defines this as @code{1}, on the assumption that you had to have @deftypevr Macro {long int} _POSIX_VERSION This constant represents the version of the POSIX.1 standard to which the implementation conforms. For an implementation conforming to the -1990 POSIX.1 standard, the value is the integer @code{199009L}. +1995 POSIX.1 standard, the value is the integer @code{199506L}. @code{_POSIX_VERSION} is always defined (in @file{unistd.h}) in any POSIX system. @@ -368,6 +368,294 @@ Inquire about the parameter corresponding to @code{CLOCKS_PER_SEC}; @pxref{Basic CPU Time}. @comment unistd.h +@comment GNU +@item _SC_CHARCLASS_NAME_MAX +Inquire about the parameter corresponding to maximal length allowed for +a character class name in an extended locale specification. These +extensions are not yet standardized and so this option is not standardized +as well. + +@comment unistdh.h +@comment POSIX.1 +@item _SC_REALTIME_SIGNALS +Inquire about the parameter corresponding to @code{_POSIX_REALTIME_SIGNALS}. + +@comment unistd.h +@comment POSIX.1 +@item _SC_PRIORITY_SCHEDULING +Inquire about the parameter corresponding to @code{_POSIX_PRIORITY_SCHEDULING}. + +@comment unistd.h +@comment POSIX.1 +@item _SC_TIMERS +Inquire about the parameter corresponding to @code{_POSIX_TIMERS}. + +@comment unistd.h +@comment POSIX.1 +@item _SC_ASYNCHRONOUS_IO +Inquire about the parameter corresponding to @code{_POSIX_ASYNCHRONOUS_IO}. + +@comment unistd.h +@comment POSIX.1 +@item _SC_PRIORITIZED_IO +Inquire about the parameter corresponding to @code{_POSIX_PRIORITIZED_IO}. + +@comment unistd.h +@comment POSIX.1 +@item _SC_SYNCHRONIZED_IO +Inquire about the parameter corresponding to @code{_POSIX_SYNCHRONIZED_IO}. + +@comment unistd.h +@comment POSIX.1 +@item _SC_FSYNC +Inquire about the parameter corresponding to @code{_POSIX_FSYNC}. + +@comment unistd.h +@comment POSIX.1 +@item _SC_MAPPED_FILES +Inquire about the parameter corresponding to @code{_POSIX_MAPPED_FILES}. + +@comment unistd.h +@comment POSIX.1 +@item _SC_MEMLOCK +Inquire about the parameter corresponding to @code{_POSIX_MEMLOCK}. + +@comment unistd.h +@comment POSIX.1 +@item _SC_MEMLOCK_RANGE +Inquire about the parameter corresponding to @code{_POSIX_MEMLOCK_RANGE}. + +@comment unistd.h +@comment POSIX.1 +@item _SC_MEMORY_PROTECTION +Inquire about the parameter corresponding to @code{_POSIX_MEMORY_PROTECTION}. + +@comment unistd.h +@comment POSIX.1 +@item _SC_MESSAGE_PASSING +Inquire about the parameter corresponding to @code{_POSIX_MESSAGE_PASSING}. + +@comment unistd.h +@comment POSIX.1 +@item _SC_SEMAPHORES +Inquire about the parameter corresponding to @code{_POSIX_SEMAPHORES}. + +@comment unistd.h +@comment POSIX.1 +@item _SC_SHARED_MEMORY_OBJECTS +Inquire about the parameter corresponding to +@code{_POSIX_SHARED_MEMORY_OBJECTS}. + +@comment unistd.h +@comment POSIX.1 +@item _SC_AIO_LISTIO_MAX +Inquire about the parameter corresponding to @code{_POSIX_AIO_LISTIO_MAX}. + +@comment unistd.h +@comment POSIX.1 +@item _SC_AIO_MAX +Inquire about the parameter corresponding to @code{_POSIX_AIO_MAX}. + +@comment unistd.h +@comment POSIX.1 +@item _SC_AIO_PRIO_DELTA_MAX +Inquire the value by which a process can decrease its asynchronous I/O +priority level from its own scheduling priority. This corresponds to the +run-time invariant value @code{AIO_PRIO_DELTA_MAX}. + +@comment unistd.h +@comment POSIX.1 +@item _SC_DELAYTIMER_MAX +Inquire about the parameter corresponding to @code{_POSIX_DELAYTIMER_MAX}. + +@comment unistd.h +@comment POSIX.1 +@item _SC_MQ_OPEN_MAX +Inquire about the parameter corresponding to @code{_POSIX_MQ_OPEN_MAX}. + +@comment unistd.h +@comment POSIX.1 +@item _SC_MQ_PRIO_MAX +Inquire about the parameter corresponding to @code{_POSIX_MQ_PRIO_MAX}. + +@comment unistd.h +@comment POSIX.1 +@item _SC_RTSIG_MAX +Inquire about the parameter corresponding to @code{_POSIX_RTSIG_MAX}. + +@comment unistd.h +@comment POSIX.1 +@item _SC_SEM_NSEMS_MAX +Inquire about the parameter corresponding to @code{_POSIX_SEM_NSEMS_MAX}. + +@comment unistd.h +@comment POSIX.1 +@item _SC_SEM_VALUE_MAX +Inquire about the parameter corresponding to @code{_POSIX_SEM_VALUE_MAX}. + +@comment unistd.h +@comment POSIX.1 +@item _SC_SIGQUEUE_MAX +Inquire about the parameter corresponding to @code{_POSIX_SIGQUEUE_MAX}. + +@comment unistd.h +@comment POSIX.1 +@item _SC_TIMER_MAX +Inquire about the parameter corresponding to @code{_POSIX_TIMER_MAX}. + +@comment unistd.h +@comment POSIX.1g +@item _SC_PII +Inquire about the parameter corresponding to @code{_POSIX_PII}. + +@comment unistd.h +@comment POSIX.1g +@item _SC_PII_XTI +Inquire about the parameter corresponding to @code{_POSIX_PII_XTI}. + +@comment unistd.h +@comment POSIX.1g +@item _SC_PII_SOCKET +Inquire about the parameter corresponding to @code{_POSIX_PII_SOCKET}. + +@comment unistd.h +@comment POSIX.1g +@item _SC_PII_INTERNET +Inquire about the parameter corresponding to @code{_POSIX_PII_INTERNET}. + +@comment unistd.h +@comment POSIX.1g +@item _SC_PII_OSI +Inquire about the parameter corresponding to @code{_POSIX_PII_OSI}. + +@comment unistd.h +@comment POSIX.1g +@item _SC_SELECT +Inquire about the parameter corresponding to @code{_POSIX_SELECT}. + +@comment unistd.h +@comment POSIX.1g +@item _SC_UIO_MAXIOV +Inquire about the parameter corresponding to @code{_POSIX_UIO_MAXIOV}. + +@comment unistd.h +@comment POSIX.1g +@item _SC_PII_INTERNET_STREAM +Inquire about the parameter corresponding to @code{_POSIX_PII_INTERNET_STREAM}. + +@comment unistd.h +@comment POSIX.1g +@item _SC_PII_INTERNET_DGRAM +Inquire about the parameter corresponding to @code{_POSIX_PII_INTERNET_DGRAM}. + +@comment unistd.h +@comment POSIX.1g +@item _SC_PII_OSI_COTS +Inquire about the parameter corresponding to @code{_POSIX_PII_OSI_COTS}. + +@comment unistd.h +@comment POSIX.1g +@item _SC_PII_OSI_CLTS +Inquire about the parameter corresponding to @code{_POSIX_PII_OSI_CLTS}. + +@comment unistd.h +@comment POSIX.1g +@item _SC_PII_OSI_M +Inquire about the parameter corresponding to @code{_POSIX_PII_OSI_M}. + +@comment unistd.h +@comment POSIX.1g +@item _SC_T_IOV_MAX +Inquire the value of the value associated with the @code{T_IOV_MAX} +variable. + +@comment unistd.h +@comment POSIX.1 +@item _SC_THREADS +Inquire about the parameter corresponding to @code{_POSIX_THREADS}. + +@comment unistd.h +@comment POSIX.1 +@item _SC_THREAD_SAFE_FUNCTIONS +Inquire about the parameter corresponding to +@code{_POSIX_THREAD_SAFE_FUNCTIONS}. + +@comment unistd.h +@comment POSIX.1 +@item _SC_GETGR_R_SIZE_MAX +Inquire about the parameter corresponding to @code{_POSIX_GETGR_R_SIZE_MAX}. + +@comment unistd.h +@comment POSIX.1 +@item _SC_GETPW_R_SIZE_MAX +Inquire about the parameter corresponding to @code{_POSIX_GETPW_R_SIZE_MAX}. + +@comment unistd.h +@comment POSIX.1 +@item _SC_LOGIN_NAME_MAX +Inquire about the parameter corresponding to @code{_POSIX_LOGIN_NAME_MAX}. + +@comment unistd.h +@comment POSIX.1 +@item _SC_TTY_NAME_MAX +Inquire about the parameter corresponding to @code{_POSIX_TTY_NAME_MAX}. + +@comment unistd.h +@comment POSIX.1 +@item _SC_THREAD_DESTRUCTOR_ITERATIONS +Inquire about the parameter corresponding to +@code{_POSIX_THREAD_DESTRUCTOR_ITERATIONS}. + +@comment unistd.h +@comment POSIX.1 +@item _SC_THREAD_KEYS_MAX +Inquire about the parameter corresponding to @code{_POSIX_THREAD_KEYS_MAX}. + +@comment unistd.h +@comment POSIX.1 +@item _SC_THREAD_STACK_MIN +Inquire about the parameter corresponding to @code{_POSIX_THREAD_STACK_MIN}. + +@comment unistd.h +@comment POSIX.1 +@item _SC_THREAD_THREADS_MAX +Inquire about the parameter corresponding to @code{_POSIX_THREAD_THREADS_MAX}. + +@comment unistd.h +@comment POSIX.1 +@item _SC_THREAD_ATTR_STACKADDR +Inquire about the parameter corresponding to +@code{_POSIX_THREAD_ATTR_STACKADDR}. + +@comment unistd.h +@comment POSIX.1 +@item _SC_THREAD_ATTR_STACKSIZE +Inquire about the parameter corresponding to +@code{_POSIX_THREAD_ATTR_STACKSIZE}. + +@comment unistd.h +@comment POSIX.1 +@item _SC_THREAD_PRIORITY_SCHEDULING +Inquire about the parameter corresponding to +@code{_POSIX_THREAD_PRIORITY_SCHEDULING}. + +@comment unistd.h +@comment POSIX.1 +@item _SC_THREAD_PRIO_INHERIT +Inquire about the parameter corresponding to @code{_POSIX_THREAD_PRIO_INHERIT}. + +@comment unistd.h +@comment POSIX.1 +@item _SC_THREAD_PRIO_PROTECT +Inquire about the parameter corresponding to @code{_POSIX_THREAD_PRIO_PROTECT}. + +@comment unistd.h +@comment POSIX.1 +@item _SC_THREAD_PROCESS_SHARED +Inquire about the parameter corresponding to +@code{_POSIX_THREAD_PROCESS_SHARED}. + +@comment unistd.h @comment POSIX.2 @item _SC_2_C_DEV Inquire about whether the system has the POSIX.2 C compiler command, @@ -465,6 +753,212 @@ support. Inquire about the virtual memory page size of the machine. @code{getpagesize} returns the same value. @c @xref{XXX getpagesize}. !!! ??? + +@comment unistd.h +@comment GNU +@item _SC_NPROCESSORS_CONF +Inquire about number of configured processors. + +@comment unistd.h +@comment GNU +@item _SC_NPROCESSORS_ONLN +Inquire about number of processors online. + +@comment unistd.h +@comment GNU +@item _SC_PHYS_PAGES +Inquire about number of physical pages in the system. + +@comment unistd.h +@comment GNU +@item _SC_AVPHYS_PAGES +Inquire about number of available physical pages in the system. + +@comment unistd.h +@comment GNU +@item _SC_ATEXIT_MAX +Inquire about number of functions which can be registered as termination +functions for @code{atexit}; @pxref{Cleanups on Exit}. + +@comment unistd.h +@comment X/Open +@item _SC_XOPEN_VERSION +Inquire about the parameter corresponding to @code{_XOPEN_VERSION}. + +@comment unistd.h +@comment X/Open +@item _SC_XOPEN_XCU_VERSION +Inquire about the parameter corresponding to @code{_XOPEN_XCU_VERSION}. + +@comment unistd.h +@comment X/Open +@item _SC_XOPEN_UNIX +Inquire about the parameter corresponding to @code{_XOPEN_UNIX}. + +@comment unistd.h +@comment X/Open +@item _SC_XOPEN_CRYPT +Inquire about the parameter corresponding to @code{_XOPEN_CRYPT}. + +@comment unistd.h +@comment X/Open +@item _SC_XOPEN_ENH_I18N +Inquire about the parameter corresponding to @code{_XOPEN_ENH_I18N}. + +@comment unistd.h +@comment X/Open +@item _SC_XOPEN_SHM +Inquire about the parameter corresponding to @code{_XOPEN_SHM}. + +@comment unistd.h +@comment X/Open +@item _SC_XOPEN_XPG2 +Inquire about the parameter corresponding to @code{_XOPEN_XPG2}. + +@comment unistd.h +@comment X/Open +@item _SC_XOPEN_XPG3 +Inquire about the parameter corresponding to @code{_XOPEN_XPG3}. + +@comment unistd.h +@comment X/Open +@item _SC_XOPEN_XPG4 +Inquire about the parameter corresponding to @code{_XOPEN_XPG4}. + +@comment unistd.h +@comment X/Open +@item _SC_CHAR_BIT +Inquire about number of bits in a variable of type @code{char}. + +@comment unistd.h +@comment X/Open +@item _SC_CHAR_MAX +Inquire about maximum value which can be stored in a variable of type +@code{char}. + +@comment unistd.h +@comment X/Open +@item _SC_CHAR_MIN +Inquire about minimum value which can be stored in a variable of type +@code{char}. + +@comment unistd.h +@comment X/Open +@item _SC_INT_MAX +Inquire about maximum value which can be stored in a variable of type +@code{int}. + +@comment unistd.h +@comment X/Open +@item _SC_INT_MIN +Inquire about minimum value which can be stored in a variable of type +@code{int}. + +@comment unistd.h +@comment X/Open +@item _SC_LONG_BIT +Inquire about number of bits in a variable of type @code{long int}. + +@comment unistd.h +@comment X/Open +@item _SC_WORD_BIT +Inquire about number of bits in a variable of a register word. + +@comment unistd.h +@comment X/Open +@item _SC_MB_LEN_MAX +Inquire the maximum length of a multi-byte representation of a wide +character value. + +@comment unistd.h +@comment X/Open +@item _SC_NZERO +Inquire value used to internally represent the zero priority level for +the process execution. + +@comment unistd.h +@comment X/Open +@item SC_SSIZE_MAX +Inquire about maximum value which can be stored in a variable of type +@code{ssize_t}. + +@comment unistd.h +@comment X/Open +@item _SC_SCHAR_MAX +Inquire about maximum value which can be stored in a variable of type +@code{signed char}. + +@comment unistd.h +@comment X/Open +@item _SC_SCHAR_MIN +Inquire about minimum value which can be stored in a variable of type +@code{signed char}. + +@comment unistd.h +@comment X/Open +@item _SC_SHRT_MAX +Inquire about maximum value which can be stored in a variable of type +@code{short int}. + +@comment unistd.h +@comment X/Open +@item _SC_SHRT_MIN +Inquire about minimum value which can be stored in a variable of type +@code{short int}. + +@comment unistd.h +@comment X/Open +@item _SC_UCHAR_MAX +Inquire about maximum value which can be stored in a variable of type +@code{unsigned char}. + +@comment unistd.h +@comment X/Open +@item _SC_UINT_MAX +Inquire about maximum value which can be stored in a variable of type +@code{unsigned int}. + +@comment unistd.h +@comment X/Open +@item _SC_ULONG_MAX +Inquire about maximum value which can be stored in a variable of type +@code{unsigned long int}. + +@comment unistd.h +@comment X/Open +@item _SC_USHRT_MAX +Inquire about maximum value which can be stored in a variable of type +@code{unsigned short int}. + +@comment unistd.h +@comment X/Open +@item _SC_NL_ARGMAX +Inquire about the parameter corresponding to @code{NL_ARGMAX}. + +@comment unistd.h +@comment X/Open +@item _SC_NL_LANGMAX +Inquire about the parameter corresponding to @code{NL_LANGMAX}. + +@comment unistd.h +@comment X/Open +@item _SC_NL_MSGMAX +Inquire about the parameter corresponding to @code{NL_MSGMAX}. + +@comment unistd.h +@comment X/Open +@item _SC_NL_NMAX +Inquire about the parameter corresponding to @code{NL_NMAX}. + +@comment unistd.h +@comment X/Open +@item _SC_NL_SETMAX +Inquire about the parameter corresponding to @code{NL_SETMAX}. + +@comment unistd.h +@comment X/Open +@item _SC_NL_TEXTMAX +Inquire about the parameter corresponding to @code{NL_TEXTMAX}. @end table @node Examples of Sysconf @@ -522,6 +1016,23 @@ system you are using can go that far. @table @code @comment limits.h @comment POSIX.1 +@item _POSIX_AIO_LISTIO_MAX +The most restrictive limit permitted by POSIX for the maximum number of +I/O operations that can be specified in a list I/O call. The value of +this constant is @code{2}; thus you can add up to two new entries +of the list of outstandard operations. + +@comment limits.h +@comment POSIX.1 +@item _POSIX_AIO_MAX +The most restrictive limit permitted by POSIX for the maximum number of +outstanding asynchronous I/O operations. The value of this constant is +@code{1}. So you cannot expect that you can issue more than one +operation and immediately continue with the normal work, receiving the +notifications asynchronously. + +@comment limits.h +@comment POSIX.1 @item _POSIX_ARG_MAX The value of this macro is the most restrictive limit permitted by POSIX for the maximum combined length of the @var{argv} and @var{environ} @@ -732,7 +1243,9 @@ particular file, call @code{pathconf} or @code{fpathconf}. Here are the names for the POSIX minimum upper bounds for some of the above parameters. The significance of these values is that you can safely push to these limits without checking whether the particular -system you are using can go that far. +system you are using can go that far. In most cases GNU systems do not +have these strict limitations. The actual limit should be requested if +necessary. @table @code @comment limits.h @@ -883,6 +1396,26 @@ Inquire about the value of @code{_POSIX_NO_TRUNC}. @comment POSIX.1 @item _PC_VDISABLE Inquire about the value of @code{_POSIX_VDISABLE}. + +@comment unistd.h +@comment POSIX.1 +@item _PC_SYNC_IO +Inquire about the value of @code{_POSIX_SYNC_IO}. + +@comment unistd.h +@comment POSIX.1 +@item _PC_ASYNC_IO +Inquire about the value of @code{_POSIX_ASYNC_IO}. + +@comment unistd.h +@comment POSIX.1 +@item _PC_PRIO_IO +Inquire about the value of @code{_POSIX_PRIO_IO}. + +@comment unistd.h +@comment POSIX.1g +@item _PC_SOCK_MAXBUF +Inquire about the value of @code{_POSIX_PIPE_BUF}. @end table @node Utility Limits @@ -1064,6 +1597,62 @@ Currently there is just one parameter you can read with @code{confstr}: This parameter's value is the recommended default path for searching for executable files. This is the path that a user has by default just after logging in. + +@comment unistd.h +@comment Unix98 +@item _CS_LFS_CFLAGS +The returned string specifies which additionals flags must be given to +the C compiler if a source is compiled using the +@code{_LARGEFILE_SOURCE} feature select macro; @pxref{Feature Test Macros}. + +@comment unistd.h +@comment Unix98 +@item _CS_LFS_LDFLAGS +The returned string specifies which additionals flags must be given to +the linker if a source is compiled using the +@code{_LARGEFILE_SOURCE} feature select macro; @pxref{Feature Test Macros}. + +@comment unistd.h +@comment Unix98 +@item _CS_LFS_LIBS +The returned string specifies which additionals libraries must be linked +to the application if a source is compiled using the +@code{_LARGEFILE_SOURCE} feature select macro; @pxref{Feature Test Macros}. + +@comment unistd.h +@comment Unix98 +@item _CS_LFS_LINTFLAGS +The returned string specifies which additionals flags must be given to +the the lint tool if a source is compiled using the +@code{_LARGEFILE_SOURCE} feature select macro; @pxref{Feature Test Macros}. + +@comment unistd.h +@comment Unix98 +@item _CS_LFS64_CFLAGS +The returned string specifies which additionals flags must be given to +the C compiler if a source is compiled using the +@code{_LARGEFILE64_SOURCE} feature select macro; @pxref{Feature Test Macros}. + +@comment unistd.h +@comment Unix98 +@item _CS_LFS64_LDFLAGS +The returned string specifies which additionals flags must be given to +the linker if a source is compiled using the +@code{_LARGEFILE64_SOURCE} feature select macro; @pxref{Feature Test Macros}. + +@comment unistd.h +@comment Unix98 +@item _CS_LFS64_LIBS +The returned string specifies which additionals libraries must be linked +to the application if a source is compiled using the +@code{_LARGEFILE64_SOURCE} feature select macro; @pxref{Feature Test Macros}. + +@comment unistd.h +@comment Unix98 +@item _CS_LFS64_LINTFLAGS +The returned string specifies which additionals flags must be given to +the the lint tool if a source is compiled using the +@code{_LARGEFILE64_SOURCE} feature select macro; @pxref{Feature Test Macros}. @end table The way to use @code{confstr} without any arbitrary limit on string size diff --git a/manual/creature.texi b/manual/creature.texi index 9d9b451..2e0c62e 100644 --- a/manual/creature.texi +++ b/manual/creature.texi @@ -71,7 +71,7 @@ included as well as the @w{ISO C}, POSIX.1, POSIX.2, and X/Open material. @end defvr @comment (none) -@comment XOPEN +@comment X/Open @defvr Macro _XOPEN_SOURCE @defvrx Macro _XOPEN_SOURCE_EXTENDED If you define this macro, functionality described in the X/Open @@ -91,11 +91,72 @@ all functionality described so far plus some new definitions from the Single Unix specification, @w{version 2}. @end defvr +@comment (NONE) +@comment X/Open +@defvr Macro _LARGEFILE_SOURCE +If this macro is defined some extra functions are available which +rectify a few shortcomings in all previous standards. More concreten +the functions @code{fseeko} and @code{ftello} are available. Without +these functions the difference between the @w{ISO C} interface +(@code{fseek}, @code{ftell}) and the low-level POSIX interface +(@code{lseek}) would lead to problems. + +This macro was introduced as part of the Large File Support extension (LFS). +@end defvr + +@comment (NONE) +@comment X/Open +@defvar Macro _LARGEFILE64_SOURCE +If you define this macro an additional set of function gets available +which enables to use on @w{32 bit} systems to use files of sizes beyond +the usual limit of 2GB. This interface is not available if the system +does not support files that large. On systems where the natural file +size limit is greater than 2GB (i.e., on @w{64 bit} systems) the new +functions are identical to the replaced functions. + +The new functionality is made available by a new set of types and +functions which replace existing. The names of these new objects +contain @code{64} to indicate the intention, e.g., @code{off_t} +vs. @code{off64_t} and @code{fseeko} vs. @code{fseeko64}. + +This macro was introduced as part of the Large File Support extension +(LFS). It is a transition interface for the time @w{64 bit} offsets are +not generally used (see @code{_FILE_OFFSET_BITS}. +@end defvar + +@comment (NONE) +@comment X/Open +@defvar _FILE_OFFSET_BITS +This macro lets decide which file system interface shall be used, one +replacing the other. While @code{_LARGEFILE64_SOURCE} makes the @w{64 +bit} interface available as an additional interface +@code{_FILE_OFFSET_BITS} allows to use the @w{64 bit} interface to +replace the old interface. + +If @code{_FILE_OFFSET_BITS} is undefined or if it is defined to the +value @code{32} nothing changes. The @w{32 bit} interface is used and +types like @code{off_t} have a size of @w{32 bits} on @w{32 bit} +systems. + +If the macro is defined to the value @code{64} the large file interface +replaces the old interface. I.e., the functions are not made available +under different names as @code{_LARGEFILE64_SOURCE} does. Instead the +old function names now reference the new functions, e.g., a call to +@code{fseeko} now indeed calls @code{fseeko64}. + +This macro should only be selected if the system provides mechanisms for +handling large files. On @w{64 bit} systems this macro has no effect +since the @code{*64} functions are identical to the normal functions. + +This macro was introduced as part of the Large File Support extension +(LFS). +@end defvar + @comment (none) @comment GNU @defvr Macro _GNU_SOURCE If you define this macro, everything is included: @w{ISO C}, POSIX.1, -POSIX.2, BSD, SVID, X/Open, and GNU extensions. In the cases where +POSIX.2, BSD, SVID, X/Open, LFS, and GNU extensions. In the cases where POSIX.1 conflicts with BSD, the POSIX definitions take precedence. If you want to get the full effect of @code{_GNU_SOURCE} but make the diff --git a/manual/llio.texi b/manual/llio.texi index 4c10b72..23c5f76 100644 --- a/manual/llio.texi +++ b/manual/llio.texi @@ -32,6 +32,7 @@ directly.) @menu * Opening and Closing Files:: How to open and close file descriptors. +* Truncating Files:: Change the size of a file. * I/O Primitives:: Reading and writing data. * File Position Primitive:: Setting a descriptor's file position. @@ -41,6 +42,7 @@ directly.) descriptors and streams. * Waiting for I/O:: How to check for input or output on multiple file descriptors. +* Synchronizing I/O:: Making sure all I/O actions completed. * Control Operations:: Various other operations on file descriptors. * Duplicating Descriptors:: Fcntl commands for duplicating @@ -136,6 +138,14 @@ or @code{O_CREAT} is set and the file does not already exist. @c !!! umask +This function is a cancelation point in multi-threaded programs. This +is a problem if the thread allocates some resources (like memory, file +descriptors, semaphores or whatever) at the time @code{open} is +called. If the thread gets canceled these resources stay allocated +until the program ends. To avoid this calls to @code{open} should be +protected using cancelation handlers. +@c ref pthread_cleanup_push / pthread_cleanup_pop + The @code{open} function is the underlying primitive for the @code{fopen} and @code{freopen} functions, that create streams. @end deftypefun @@ -175,6 +185,14 @@ When all file descriptors associated with a pipe or FIFO have been closed, any unread data is discarded. @end itemize +This function is a cancelation point in multi-threaded programs. This +is a problem if the thread allocates some resources (like memory, file +descriptors, semaphores or whatever) at the time @code{close} is +called. If the thread gets canceled these resources stay allocated +until the program ends. To avoid this calls to @code{close} should be +protected using cancelation handlers. +@c ref pthread_cleanup_push / pthread_cleanup_pop + The normal return value from @code{close} is @code{0}; a value of @code{-1} is returned in case of failure. The following @code{errno} error conditions are defined for this function: @@ -206,6 +224,73 @@ of trying to close its underlying file descriptor with @code{close}. This flushes any buffered output and updates the stream object to indicate that it is closed. + +@node Truncating Files +@section Change the size of a file + +In some situations it is useful to explicitly determine the size of a +file. Since the 4.2BSD days there is a function to truncate a file to +at most a given number of bytes and POSIX defines one additional +function. The prototypes for these functions are in @file{unistd.h}. + +@comment unistd.h +@comment X/Open +@deftypefun int truncate (const char *@var{name}, size_t @var{length}) +The @code{truncation} function truncates the file named by @var{name} to +at most @var{length} bytes. I.e., if the file was larger before the +extra bytes are stripped of. If the file was small or equal to +@var{length} in size before nothing is done. The file must be writable +by the user to perform this operation. + +The return value is zero is everything wnet ok. Otherwise the return +value is @math{-1} and the global variable @var{errno} is set to: +@table @code +@item EACCES +The file is not accessible to the user. +@item EINVAL +The @var{length} value is illegal. +@item EISDIR +The object named by @var{name} is a directory. +@item ENOENT +The file named by @var{name} does not exist. +@item ENOTDIR +One part of the @var{name} is not a directory. +@end table + +This function was introduced in 4.2BSD but also was available in later +@w{System V} systems. It is not added to POSIX since the authors felt +it is only of marginally additional utility. See below. +@end deftypefun + +@comment unistd.h +@comment POSIX +@deftypefun int ftruncate (int @var{fd}, size_t @var{length}) +The @code{ftruncate} function is similar to the @code{truncate} +function. The main difference is that it takes a descriptor for an +opened file instead of a file name to identify the object. The file +must be opened for writing to successfully carry out the operation. + +The POSIX standard leaves it implementation defined what happens if the +specified new @var{length} of the file is bigger than the original size. +The @code{ftruncate} function might simply leave the file alone and do +nothing or it can increase the size to the desired size. In this later +case the extended area should be zero-filled. So using @code{ftruncate} +is no reliable way to increase the file size but if it is possible it is +probably the fastest way. The function also operates on POSIX shared +memory segments if these are implemented by the system. + +On success the function returns zero. Otherwise it returns @math{-1} +and set @var{errno} to one of these values: +@table @code +@item EBADF +@var{fd} is no valid file descriptor or is not opened for writing. +@item EINVAL +The object referred to by @var{fd} does not permit this operation. +@item EROFS +The file is on a read-only file system. +@end table +@end deftypefun + @node I/O Primitives @section Input and Output Primitives @@ -297,6 +382,14 @@ orphaned. @xref{Job Control}, for more information about job control, and @ref{Signal Handling}, for information about signals. @end table +This function is a cancelation point in multi-threaded programs. This +is a problem if the thread allocates some resources (like memory, file +descriptors, semaphores or whatever) at the time @code{read} is +called. If the thread gets canceled these resources stay allocated +until the program ends. To avoid this calls to @code{read} should be +protected using cancelation handlers. +@c ref pthread_cleanup_push / pthread_cleanup_pop + The @code{read} function is the underlying primitive for all of the functions that read from streams, such as @code{fgetc}. @end deftypefun @@ -419,6 +512,14 @@ macro @code{TEMP_FAILURE_RETRY}, as follows: nbytes = TEMP_FAILURE_RETRY (write (desc, buffer, count)); @end smallexample +This function is a cancelation point in multi-threaded programs. This +is a problem if the thread allocates some resources (like memory, file +descriptors, semaphores or whatever) at the time @code{write} is +called. If the thread gets canceled these resources stay allocated +until the program ends. To avoid this calls to @code{write} should be +protected using cancelation handlers. +@c ref pthread_cleanup_push / pthread_cleanup_pop + The @code{write} function is the underlying primitive for all of the functions that write to streams, such as @code{fputc}. @end deftypefun @@ -537,9 +638,18 @@ only for pipes and FIFOs, but in the GNU system, you always get @code{ESPIPE} if the object is not seekable.) @end table +This function is a cancelation point in multi-threaded programs. This +is a problem if the thread allocates some resources (like memory, file +descriptors, semaphores or whatever) at the time @code{lseek} is +called. If the thread gets canceled these resources stay allocated +until the program ends. To avoid this calls to @code{lseek} should be +protected using cancelation handlers. +@c ref pthread_cleanup_push / pthread_cleanup_pop + The @code{lseek} function is the underlying primitive for the -@code{fseek}, @code{ftell} and @code{rewind} functions, which operate on -streams instead of file descriptors. +@code{fseek}, @code{fseeko}, @code{ftell}, @code{ftello} and +@code{rewind} functions, which operate on streams instead of file +descriptors. @end deftypefun You can have multiple descriptors for the same file if you open the file @@ -1007,6 +1117,100 @@ There is another example showing the use of @code{select} to multiplex input from multiple sockets in @ref{Server Example}. +@node Synchronizing I/O +@section Synchronizing I/O operations + +@cindex synchronizing +In most modern operation systems the normal I/O operations are not +executed synchronously. I.e., even if a @code{write} system call +returns this does not mean the data is actually written to the media, +e.g., the disk. + +In situations where synchronization points are necessary the user can +use special functions which ensure that all operations finished before +they return. + +@comment unistd.h +@comment X/Open +@deftypefun int sync (void) +A call to this function will not return as long as there is data which +that is not written to the device. All dirty buffers in the kernel will +be written and so an overall consistent system can be achieved (if no +other process in parallel writes data). + +A prototype for @code{sync} can be found in @file{unistd.h}. + +The return value is zero to indicate no error. +@end deftypefun + +More often it is wanted that not all data in the system is committed. +Programs want to ensure that data written to a given file are all +committed and in this situation @code{sync} is overkill. + +@comment unistd.h +@comment POSIX +@deftypefun int fsync (int @var{fildes}) +The @code{fsync} can be used to make sure all data associated with the +open file @var{fildes} is written to the device associated with the +descriptor. The function call does not return unless all actions have +finished. + +A prototype for @code{fsync} can be found in @file{unistd.h}. + +This function is a cancelation point in multi-threaded programs. This +is a problem if the thread allocates some resources (like memory, file +descriptors, semaphores or whatever) at the time @code{fsync} is +called. If the thread gets canceled these resources stay allocated +until the program ends. To avoid this calls to @code{fsync} should be +protected using cancelation handlers. +@c ref pthread_cleanup_push / pthread_cleanup_pop + +The return value of the function is zero if no error occured. Otherwise +it is @math{-1} and the global variable @var{errno} is set to the +following values: +@table @code +@item EBADF +The descriptor @var{fildes} is not valid. + +@item EINVAL +No synchronization is possible since the system does not implement this. +@end table +@end deftypefun + +Sometimes it is not even necessary to write all data associated with a +file descriptor. E.g., in database files which do not change in size it +is enough to write all the file content data to the device. +Metainformation like the modification time etc. are not that important +and leaving such information uncommitted does not prevent a successful +recovering of the file in case of a problem. + +@comment unistd.h +@comment POSIX +@deftypefun int fdatasync (int @var{fildes}) +When a call to the @code{fdatasync} function returns it is maed sure +that all of the file data is written to the device. For all pending I/O +operations the parts guaranteeing data integrety finished. + +Not all systems implement the @code{fdatasync} operation. On systems +missing this functionality @code{fdatasync} is emulated by a call to +@code{fsync} since the performed actions are a superset of those +required by @code{fdatasyn}. + +The prototype for @code{fdatasync} is in @file{unistd.h}. + +The return value of the function is zero if no error occured. Otherwise +it is @math{-1} and the global variable @var{errno} is set to the +following values: +@table @code +@item EBADF +The descriptor @var{fildes} is not valid. + +@item EINVAL +No synchronization is possible since the system does not implement this. +@end table +@end deftypefun + + @node Control Operations @section Control Operations on Files @@ -1069,6 +1273,14 @@ Get process or process group ID to receive @code{SIGIO} signals. Set process or process group ID to receive @code{SIGIO} signals. @xref{Interrupt Input}. @end table + +This function is a cancelation point in multi-threaded programs. This +is a problem if the thread allocates some resources (like memory, file +descriptors, semaphores or whatever) at the time @code{fcntl} is +called. If the thread gets canceled these resources stay allocated +until the program ends. To avoid this calls to @code{fcntl} should be +protected using cancelation handlers. +@c ref pthread_cleanup_push / pthread_cleanup_pop @end deftypefun diff --git a/manual/maint.texi b/manual/maint.texi index 2818270..e6fc47f 100644 --- a/manual/maint.texi +++ b/manual/maint.texi @@ -50,28 +50,21 @@ Here are some options that you should specify (if appropriate) when you run @code{configure}: @table @samp -@item --with-gnu-ld -Use this option if you plan to use GNU @code{ld} to link programs with -the GNU C Library. (We strongly recommend that you do.) This option -enables use of features that exist only in GNU @code{ld}; so if you -configure for GNU @code{ld} you must use GNU @code{ld} @emph{every time} -you link with the GNU C Library, and when building it. - -@item --with-gnu-as -Use this option if you plan to use the GNU assembler, @code{gas}, when -building the GNU C Library. On some systems, the library may not build -properly if you do @emph{not} use @code{gas}. - -@item --with-gnu-binutils -This option implies both @w{@samp{--with-gnu-ld}} and @w{@samp{--with-gnu-as}}. -On systems where GNU tools are the system tools, there is no need to -specify this option. These include GNU, GNU/Linux, and free BSD systems. +@item --with-binutils=@var{directory} +Use the binutils (assembler and linker) in @file{@var{directory}}, not +the ones the C compiler would default to. You could use this option if +the default binutils on your system cannot deal with all the constructs +in the GNU C library. (@code{configure} will detect the problem and +suppress these constructs, so the library will still be usable, but +functionality may be lost---for example, you can not build a shared libc +with old binutils.) @c extra blank line makes it look better @item --without-fp @itemx --nfp -Use this option if your computer lacks hardware floating-point support. +Use this option if your computer lacks hardware floating-point support +and your operating system does not emulate an FPU. @item --prefix=@var{directory} Install machine-independent data files in subdirectories of @@ -1133,6 +1126,114 @@ extensions that they make and grant Carnegie Mellon the rights to redistribute these changes. @end quotation +@item +The code for the database library @file{libdb} comes from the 2.3 +release of Berkeley DB. That code is under the same copyright as 4.4 BSD +and also: + +@quotation +@display +Copyright @copyright{} 1990, 1993, 1994, 1995, 1996, 1997 +Sleepycat Software. All rights reserved. +@end display + +Redistribution and use in source and binary forms, with or without +modification, are permitted provided that the following conditions +are met: + +@enumerate +@item +Redistributions of source code must retain the above copyright +notice, this list of conditions and the following disclaimer. +@item +Redistributions in binary form must reproduce the above copyright +notice, this list of conditions and the following disclaimer in the +documentation and/or other materials provided with the distribution. +@item +Redistributions in any form must be accompanied by information on +how to obtain complete source code for the DB software and any +accompanying software that uses the DB software. The source code +must either be included in the distribution or be available for no +more than the cost of distribution plus a nominal fee, and must be +freely redistributable under reasonable conditions. For an +executable file, complete source code means the source code for all +modules it contains. It does not mean source code for modules or +files that typically accompany the operating system on which the +executable file runs, e.g., standard library modules or system +header files. +@end enumerate + +@sc{this software is provided by sleepycat software ``as is'' and +any express or implied warranties, including, but not limited to, the +implied warranties of merchantability and fitness for a particular purpose +are disclaimed. in no event shall sleepycat software be liable +for any direct, indirect, incidental, special, exemplary, or consequential +damages (including, but not limited to, procurement of substitute goods +or services; loss of use, data, or profits; or business interruption) +however caused and on any theory of liability, whether in contract, strict +liability, or tort (including negligence or otherwise) arising in any way +out of the use of this software, even if advised of the possibility of +such damage.} + +@display +Portions copyright @copyright{} 1995, 1996 +The President and Fellows of Harvard University. +All rights reserved. +@end display + +Redistribution and use in source and binary forms, with or without +modification, are permitted provided that the following conditions +are met: +@enumerate +@item +Redistributions of source code must retain the above copyright +notice, this list of conditions and the following disclaimer. +@item +Redistributions in binary form must reproduce the above copyright +notice, this list of conditions and the following disclaimer in the +documentation and/or other materials provided with the distribution. +@item +All advertising materials mentioning features or use of this software +must display the following acknowledgement: +@quotation + This product includes software developed by Harvard University + and its contributors. +@end quotation +@item +Neither the name of the University nor the names of its contributors +may be used to endorse or promote products derived from this software +without specific prior written permission. +@end enumerate + +@sc{this software is provided by harvard and its contributors ``as is'' and +any express or implied warranties, including, but not limited to, the +implied warranties of merchantability and fitness for a particular purpose +are disclaimed. in no event shall harvard or its contributors be liable +for any direct, indirect, incidental, special, exemplary, or consequential +damages (including, but not limited to, procurement of substitute goods +or services; loss of use, data, or profits; or business interruption) +however caused and on any theory of liability, whether in contract, strict +liability, or tort (including negligence or otherwise) arising in any way +out of the use of this software, even if advised of the possibility of +such damage.} + +@noindent +For a license to use, redistribute or sell DB software under conditions +other than those described above, or to purchase support for this +software, please contact Sleepycat Software at + +@display + Sleepycat Software + 394 E. Riding Dr. + Carlisle, MA 01741 + USA + +1-508-287-4781 +@end display + +or @email{db@@sleepycat.com}. + +@end quotation + @end itemize @c @bye diff --git a/manual/math.texi b/manual/math.texi index 15a2075..fe9394b 100644 --- a/manual/math.texi +++ b/manual/math.texi @@ -1259,6 +1259,31 @@ $$\log(z) = \log(|z|) + i \arg(z)$$ @end iftex @end deftypefun + +@comment complex.h +@comment GNU +@deftypefun {complex double} clog10 (complex double @var{z}) +@deftypefunx {complex float} clog10f (complex float @var{z}) +@deftypefunx {complex long double} clog10l (complex long double @var{z}) +These functions return the base 10 logarithm of the complex value +@var{z}. Unlike the real value version @code{log} and its variants, +@code{clog} has no limit for the range of its argument @var{z}. + +@noindent +Mathematically this corresponds to the value + +@ifinfo +@math{log (z) = log10 (cabs (z)) + I * carg (z)} +@end ifinfo +@iftex +@tex +$$\log_{10}(z) = \log_{10}(|z|) + i \arg(z)$$ +@end tex +@end iftex + +This function is a GNU extension. +@end deftypefun + @comment complex.h @comment ISO @deftypefun {complex double} csqrt (complex double @var{z}) @@ -1274,7 +1299,7 @@ the value of the argument. @deftypefun {complex double} cpow (complex double @var{base}, complex double @var{power}) @deftypefunx {complex float} cpowf (complex float @var{base}, complex float @var{power}) @deftypefunx {complex long double} cpowl (complex long double @var{base}, complex long double @var{power}) -These functions return the complex value @var{BASE} raised to the power of +These functions return the complex value @var{base} raised to the power of @var{power}. This is computed as @ifinfo diff --git a/manual/process.texi b/manual/process.texi index d382df5..4323015 100644 --- a/manual/process.texi +++ b/manual/process.texi @@ -62,6 +62,14 @@ possible to create the shell process, and otherwise is the status of the shell process. @xref{Process Completion}, for details on how this status code can be interpreted. +This function is a cancelation point in multi-threaded programs. This +is a problem if the thread allocates some resources (like memory, file +descriptors, semaphores or whatever) at the time @code{system} is +called. If the thread gets canceled these resources stay allocated +until the program ends. To avoid this calls to @code{system} should be +protected using cancelation handlers. +@c ref pthread_cleanup_push / pthread_cleanup_pop + @pindex stdlib.h The @code{system} function is declared in the header file @file{stdlib.h}. @@ -477,6 +485,14 @@ processes as well as processes that have terminated. The status information from the child process is stored in the object that @var{status-ptr} points to, unless @var{status-ptr} is a null pointer. +This function is a cancelation point in multi-threaded programs. This +is a problem if the thread allocates some resources (like memory, file +descriptors, semaphores or whatever) at the time @code{waitpid} is +called. If the thread gets canceled these resources stay allocated +until the program ends. To avoid this calls to @code{waitpid} should be +protected using cancelation handlers. +@c ref pthread_cleanup_push / pthread_cleanup_pop + The return value is normally the process ID of the child process whose status is reported. If the @code{WNOHANG} option was specified and no child process is waiting to be noticed, the value is zero. A value of @@ -547,6 +563,14 @@ is exactly equivalent to: @smallexample waitpid (-1, &status, 0) @end smallexample + +This function is a cancelation point in multi-threaded programs. This +is a problem if the thread allocates some resources (like memory, file +descriptors, semaphores or whatever) at the time @code{wait} is +called. If the thread gets canceled these resources stay allocated +until the program ends. To avoid this calls to @code{wait} should be +protected using cancelation handlers. +@c ref pthread_cleanup_push / pthread_cleanup_pop @end deftypefun @comment sys/wait.h diff --git a/manual/signal.texi b/manual/signal.texi index bc69019..7948229 100644 --- a/manual/signal.texi +++ b/manual/signal.texi @@ -2927,6 +2927,14 @@ The function was interrupted by delivery of a signal. If the signal causes program termination, @code{pause} doesn't return (obviously). +This function is a cancelation point in multi-threaded programs. This +is a problem if the thread allocates some resources (like memory, file +descriptors, semaphores or whatever) at the time @code{pause} is +called. If the thread gets canceled these resources stay allocated +until the program ends. To avoid this calls to @code{pause} should be +protected using cancelation handlers. +@c ref pthread_cleanup_push / pthread_cleanup_pop + The @code{pause} function is declared in @file{unistd.h}. @end deftypefun diff --git a/manual/stdio.texi b/manual/stdio.texi index 4c90b25..fbf218e 100644 --- a/manual/stdio.texi +++ b/manual/stdio.texi @@ -895,7 +895,7 @@ The conversion specifications in a @code{printf} template string have the general form: @example -% @var{flags} @var{width} @r{[} . @var{precision} @r{]} @var{type} @var{conversion} +% @r{[} @var{param-no} @r{$]} @var{flags} @var{width} @r{[} . @var{precision} @r{]} @var{type} @var{conversion} @end example For example, in the conversion specifier @samp{%-10.8ld}, the @samp{-} @@ -910,6 +910,33 @@ initial @samp{%} character followed in sequence by: @itemize @bullet @item +An optional specification of the parameter used for this format. +Normally the parameters to the @code{printf} function a assigned to the +formats in the order of appearence in the format string. But in some +situations (such as message translation) this is not desirable and this +extension allows to specify and explicit parameter to be used. + +The @var{param-no} part of the format must be an integer in the range of +1 to the maximum number of arguments present to the function call. Some +implementations limit this number to a certainly upper bound. The exact +limit can be retrieved by the following constant. + +@defvr Macro NL_ARGMAX +The value of @code{ARGMAX} is the maximum value allowed for the +specification of an positional parameter in a @code{printf} call. The +actual value in effect at runtime can be retrieved by using +@code{sysconf} using the @code{_SC_NL_ARGMAX} parameter @pxref{Sysconf +Definition}. + +Some system have a quite low limit such as @math{9} for @w{System V} +systems. The GNU C library has no real limit. +@end defvr + +If any of the formats has a specification for the parameter position all +of them in the format string shall have one. Otherwise the behaviour is +undefined. + +@item Zero or more @dfn{flag characters} that modify the normal behavior of the conversion specification. @cindex flag character (@code{printf}) diff --git a/manual/terminal.texi b/manual/terminal.texi index fcd30a1..7e0f985 100644 --- a/manual/terminal.texi +++ b/manual/terminal.texi @@ -1638,6 +1638,14 @@ The @var{filedes} is not associated with a terminal device. The @code{tcdrain} function waits until all queued output to the terminal @var{filedes} has been transmitted. +This function is a cancelation point in multi-threaded programs. This +is a problem if the thread allocates some resources (like memory, file +descriptors, semaphores or whatever) at the time @code{tcdrain} is +called. If the thread gets canceled these resources stay allocated +until the program ends. To avoid this calls to @code{tcdrain} should be +protected using cancelation handlers. +@c ref pthread_cleanup_push / pthread_cleanup_pop + The return value is normally zero. In the event of an error, a value of @code{-1} is returned. The following @code{errno} error conditions are defined for this function: diff --git a/manual/time.texi b/manual/time.texi index 7a5cd65..c2b2378 100644 --- a/manual/time.texi +++ b/manual/time.texi @@ -1455,6 +1455,42 @@ On the GNU system, it is safe to use @code{sleep} and @code{SIGALRM} in the same program, because @code{sleep} does not work by means of @code{SIGALRM}. +@comment time.h +@comment POSIX.1 +@deftypefun int nanosleep (const struct timespec *@var{requested_time}, struct timespec *@var{remaining}) +If the resolution of seconds is not enough the @code{nanosleep} function +can be used. As the name suggests the sleeping period can be specified +in nanoseconds. The actual period of waiting time might be longer since +the requested time in the @var{requested_time} parameter is rounded up +to the next integer multiple of the actual resolution of the system. + +If the function returns because the time has elapsed the return value is +zero. If the function return @math{-1} the global variable @var{errno} +is set to the following values: + +@table @code +@item EINTR +The call was interrupted because a signal was delivered to the thread. +If the @var{remaining} parameter is not the null pointer the structure +pointed to by @var{remaining} is updated to contain the remaining time. + +@item EINVAL +The nanosecond value in the @var{requested_time} parameter contains an +illegal value. Either the value is negative or greater than or equal to +1000 million. +@end table + +This function is a cancelation point in multi-threaded programs. This +is a problem if the thread allocates some resources (like memory, file +descriptors, semaphores or whatever) at the time @code{nanosleep} is +called. If the thread gets canceled these resources stay allocated +until the program ends. To avoid this calls to @code{nanosleep} should +be protected using cancelation handlers. +@c ref pthread_cleanup_push / pthread_cleanup_pop + +The @code{nanosleep} function is declared in @file{time.h}. +@end deftypefun + @node Resource Usage @section Resource Usage |