Man Linux: Main Page and Category List

NAME

       SDL_SemWait  - Lock a semaphore and suspend the thread if the semaphore
       value is zero.

SYNOPSIS

       #include "SDL.h" #include "SDL_thread.h"

       int SDL_SemWait(SDL_sem *sem);

DESCRIPTION

       SDL_SemWait() suspends the calling thread until  either  the  semaphore
       pointed  to  by  sem has a positive value, the call is interrupted by a
       signal or error. If the call is successful it will atomically decrement
       the semaphore value.

       After  SDL_SemWait()  is  successful, the semaphore can be released and
       its count atomically incremented by a successful call to SDL_SemPost.

RETURN VALUE

       Returns 0 if successful or -1  if  there  was  an  error  (leaving  the
       semaphore unchanged).

EXAMPLES

       if (SDL_SemWait(my_sem) == -1) {
               return WAIT_FAILED;
       }

       ...

       SDL_SemPost(my_sem);

SEE ALSO

       SDL_CreateSemaphore,        SDL_DestroySemaphore,       SDL_SemTryWait,
       SDL_SemWaitTimeout, SDL_SemPost, SDL_SemValue