semctl — semaphore control operations
#include <sys/types.h> #include <sys/ipc.h> #include <sys/sem.h>
| int
            semctl( | int semid, | 
| int semnum, | |
| int cmd, | |
| ... ); | 
semctl() performs the
      control operation specified by cmd on the semaphore set
      identified by semid,
      or on the semnum-th
      semaphore of that set. (The semaphores in a set are numbered
      starting at 0.)
This function has three or four arguments, depending on
      cmd. When there are
      four, the fourth has the type union semun. The calling program must define this
      union as follows:
union semun { int val;struct semid_ds * buf;unsigned short * array;struct seminfo * __buf;
(Linux-specific) */}; 
The semid_ds
      data structure is defined in <sys/sem.h>
      as follows:
struct semid_ds { struct ipc_perm sem_perm;time_t sem_otime;time_t sem_ctime;unsigned short sem_nsems;}; 
The ipc_perm
      structure is defined in <sys/ipc.h>
      as follows (the highlighted fields are settable using
      IPC_SET):
struct ipc_perm { key_t __key;uid_t uid;gid_t gid;uid_t cuid;gid_t cgid;unsigned short mode;unsigned short __seq;}; 
Valid values for cmd are:
IPC_STATCopy information from the kernel data structure
            associated with semid into the semid_ds structure
            pointed to by arg.buf. The argument
            semnum is
            ignored. The calling process must have read permission
            on the semaphore set.
IPC_SETWrite the values of some members of the semid_ds structure
            pointed to by arg.buf to the kernel
            data structure associated with this semaphore set,
            updating also its sem_ctime member. The
            following members of the structure are updated:
            sem_perm.uid,
            sem_perm.gid,
            and (the least significant 9 bits of) sem_perm.mode. The
            effective UID of the calling process must match the
            owner (sem_perm.uid) or
            creator (sem_perm.cuid) of the
            semaphore set, or the caller must be privileged. The
            argument semnum
            is ignored.
IPC_RMIDImmediately remove the semaphore set, awakening all
            processes blocked in semop(2) calls on the
            set (with an error return and errno set to EIDRM). The effective user ID of the
            calling process must match the creator or owner of the
            semaphore set, or the caller must be privileged. The
            argument semnum
            is ignored.
IPC_INFO (Linux-specific)Returns information about system-wide semaphore
            limits and parameters in the structure pointed to by
            arg.__buf.
            This structure is of type seminfo, defined in
            <sys/sem.h> if the _GNU_SOURCE feature test macro is
            defined:
struct seminfo { int semmap;
map; unused within kernel */int semmni;int semmns;
semaphore sets */int semmnu;
structures; unused within kernel */int semmsl;
set */int semopm;
semop(2) */int semume;
process; unused within kernel */int semusz;int semvmx;int semaem;
semaphore adjustment (SEM_UNDO) */}; 
The semmsl,
            semmns,
            semopm, and
            semmni settings
            can be changed via /proc/sys/kernel/sem; see proc(5) for
            details.
SEM_INFO (Linux-specific)Returns a seminfo structure
            containing the same information as for IPC_INFO, except that the following
            fields are returned with information about system
            resources consumed by semaphores: the semusz field returns the
            number of semaphore sets that currently exist on the
            system; and the semaem field returns the
            total number of semaphores in all semaphore sets on the
            system.
SEM_STAT (Linux-specific)Returns a semid_ds structure as
            for IPC_STAT. However,
            the semid
            argument is not a semaphore identifier, but instead an
            index into the kernel's internal array that maintains
            information about all semaphore sets on the system.
GETALLReturn semval (i.e., the
            current value) for all semaphores of the set into
            arg.array.
            The argument semnum is ignored. The
            calling process must have read permission on the
            semaphore set.
GETNCNTThe system call returns the value of semncnt (i.e., the
            number of processes waiting for the value of this
            semaphore to increase) for the semnum−th semaphore
            of the set (i.e., the number of processes waiting for
            an increase of semval for the
            semnum−th
            semaphore of the set). The calling process must have
            read permission on the semaphore set.
GETPIDThe system call returns the value of sempid for the
            semnum−th
            semaphore of the set (i.e., the PID of the process that
            executed the last semop(2) call for the
            semnum−th
            semaphore of the set). The calling process must have
            read permission on the semaphore set.
GETVALThe system call returns the value of semval for the
            semnum−th
            semaphore of the set. The calling process must have
            read permission on the semaphore set.
GETZCNTThe system call returns the value of semzcnt (i.e., the
            number of processes waiting for the value of this
            semaphore to become zero) for the semnum−th semaphore
            of the set (i.e., the number of processes waiting for
            semval of the
            semnum−th
            semaphore of the set to become 0). The calling process
            must have read permission on the semaphore set.
SETALLSet semval
            for all semaphores of the set using arg.array, updating
            also the sem_ctime member of the
            semid_ds
            structure associated with the set. Undo entries (see
            semop(2)) are cleared
            for altered semaphores in all processes. If the changes
            to semaphore values would permit blocked semop(2) calls in
            other processes to proceed, then those processes are
            woken up. The argument semnum is ignored. The
            calling process must have alter (write) permission on
            the semaphore set.
