Optimize for kernels which are known to have the vfork syscall.
[glibc/pb-stable.git] / nptl / DESIGN-sem.txt
blobd25a1c281d195dec50364ca9289f26e9efd1ec94
1 Semaphores pseudocode
2 ==============================
4        int sem_wait(sem_t * sem);
5        int sem_trywait(sem_t * sem);
6        int sem_post(sem_t * sem);
7        int sem_getvalue(sem_t * sem, int * sval);
9 struct sem_t {
11    unsigned int count;
12          - current semaphore count, also used as a futex
15 sem_wait(sem_t *sem)
17   for (;;) {
19     if (atomic_decrement_if_positive(sem->count))
20       break;
22     futex_wait(&sem->count, 0)
23   }
26 sem_post(sem_t *sem)
28   n = atomic_increment(sem->count);
29   futex_wake(&sem->count, n);
32 sem_trywait(sem_t *sem)
34   if (atomic_decrement_if_positive(sem->count)) {
35     return 0;
36   } else {
37     return EAGAIN;
38   }
41 sem_getvalue(sem_t *sem, int *sval)
43   *sval = sem->count;
44   read_barrier();