2 .\" Copyright 1989 AT&T.
3 .\" Copyright (c) 2006, Sun Microsystems, Inc. All Rights Reserved.
4 .\" The contents of this file are subject to the terms of the Common Development and Distribution License (the "License"). You may not use this file except in compliance with the License.
5 .\" You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE or http://www.opensolaris.org/os/licensing. See the License for the specific language governing permissions and limitations under the License.
6 .\" When distributing Covered Code, include this CDDL HEADER in each file and include the License file at usr/src/OPENSOLARIS.LICENSE. If applicable, add the following below this CDDL HEADER, with the fields enclosed by brackets "[]" replaced with your own identifying information: Portions Copyright [yyyy] [name of copyright owner]
7 .TH SEMOP 2 "May 12, 2006"
9 semop, semtimedop \- semaphore operations
13 #include <sys/types.h>
17 \fBint\fR \fBsemop\fR(\fBint\fR \fIsemid\fR, \fBstruct sembuf *\fR\fIsops\fR, \fBsize_t\fR \fInsops\fR);
22 \fBint\fR \fBsemtimedop\fR(\fBint\fR \fIsemid\fR, \fBstruct sembuf *\fR\fIsops\fR, \fBsize_t\fR \fInsops\fR,
23 \fBconst struct timespec *\fR\fItimeout\fR);
29 The \fBsemop()\fR function is used to perform atomically an array of semaphore
30 operations on the set of semaphores associated with the semaphore identifier
31 specified by \fIsemid\fR. The \fIsops\fR argument is a pointer to the array of
32 semaphore-operation structures. The \fInsops\fR argument is the number of such
33 structures in the array.
36 Each \fBsembuf\fR structure contains the following members:
40 short sem_num; /* semaphore number */
41 short sem_op; /* semaphore operation */
42 short sem_flg; /* operation flags */
48 Each semaphore operation specified by \fBsem_op\fR is performed on the
49 corresponding semaphore specified by \fIsemid\fR and \fBsem_num\fR. The
50 permission required for a semaphore operation is given as {\fItoken\fR}, where
51 \fItoken\fR is the type of permission needed. The types of permission are
52 interpreted as follows:
67 See the \fBSemaphore Operation Permissions\fR section of \fBIntro\fR(2) for
71 A process maintains a value, \fBsemadj\fR, for each semaphore it modifies. This
72 value contains the cumulative effect of operations the process has performed on
73 an individual semaphore with the \fBSEM_UNDO\fR flag set (so that they can be
74 undone if the process terminates unexpectedly). The value of \fBsemadj\fR can
75 affect the behavior of calls to \fBsemop()\fR, \fBsemtimedop()\fR,
76 \fBexit()\fR, and \fB_exit()\fR (the latter two functions documented on
77 \fBexit\fR(2)), but is otherwise unobservable. See below for details.
80 The \fBsem_op\fR member specifies one of three semaphore operations:
84 The \fBsem_op\fR member is a negative integer; {ALTER}
89 If \fBsemval\fR (see \fBIntro\fR(2)) is greater than or equal to the absolute
90 value of \fBsem_op\fR, the absolute value of \fBsem_op\fR is subtracted from
91 \fBsemval\fR. Also, if (\fIsem_flg\fR\fB&SEM_UNDO\fR) is true, the absolute
92 value of \fBsem_op\fR is added to the calling process's \fBsemadj\fR value (see
93 \fBexit\fR(2)) for the specified semaphore.
99 If \fBsemval\fR is less than the absolute value of \fBsem_op\fR and
100 (\fIsem_flg\fR\fB&IPC_NOWAIT\fR) is true, \fBsemop()\fR returns immediately.
106 If \fBsemval\fR is less than the absolute value of \fBsem_op\fR and
107 (\fIsem_flg\fR\fB&IPC_NOWAIT\fR) is false, \fBsemop()\fR increments the
108 \fBsemncnt\fR associated with the specified semaphore and suspends execution of
109 the calling thread until one of the following conditions occur:
114 The value of \fBsemval\fR becomes greater than or equal to the absolute value
115 of \fBsem_op\fR. When this occurs, the value of \fBsemncnt\fR associated with
116 the specified semaphore is decremented, the absolute value of \fBsem_op\fR is
117 subtracted from \fBsemval\fR and, if (\fIsem_flg\fR\fB&SEM_UNDO\fR) is true,
118 the absolute value of \fBsem_op\fR is added to the calling process's
119 \fBsemadj\fR value for the specified semaphore.
125 The \fIsemid\fR for which the calling thread is awaiting action is removed from
126 the system (see \fBsemctl\fR(2)). When this occurs, \fBerrno\fR is set to
127 \fBEIDRM\fR and \fB\(mi1\fR is returned.
133 The calling thread receives a signal that is to be caught. When this occurs,
134 the value of \fBsemncnt\fR associated with the specified semaphore is
135 decremented, and the calling thread resumes execution in the manner prescribed
136 in \fBsigaction\fR(2).
143 The \fBsem_op\fR member is a positive integer; {ALTER}
145 The value of \fBsem_op\fR is added to \fBsemval\fR and, if
146 (\fIsem_flg\fR\fB&SEM_UNDO\fR) is true, the value of \fBsem_op\fR is subtracted
147 from the calling process's \fBsemadj\fR value for the specified semaphore.
152 The \fBsem_op\fR member is 0; {READ}
157 If \fBsemval\fR is 0, \fBsemop()\fR returns immediately.
163 If \fBsemval\fR is not equal to 0 and (\fIsem_flg\fR\fB&IPC_NOWAIT\fR) is true,
164 \fBsemop()\fR returns immediately.
170 If \fBsemval\fR is not equal to 0 and (\fIsem_flg\fR\fB&IPC_NOWAIT\fR) is
171 false, \fBsemop()\fR increments the \fBsemzcnt\fR associated with the specified
172 semaphore and suspends execution of the calling thread until one of the
178 The value of \fBsemval\fR becomes 0, at which time the value of \fBsemzcnt\fR
179 associated with the specified semaphore is set to 0 and all processes waiting
180 on \fBsemval\fR to become 0 are awakened.
186 The \fIsemid\fR for which the calling thread is awaiting action is removed from
187 the system. When this occurs, \fBerrno\fR is set to \fBEIDRM\fR and \fB\(mi1\fR
194 The calling thread receives a signal that is to be caught. When this occurs,
195 the value of \fBsemzcnt\fR associated with the specified semaphore is
196 decremented, and the calling thread resumes execution in the manner prescribed
197 in \fBsigaction\fR(2).
203 Upon successful completion, the value of \fBsempid\fR for each semaphore
204 specified in the array pointed to by \fIsops\fR is set to the process \fBID\fR
205 of the calling process.
208 The \fBsemtimedop()\fR function behaves as \fBsemop()\fR except when it must
209 suspend execution of the calling process to complete its operation. If
210 \fBsemtimedop()\fR must suspend the calling process after the time interval
211 specified in \fItimeout\fR expires, or if the timeout expires while the process
212 is suspended, \fBsemtimedop()\fR returns with an error. If the \fBtimespec\fR
213 structure pointed to by \fItimeout\fR is zero-valued and \fBsemtimedop()\fR
214 needs to suspend the calling process to complete the requested operation(s), it
215 returns immediately with an error. If \fItimeout\fR is the \fINULL\fR pointer,
216 the behavior of \fBsemtimedop()\fR is identical to that of \fBsemop()\fR.
220 Upon successful completion, \fB0\fR is returned. Otherwise, \fB\(mi1\fR is
221 returned and \fBerrno\fR is set to indicate the error.
225 The \fBsemop()\fR and \fBsemtimedop()\fR functions will fail if:
232 The \fInsops\fR argument is greater than the system-imposed maximum. See NOTES.
241 Operation permission is denied to the calling process (see \fBIntro\fR(2)).
250 The operation would result in suspension of the calling process but
251 (\fIsem_flg\fR\fB&IPC_NOWAIT\fR) is true.
260 The \fIsops\fR argument points to an illegal address.
269 The value of \fBsem_num\fR is less than 0 or greater than or equal to the
270 number of semaphores in the set associated with \fIsemid\fR.
279 A \fIsemid\fR was removed from the system.
288 A signal was received.
297 The \fIsemid\fR argument is not a valid semaphore identifier, or the number of
298 individual semaphores for which the calling process requests a \fBSEM_UNDO\fR
299 operation would exceed the system-imposed limit. Solaris does not impose a
300 limit on the number of individual semaphores for which the calling process
301 requests a \fBSEM_UNDO\fR operation.
310 The limit on the number of individual processes requesting a \fBSEM_UNDO\fR
311 operation would be exceeded. Solaris does not impose a limit on the number of
312 individual processes requesting an \fBSEM_UNDO\fR operation.
321 An operation would cause a \fBsemval\fR or a \fBsemadj\fR value to overflow the
322 system-imposed limit.
327 The \fBsemtimedop()\fR function will fail if:
334 The timeout expired before the requested operation could be completed.
339 The \fBsemtimedop()\fR function will fail if one of the following is detected:
346 The \fItimeout\fR argument points to an illegal address.
355 The \fItimeout\fR argument specified a \fBtv_sec\fR or \fBtv_nsec\fR value less
356 than 0, or a \fBtv_nsec\fR value greater than or equal to 1000 million.
362 See \fBattributes\fR(5) for descriptions of the following attributes:
370 ATTRIBUTE TYPE ATTRIBUTE VALUE
372 Interface Stability \fBsemop()\fR is Standard.
378 \fBipcs\fR(1), \fBrctladm\fR(1M), \fBIntro\fR(2), \fBexec\fR(2), \fBexit\fR(2),
379 \fBfork\fR(2), \fBsemctl\fR(2), \fBsemget\fR(2), \fBsetrctl\fR(2),
380 \fBsigaction\fR(2), \fBattributes\fR(5), \fBstandards\fR(5)
384 The system-imposed maximum on \fInsops\fR for a semaphore identifier is the
385 minimum enforced value of the \fBprocess.max-sem-ops\fR resource control of the
386 creating process at the time \fBsemget\fR(2) was used to allocate the
390 See \fBrctladm\fR(1M) and \fBsetrctl\fR(2) for information about using resource