Feedback
Feedback

If you are having issues with the exercises, please create a ticket on DevZone: devzone.nordicsemi.com
Click or drag files to this area to upload. You can upload up to 2 files.

Semaphores

In its simplest form, a semaphore is merely a plain variable that is changed, indicating the status of the common resource. Semaphores can be seen as a resource-sharing mechanism, where you have a finite instance of a resource that you want to manage access for multiple threads. They are more of a signaling mechanism used to control access to a given number of instances of a resource.

Semaphores have the following properties:

  • At initialization, you set an initial count (greater or equal to 0) and a maximum limit.
  • “Give” will increment the semaphore count unless the count is already at the maximum limit, in which case the signal will not increment. “Give” can be done from any thread or ISR.
  • “Take” will decrement the semaphore count unless the semaphore is unavailable (count at zero). Any thread that is trying to take a semaphore that is unavailable needs to wait until some other thread makes it available (by giving the semaphore). “Take” can be done only in threads and not in ISR (the kernel does allow an ISR to take a semaphore, however the ISR must not attempt to wait if the semaphore is unavailable).
  • There is no ownership of semaphores. This means a semaphore can be taken by one thread and can be given by any thread. It is not necessary that the thread that has taken the semaphore is the one to give it.
  • The thread taking the semaphore is NOT eligible for priority inheritance since the taking thread does not own the semaphore and any other thread can give the semaphore.

The figure below shows the semaphore properties

Semaphore

Note

You may initialize a “full” semaphore (count equal to limit) to limit the number of threads able to execute the critical section at the same time.

You may also initialize an “empty semaphore” (count equal to 0, with a limit equal to 1) to create a gate where no waiting thread may pass until the semaphore is incremented first.

Register an account
Already have an account? Log in
(All fields are required unless specified optional)

  • 8 or more characters
  • Upper and lower case letters
  • At least one number or special character

Forgot your password?
Enter the email associated with your account, and we will send you a link to reset your password.