Binary Semaphores (Locks)

This lesson talks about a special kind of semaphores, the binary semaphores.

We'll cover the following...

We are now ready to use a semaphore. Our first use will be one with which we are already familiar: using a semaphore as a lock. Look at the code snippet below.

sem_t m;
sem_init(&m, 0, X); // initialize to X; what should X be?
sem_wait(&m);
// critical section here
sem_post(&m);

Therein, you can see that we simply surround the critical section of interest with a sem_wait()/sem_post() pair. Critical to making this work, though, is the initial value of the semaphore m (initialized to X in the figure). What should X be?

… (Try thinking about it before going on) …

Looking back at the definition of the sem_wait() and sem_post() routines above, we can see that the ...