Alfred Perlstein wrote: > Ok, any of you guys have a copy of the standards documents that > describe the sem_* API? > > I have a question... > > What are the semantics of the sem_init when pshared is set to true?
The sem_init() function is used to initialise the unnamed semaphore referred to by sem. The value of the initialised semaphore is value. Following a successful call to sem_init(), the semaphore may be used in subsequent calls to sem_wait(), sem_trywait(), sem_post(), and sem_destroy(). This semaphore remains usable until the semaphore is destroyed. If the pshared argument has a non-zero value, then the semaphore is shared between processes; in this case, any process that can access the semaphore sem can use sem for performing sem_wait(), sem_trywait(), sem_post(), and sem_destroy() operations. Only sem itself may be used for performing synchronisation. The result of referring to copies of sem in calls to sem_wait(), sem_trywait(), sem_post(), and sem_destroy(), is undefined. If the pshared argument is zero, then the semaphore is shared between threads of the process; any thread in this process can use sem for performing sem_wait(), sem_trywait(), sem_post(), and sem_destroy() operations. The use of the semaphore by threads other than those created in the same process is undefined. Attempting to initialise an already initialised semaphore results in undefined behaviour. > Like, if the process that created the semaphore exits, then what? The use of the semaphore by threads other than those created in the same process is undefined. > Is it only valid for the life of the process that did the sem_init? The use of the semaphore by threads other than those created in the same process is undefined. 8-). -- Terry To Unsubscribe: send mail to [EMAIL PROTECTED] with "unsubscribe freebsd-hackers" in the body of the message