Provided by: manpages-posix-dev_2.16-1_all bug

NAME

       sysconf - get configurable system variables

SYNOPSIS

       #include <unistd.h>

       long sysconf(int name);

DESCRIPTION

       The  sysconf()  function  provides  a  method  for  the  application  to determine the current value of a
       configurable system limit or option ( variable). The implementation shall support all  of  the  variables
       listed in the following table and may support others.

       The  name  argument  represents the system variable to be queried.  The following table lists the minimal
       set of system variables from <limits.h> or <unistd.h> that can be returned by sysconf(), and the symbolic
       constants defined in <unistd.h> that are the corresponding values used for name.
                          Variable                          Value of Name
                          {AIO_LISTIO_MAX}                  _SC_AIO_LISTIO_MAX
                          {AIO_MAX}                         _SC_AIO_MAX
                          {AIO_PRIO_DELTA_MAX}              _SC_AIO_PRIO_DELTA_MAX
                          {ARG_MAX}                         _SC_ARG_MAX
                          {ATEXIT_MAX}                      _SC_ATEXIT_MAX
                          {BC_BASE_MAX}                     _SC_BC_BASE_MAX
                          {BC_DIM_MAX}                      _SC_BC_DIM_MAX
                          {BC_SCALE_MAX}                    _SC_BC_SCALE_MAX
                          {BC_STRING_MAX}                   _SC_BC_STRING_MAX
                          {CHILD_MAX}                       _SC_CHILD_MAX
                          Clock ticks/second                _SC_CLK_TCK
                          {COLL_WEIGHTS_MAX}                _SC_COLL_WEIGHTS_MAX
                          {DELAYTIMER_MAX}                  _SC_DELAYTIMER_MAX
                          {EXPR_NEST_MAX}                   _SC_EXPR_NEST_MAX
                          {HOST_NAME_MAX}                   _SC_HOST_NAME_MAX
                          {IOV_MAX}                         _SC_IOV_MAX
                          {LINE_MAX}                        _SC_LINE_MAX
                          {LOGIN_NAME_MAX}                  _SC_LOGIN_NAME_MAX
                          {NGROUPS_MAX}                     _SC_NGROUPS_MAX
                          Maximum size of getgrgid_r() and  _SC_GETGR_R_SIZE_MAX
                          getgrnam_r() data buffers
                          Maximum size of getpwuid_r() and  _SC_GETPW_R_SIZE_MAX
                          getpwnam_r() data buffers
                          {MQ_OPEN_MAX}                     _SC_MQ_OPEN_MAX
                          {MQ_PRIO_MAX}                     _SC_MQ_PRIO_MAX
                          {OPEN_MAX}                        _SC_OPEN_MAX
                          _POSIX_ADVISORY_INFO              _SC_ADVISORY_INFO
                          _POSIX_BARRIERS                   _SC_BARRIERS
                          _POSIX_ASYNCHRONOUS_IO            _SC_ASYNCHRONOUS_IO
                          _POSIX_CLOCK_SELECTION            _SC_CLOCK_SELECTION
                          _POSIX_CPUTIME                    _SC_CPUTIME
                          _POSIX_FILE_LOCKING               _SC_FILE_LOCKING
                          _POSIX_FSYNC                      _SC_FSYNC
                          _POSIX_IPV6                       _SC_IPV6
                          _POSIX_JOB_CONTROL                _SC_JOB_CONTROL
                          _POSIX_MAPPED_FILES               _SC_MAPPED_FILES
                          _POSIX_MEMLOCK                    _SC_MEMLOCK
                          _POSIX_MEMLOCK_RANGE              _SC_MEMLOCK_RANGE
                          _POSIX_MEMORY_PROTECTION          _SC_MEMORY_PROTECTION
                          _POSIX_MESSAGE_PASSING            _SC_MESSAGE_PASSING
                          _POSIX_MONOTONIC_CLOCK            _SC_MONOTONIC_CLOCK
                          _POSIX_MULTI_PROCESS              _SC_MULTI_PROCESS
                          _POSIX_PRIORITIZED_IO             _SC_PRIORITIZED_IO
                          _POSIX_PRIORITY_SCHEDULING        _SC_PRIORITY_SCHEDULING
                          _POSIX_RAW_SOCKETS                _SC_RAW_SOCKETS
                          _POSIX_READER_WRITER_LOCKS        _SC_READER_WRITER_LOCKS
                          _POSIX_REALTIME_SIGNALS           _SC_REALTIME_SIGNALS
                          _POSIX_REGEXP                     _SC_REGEXP
                          _POSIX_SAVED_IDS                  _SC_SAVED_IDS
                          _POSIX_SEMAPHORES                 _SC_SEMAPHORES
                          _POSIX_SHARED_MEMORY_OBJECTS      _SC_SHARED_MEMORY_OBJECTS
                          _POSIX_SHELL                      _SC_SHELL
                          _POSIX_SPAWN                      _SC_SPAWN
                          _POSIX_SPIN_LOCKS                 _SC_SPIN_LOCKS
                          _POSIX_SPORADIC_SERVER            _SC_SPORADIC_SERVER
                          _POSIX_SYMLOOP_MAX                _SC_SYMLOOP_MAX
                          _POSIX_SYNCHRONIZED_IO            _SC_SYNCHRONIZED_IO
                          _POSIX_THREAD_ATTR_STACKADDR      _SC_THREAD_ATTR_STACKADDR
                          _POSIX_THREAD_ATTR_STACKSIZE      _SC_THREAD_ATTR_STACKSIZE
                          _POSIX_THREAD_CPUTIME             _SC_THREAD_CPUTIME
                          _POSIX_THREAD_PRIO_INHERIT        _SC_THREAD_PRIO_INHERIT
                          _POSIX_THREAD_PRIO_PROTECT        _SC_THREAD_PRIO_PROTECT
                          _POSIX_THREAD_PRIORITY_SCHEDULING _SC_THREAD_PRIORITY_SCHEDULING
                          _POSIX_THREAD_PROCESS_SHARED      _SC_THREAD_PROCESS_SHARED
                          _POSIX_THREAD_SAFE_FUNCTIONS      _SC_THREAD_SAFE_FUNCTIONS
                          _POSIX_THREAD_SPORADIC_SERVER     _SC_THREAD_SPORADIC_SERVER
                          _POSIX_THREADS                    _SC_THREADS
                          _POSIX_TIMEOUTS                   _SC_TIMEOUTS
                          _POSIX_TIMERS                     _SC_TIMERS
                          _POSIX_TRACE                      _SC_TRACE
                          _POSIX_TRACE_EVENT_FILTER         _SC_TRACE_EVENT_FILTER
                          _POSIX_TRACE_INHERIT              _SC_TRACE_INHERIT
                          _POSIX_TRACE_LOG                  _SC_TRACE_LOG
                          _POSIX_TYPED_MEMORY_OBJECTS       _SC_TYPED_MEMORY_OBJECTS
                          _POSIX_VERSION                    _SC_VERSION
                          _POSIX_V6_ILP32_OFF32             _SC_V6_ILP32_OFF32
                          _POSIX_V6_ILP32_OFFBIG            _SC_V6_ILP32_OFFBIG
                          _POSIX_V6_LP64_OFF64              _SC_V6_LP64_OFF64
                          _POSIX_V6_LPBIG_OFFBIG            _SC_V6_LPBIG_OFFBIG
                          _POSIX2_C_BIND                    _SC_2_C_BIND
                          _POSIX2_C_DEV                     _SC_2_C_DEV
                          _POSIX2_C_VERSION                 _SC_2_C_VERSION
                          _POSIX2_CHAR_TERM                 _SC_2_CHAR_TERM
                          _POSIX2_FORT_DEV                  _SC_2_FORT_DEV
                          _POSIX2_FORT_RUN                  _SC_2_FORT_RUN
                          _POSIX2_LOCALEDEF                 _SC_2_LOCALEDEF
                          _POSIX2_PBS                       _SC_2_PBS
                          _POSIX2_PBS_ACCOUNTING            _SC_2_PBS_ACCOUNTING
                          _POSIX2_PBS_CHECKPOINT            _SC_2_PBS_CHECKPOINT
                          _POSIX2_PBS_LOCATE                _SC_2_PBS_LOCATE
                          _POSIX2_PBS_MESSAGE               _SC_2_PBS_MESSAGE
                          _POSIX2_PBS_TRACK                 _SC_2_PBS_TRACK
                          _POSIX2_SW_DEV                    _SC_2_SW_DEV
                          _POSIX2_UPE                       _SC_2_UPE
                          _POSIX2_VERSION                   _SC_2_VERSION
                          _REGEX_VERSION                    _SC_REGEX_VERSION
                          {PAGE_SIZE}                       _SC_PAGE_SIZE
                          {PAGESIZE}                        _SC_PAGESIZE
                          {PTHREAD_DESTRUCTOR_ITERATIONS}   _SC_THREAD_DESTRUCTOR_ITERATIONS
                          {PTHREAD_KEYS_MAX}                _SC_THREAD_KEYS_MAX
                          {PTHREAD_STACK_MIN}               _SC_THREAD_STACK_MIN
                          {PTHREAD_THREADS_MAX}             _SC_THREAD_THREADS_MAX
                          {RE_DUP_MAX}                      _SC_RE_DUP_MAX
                          {RTSIG_MAX}                       _SC_RTSIG_MAX
                          {SEM_NSEMS_MAX}                   _SC_SEM_NSEMS_MAX
                          {SEM_VALUE_MAX}                   _SC_SEM_VALUE_MAX
                          {SIGQUEUE_MAX}                    _SC_SIGQUEUE_MAX
                          {STREAM_MAX}                      _SC_STREAM_MAX
                          {SYMLOOP_MAX}                     _SC_SYMLOOP_MAX
                          {TIMER_MAX}                       _SC_TIMER_MAX
                          {TTY_NAME_MAX}                    _SC_TTY_NAME_MAX
                          {TZNAME_MAX}                      _SC_TZNAME_MAX
                          _XBS5_ILP32_OFF32 (LEGACY)        _SC_XBS5_ILP32_OFF32 (LEGACY)
                          _XBS5_ILP32_OFFBIG (LEGACY)       _SC_XBS5_ILP32_OFFBIG (LEGACY)
                          _XBS5_LP64_OFF64 (LEGACY)         _SC_XBS5_LP64_OFF64 (LEGACY)
                          _XBS5_LPBIG_OFFBIG (LEGACY)       _SC_XBS5_LPBIG_OFFBIG (LEGACY)
                          _XOPEN_CRYPT                      _SC_XOPEN_CRYPT
                          _XOPEN_ENH_I18N                   _SC_XOPEN_ENH_I18N
                          _XOPEN_LEGACY                     _SC_XOPEN_LEGACY
                          _XOPEN_REALTIME                   _SC_XOPEN_REALTIME
                          _XOPEN_REALTIME_THREADS           _SC_XOPEN_REALTIME_THREADS
                          _XOPEN_SHM                        _SC_XOPEN_SHM
                          _XOPEN_STREAMS                    _SC_XOPEN_STREAMS
                          _XOPEN_UNIX                       _SC_XOPEN_UNIX
                          _XOPEN_VERSION                    _SC_XOPEN_VERSION
                          _XOPEN_XCU_VERSION                _SC_XOPEN_XCU_VERSION

