Main index | Section 3 | Options |
#include <semaphore.h>
This implementation places strict requirements on the value of name: it must begin with a slash (‘/’) and contain no other slash characters.
The following bits may be set in the oflag argument:
O_CREAT | |
Create the semaphore if it does not already exist.
The third argument to the call to sem_open() must be of type mode_t and specifies the mode for the semaphore. Only the S_IWUSR, S_IWGRP, and S_IWOTH bits are examined; it is not possible to grant only "read" permission on a semaphore. The mode is modified according to the process's file creation mask; see umask(2). The fourth argument must be an unsigned int and specifies the initial value for the semaphore, and must be no greater than SEM_VALUE_MAX. | |
O_EXCL | Create the semaphore if it does not exist. If the semaphore already exists, sem_open() will fail. This flag is ignored unless O_CREAT is also specified. |
The sem_close() function closes a named semaphore that was opened by a call to sem_open().
The sem_unlink() function removes the semaphore named name. Resources allocated to the semaphore are only deallocated when all processes that have the semaphore open close it.
The sem_closeand sem_unlink functions return the value 0 if successful; otherwise the value -1 is returned and the global variable errno is set to indicate the error.
[EACCES] | |
The semaphore exists and the permissions specified by oflag at the time it was created deny access to this process. | |
[EACCES] | |
The semaphore does not exist, but permission to create it is denied. | |
[EEXIST] | |
O_CREAT and O_EXCL are set but the semaphore already exists. | |
[EINTR] | |
The call was interrupted by a signal. | |
[EINVAL] | |
The sem_open() operation is not supported for the given name. | |
[EINVAL] | |
The value argument is greater than SEM_VALUE_MAX. | |
[ENAMETOOLONG] | |
The name argument is too long. | |
[ENFILE] | |
The system limit on semaphores has been reached. | |
[ENOENT] | |
O_CREAT is not set but the named semaphore does not exist. | |
[ENOSPC] | |
There is not enough space to create the semaphore. | |
The sem_close() function will fail if:
[EINVAL] | |
The sem argument is not a valid semaphore. | |
The sem_unlink() function will fail if:
[EACCES] | |
Permission is denied to unlink the semaphore. | |
[ENAMETOOLONG] | |
The specified name is too long. | |
[ENOENT] | |
The named semaphore does not exist. | |
SEM_OPEN (3) | January 9, 2010 |
Main index | Section 3 | Options |
Please direct any comments about this manual page service to Ben Bullock. Privacy policy.
“ | Our grievance is not just against Unix itself, but against the cult of Unix zealots who defend and nurture it. They take the heat, disease, and pestilence as givens, and, as ancient shamans did, display their wounds, some self-inflicted, as proof of their power and wizardry. We aim, through bluntness and humor, to show them that they pray to a tin god, and that science, not religion, is the path to useful and friendly technology. | ” |
— The Unix Haters' handbook |