sysctl(2)


NAME

   sysctl - read/write system parameters

SYNOPSIS

   #include <unistd.h>
   #include <linux/sysctl.h>

   int _sysctl(struct __sysctl_args *args);

   Note: There is no glibc wrapper for this system call; see NOTES.

DESCRIPTION

   Do not use this system call!  See NOTES.

   The _sysctl() call reads and/or writes kernel parameters.  For example,
   the hostname, or the maximum number of open files.   The  argument  has
   the form

       struct __sysctl_args {
           int    *name;    /* integer vector describing variable */
           int     nlen;    /* length of this vector */
           void   *oldval;  /* 0 or address where to store old value */
           size_t *oldlenp; /* available room for old value,
                               overwritten by actual size of old value */
           void   *newval;  /* 0 or address of new value */
           size_t  newlen;  /* size of new value */
       };

   This  call  does  a  search  in a tree structure, possibly resembling a
   directory tree under /proc/sys, and if  the  requested  item  is  found
   calls some appropriate routine to read or modify the value.

RETURN VALUE

   Upon successful completion, _sysctl() returns 0.  Otherwise, a value of
   -1 is returned and errno is set to indicate the error.

ERRORS

   EACCES, EPERM
          No search permission for one of the  encountered  "directories",
          or  no  read  permission  where  oldval was nonzero, or no write
          permission where newval was nonzero.

   EFAULT The invocation asked for the previous value  by  setting  oldval
          non-NULL, but allowed zero room in oldlenp.

   ENOTDIR
          name was not found.

CONFORMING TO

   This  call  is  Linux-specific,  and  should  not  be  used in programs
   intended to be portable.  A sysctl() call has  been  present  in  Linux
   since  version  1.3.57.   It  originated in 4.4BSD.  Only Linux has the
   /proc/sys mirror, and the object naming schemes  differ  between  Linux
   and 4.4BSD, but the declaration of the sysctl() function is the same in
   both.

NOTES

   Glibc does not provide a wrapper for this system call;  call  it  using
   syscall(2).   Or  rather...  don't call it: use of this system call has
   long been discouraged, and it is  so  unloved  that  it  is  likely  to
   disappear in a future kernel version.  Since Linux 2.6.24, uses of this
   system call result in warnings in the kernel log.  Remove it from  your
   programs now; use the /proc/sys interface instead.

   This  system  call  is available only if the kernel was configured with
   the CONFIG_SYSCTL_SYSCALL option.

BUGS

   The object names vary between kernel versions, making this system  call
   worthless for applications.

   Not all available objects are properly documented.

   It  is  not  yet  possible  to  change  operating  system by writing to
   /proc/sys/kernel/ostype.

EXAMPLE

   #define _GNU_SOURCE
   #include <unistd.h>
   #include <sys/syscall.h>
   #include <string.h>
   #include <stdio.h>
   #include <stdlib.h>
   #include <linux/sysctl.h>

   int _sysctl(struct __sysctl_args *args );

   #define OSNAMESZ 100

   int
   main(void)
   {
       struct __sysctl_args args;
       char osname[OSNAMESZ];
       size_t osnamelth;
       int name[] = { CTL_KERN, KERN_OSTYPE };

       memset(&args, 0, sizeof(struct __sysctl_args));
       args.name = name;
       args.nlen = sizeof(name)/sizeof(name[0]);
       args.oldval = osname;
       args.oldlenp = &osnamelth;

       osnamelth = sizeof(osname);

       if (syscall(SYS__sysctl, &args) == -1) {
           perror("_sysctl");
           exit(EXIT_FAILURE);
       }
       printf("This machine is running %*s\n", osnamelth, osname);
       exit(EXIT_SUCCESS);
   }

SEE ALSO

   proc(5)

COLOPHON

   This page is part of release 4.09 of the Linux  man-pages  project.   A
   description  of  the project, information about reporting bugs, and the
   latest    version    of    this    page,    can     be     found     at
   https://www.kernel.org/doc/man-pages/.


More Linux Commands

manpages/svipc.7.html
svipc(7) - System V interprocess communication mechanisms...
This manual page refers to the Linux implementation of the System V interprocess communication (IPC) mechanisms: message queues, semaphore sets, and shared memo

manpages/ClientWhitePointOfCCC.3.html
ClientWhitePointOfCCC(3) - Color Conversion Context macros
The DisplayOfCCC macro returns the display associated with the specified CCC. The VisualOfCCC macro returns the visual associated with the specified CCC. The Sc

manpages/DefaultVisual.3.html
DefaultVisual(3) - Display macros and functions (Man Page)
The AllPlanes macro returns a value with all bits set to 1 suitable for use in a plane argument to a procedure. The BlackPixel macro returns the black pixel val

manpages/xcursorgen.1.html
xcursorgen(1) - create an X cursor file from a collection of
Xcursorgen reads the config-file to find the list of cursor images along with their hotspot and nominal size information. Xcursorgen converts all of the images

manpages/XIQueryPointer.3.html
XIQueryPointer(3) - get device pointer coordinates (ManPage)
The XIQueryPointer function returns the root window the devices pointer is logically on and the pointer coordinates relative to the root windows origin. If XIQu

manpages/wcursyncup.3ncurses.html
wcursyncup(3ncurses) - create curses windows (Man Page).....
Calling newwin creates and returns a pointer to a new window with the given number of lines and columns. The upper left-hand corner of the window is at line beg

manpages/lattice.1.html
lattice(1) - linked rings. (Commands - Linux manual page)...
From Terry Walsh (http://reallyslick.com): Fly through an endless world of linked rings. You can choose from several different textures for the rings and alter

manpages/gnutls_x509_crl_export.3.html
gnutls_x509_crl_export(3) - API function - Linux man page...
This function will export the revocation list to DER or PEM format. If the buffer provided is not long enough to hold the output, then GNUTLS_E_SHORT_MEMORY_BUF

manpages/intro.8.html
intro.8 - intro(8) - Introduction to administration and privileged com
Section 8 of the manual describes commands which either can be or are used only by the superuser, like system-administration commands, daemons, and hardware-rel

manpages/busctl.1.html
busctl(1) Introspect the bus (Commands - Linux man page)....
busctl may be used to introspect and monitor the D-Bus bus. OPTIONS The following options are understood: --address=ADDRESS Connect to the bus specified by ADDR

manpages/gnutls_certificate_set_retrieve_function2.3.html
gnutls_certificate_set_retrieve_function2.3.................
This function sets a callback to be called in order to retrieve the certificate to be used in the handshake. The callbacks function prototype is: int (*callback

manpages/gvfs-info.1.html
gvfs-info(1) Show information about files - Linux man page
gvfs-info shows information about the given locations. gvfs-info is similar to the traditional ls utility, but using gvfs locations instead of local files: for





We can't live, work or learn in freedom unless the software we use is free.