SETVALSet the value of semval to arg.val for the
            semnum−th
            semaphore of the set, updating also the sem_ctime member of the
            semid_ds
            structure associated with the set. Undo entries are
            cleared for altered semaphores in all processes. If the
            changes to semaphore values would permit blocked
            semop(2) calls in
            other processes to proceed, then those processes are
            woken up. The calling process must have alter
            permission on the semaphore set.
On failure semctl() returns
      −1 with errno indicating
      the error.
Otherwise the system call returns a non-negative value
      depending on cmd as
      follows:
GETNCNTthe value of semncnt.
GETPIDthe value of sempid.
GETVALthe value of semval.
GETZCNTthe value of semzcnt.
IPC_INFOthe index of the highest used entry in the kernel's
            internal array recording information about all
            semaphore sets. (This information can be used with
            repeated SEM_STAT
            operations to obtain information about all semaphore
            sets on the system.)
SEM_INFOAs for IPC_INFO.
SEM_STATthe identifier of the semaphore set whose index was
            given in semid.
All other cmd
      values return 0 on success.
On failure, errno will be set
      to one of the following:
The argument cmd has one of the values
            GETALL, GETPID, GETVAL, GETNCNT, GETZCNT, IPC_STAT, SEM_STAT, SETALL, or SETVAL and the calling process does
            not have the required permissions on the semaphore set
            and does not have the CAP_IPC_OWNER capability.
The address pointed to by arg.buf or arg.array isn't
            accessible.
The semaphore set was removed.
Invalid value for cmd or semid. Or: for a
            SEM_STAT operation, the
            index value specified in semid referred to an
            array slot that is currently unused.
The argument cmd has the value
            IPC_SET or IPC_RMID but the effective user ID of
            the calling process is not the creator (as found in
            sem_perm.cuid) or the
            owner (as found in sem_perm.uid) of the
            semaphore set, and the process does not have the
            CAP_SYS_ADMIN
            capability.
The argument cmd has the value
            SETALL or SETVAL and the value to which
            semval is to
            be set (for some semaphore of the set) is less than 0
            or greater than the implementation limit SEMVMX.
The IPC_INFO, SEM_STAT and SEM_INFO operations are used by the
      ipcs(8) program to provide
      information on allocated resources. In the future these may
      modified or moved to a /proc file system interface.
Various fields in a struct
      semid_ds were typed as short under Linux 2.2 and have become
      long under Linux 2.4. To take
      advantage of this, a recompilation under glibc-2.1.91 or
      later should suffice. (The kernel distinguishes old and new
      calls by an IPC_64 flag in
      cmd.)
In some earlier versions of glibc, the semun union was defined in
      <sys/sem.h>
      but POSIX.1-2001 requires that the caller define this union.
      On versions of glibc where this union is not defined, the macro
      _SEM_SEMUN_UNDEFINED is defined
      in <sys/sem.h>
The following system limit on semaphore sets affects a
      semctl() call:
SEMVMXMaximum value for semval: implementation
            dependent (32767).
For greater portability it is best to always call
      semctl() with four
      arguments.
This page is part of release 3.22 of the Linux man-pages project. A
      description of the project, and information about reporting
      bugs, can be found at
      http://www.kernel.org/doc/man-pages/.
| Copyright 1993 Giorgio Ciucci (giorgiocrcc.it) and Copyright 2004, 2005 Michael Kerrisk <mtk.manpagesgmail.com> Permission is granted to make and distribute verbatim copies of this manual provided the copyright notice and this permission notice are preserved on all copies. Permission is granted to copy and distribute modified versions of this manual under the conditions for verbatim copying, provided that the entire resulting derived work is distributed under the terms of a permission notice identical to this one. Since the Linux kernel and libraries are constantly changing, this manual page may be incorrect or out-of-date. The author(s) assume no responsibility for errors or omissions, or for damages resulting from the use of the information contained herein. The author(s) may not have taken the same level of care in the production of this manual, which is licensed free of charge, as they might when working professionally. Formatted or processed versions of this manual, if unaccompanied by the source, must acknowledge the copyright and authors of this work. Modified Tue Oct 22 17:53:56 1996 by Eric S. Raymond <esrthyrsus.com> Modified Fri Jun 19 10:59:15 1998 by Andries Brouwer <aebcwi.nl> Modified Sun Feb 18 01:59:29 2001 by Andries Brouwer <aebcwi.nl> Modified 20 Dec 2001, Michael Kerrisk <mtk.manpagesgmail.com> Modified 21 Dec 2001, aeb Modified 27 May 2004, Michael Kerrisk <mtk.manpagesgmail.com> Added notes on CAP_IPC_OWNER requirement Modified 17 Jun 2004, Michael Kerrisk <mtk.manpagesgmail.com> Added notes on CAP_SYS_ADMIN requirement for IPC_SET and IPC_RMID Modified, 11 Nov 2004, Michael Kerrisk <mtk.manpagesgmail.com> Language and formatting clean-ups Rewrote semun text Added semid_ds and ipc_perm structure definitions 2005-08-02, mtk: Added IPC_INFO, SEM_INFO, SEM_STAT descriptions. |