Man Linux: Main Page and Category List

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 .