RETURN VALUE

       If name is an invalid value, sysconf() shall return -1 and set  errno  to  indicate  the  error.  If  the
       variable  corresponding  to  name  has  no limit, sysconf() shall return -1 without changing the value of
       errno. Note that indefinite limits do not imply infinite limits; see <limits.h>.

       Otherwise, sysconf() shall return the current variable value on the system. The value returned shall  not
       be  more  restrictive than the corresponding value described to the application when it was compiled with
       the implementation's <limits.h> or <unistd.h>. The value shall not change  during  the  lifetime  of  the
       calling  process,   except that sysconf(_SC_OPEN_MAX) may return different values before and after a call
       to setrlimit() which changes the RLIMIT_NOFILE soft limit.

ERRORS

       The sysconf() function shall fail if:

       EINVAL The value of the name argument is invalid.

       The following sections are informative.

EXAMPLES

       None.

APPLICATION USAGE

       As -1 is a permissible return value in a successful situation, an application wishing to check for  error
       situations  should  set  errno to 0, then call sysconf(), and, if it returns -1, check to see if errno is
       non-zero.

       If the value of sysconf(_SC_2_VERSION) is  not  equal  to  the  value  of  the  _POSIX2_VERSION  symbolic
       constant,  the utilities available via system() or popen() might not behave as described in the Shell and
       Utilities volume of IEEE Std 1003.1-2001.  This would mean that the application  is  not  running  in  an
       environment  that  conforms  to the Shell and Utilities volume of IEEE Std 1003.1-2001. Some applications
       might be able to deal with this, others might not. However, the  functions  defined  in  this  volume  of
       IEEE Std 1003.1-2001  continue  to  operate as specified, even if sysconf(_SC_2_VERSION) reports that the
       utilities no longer perform as specified.

RATIONALE

       This functionality was added in response to requirements of application developers and of system  vendors
       who  deal  with  many  international  system  configurations.  It  is  closely  related to pathconf() and
       fpathconf().

       Although a conforming application can run on all systems by  never  demanding  more  resources  than  the
       minimum  values published in this volume of IEEE Std 1003.1-2001, it is useful for that application to be
       able to use the actual value for the quantity of a resource available on any given system.  To  do  this,
       the application makes use of the value of a symbolic constant in <limits.h> or <unistd.h>.

       However, once compiled, the application must still be able to cope if the amount of resource available is
       increased. To that end, an application may need a means of determining the quantity of a resource, or the
       presence of an option, at execution time.

       Two examples are offered:

        1. Applications may wish to act differently on systems with or without job control. Applications vendors
           who wish to distribute only a single binary package to all instances of a computer architecture would
           be  forced to assume job control is never available if it were to rely solely on the <unistd.h> value
           published in this volume of IEEE Std 1003.1-2001.

        2. International applications vendors occasionally require knowledge of the number of  clock  ticks  per
           second.  Without  these  facilities,  they  would be required to either distribute their applications
           partially in source form or to have 50 Hz and 60 Hz versions for the various countries in which  they
           operate.

       It  is the knowledge that many applications are actually distributed widely in executable form that leads
       to this facility. If limited to the most restrictive values in the headers, such applications would  have
       to  be  prepared to accept the most limited environments offered by the smallest microcomputers. Although
       this is entirely portable, there was a consensus that they should  be  able  to  take  advantage  of  the
       facilities  offered  by  large  systems,  without  the  restrictions  associated  with  source and object
       distributions.

       During the discussions of this feature, it was pointed out that it  is  almost  always  possible  for  an
       application  to  discern  what  a  value  might  be  at runtime by suitably testing the various functions
       themselves. And, in any event, it could always be written to adequately deal with error returns from  the
       various  functions.  In  the end, it was felt that this imposed an unreasonable level of complication and
       sophistication on the application writer.

       This runtime facility is not meant to provide  ever-changing  values  that  applications  have  to  check
       multiple  times.  The values are seen as changing no more frequently than once per system initialization,
       such as by a system administrator or operator with an automatic configuration  program.  This  volume  of
       IEEE Std 1003.1-2001 specifies that they shall not change within the lifetime of the process.

       Some values apply to the system overall and others vary at the file system or directory level. The latter
       are described in pathconf() .

       Note  that  all  values  returned must be expressible as integers. String values were considered, but the
       additional flexibility of this approach was rejected due to its added complexity  of  implementation  and
       use.

       Some  values,  such  as  {PATH_MAX},  are sometimes so large that they must not be used to, say, allocate
       arrays. The sysconf() function returns a negative value to show that this symbolic constant is  not  even
       defined in this case.

       Similar  to  pathconf(),  this  permits  the  implementation  not  to  have a limit. When one resource is
       infinite, returning an error indicating that some other resource limit has  been  reached  is  conforming
       behavior.

FUTURE DIRECTIONS

       None.

SEE ALSO

       confstr() , pathconf() , the Base Definitions volume of IEEE Std 1003.1-2001, <limits.h>, <unistd.h>, the
       Shell and Utilities volume of IEEE Std 1003.1-2001, getconf

COPYRIGHT

       Portions of this text are reprinted and reproduced in electronic form from IEEE Std 1003.1, 2003 Edition,
       Standard  for  Information Technology -- Portable Operating System Interface (POSIX), The Open Group Base
       Specifications Issue 6, Copyright (C) 2001-2003 by the Institute of Electrical and Electronics Engineers,
       Inc and The Open Group. In the event of any discrepancy between this version and the  original  IEEE  and
       The  Open  Group  Standard,  the  original  IEEE and The Open Group Standard is the referee document. The
       original Standard can be obtained online at http://www.opengroup.org/unix/online.html .

IEEE/The Open Group                                   2003                                            SYSCONF(P)