arsa
2.7
|
Go to the source code of this file.
Macros | |
#define | SDL_MUTEX_TIMEDOUT 1 |
#define | SDL_MUTEX_MAXWAIT (~(Uint32)0) |
Mutex functions | |
#define | SDL_mutexP(m) SDL_LockMutex(m) |
#define | SDL_mutexV(m) SDL_UnlockMutex(m) |
typedef struct SDL_mutex | SDL_mutex |
DECLSPEC SDL_mutex *SDLCALL | SDL_CreateMutex (void) |
DECLSPEC int SDLCALL | SDL_LockMutex (SDL_mutex *mutex) |
DECLSPEC int SDLCALL | SDL_TryLockMutex (SDL_mutex *mutex) |
DECLSPEC int SDLCALL | SDL_UnlockMutex (SDL_mutex *mutex) |
DECLSPEC void SDLCALL | SDL_DestroyMutex (SDL_mutex *mutex) |
Semaphore functions | |
typedef struct SDL_semaphore | SDL_sem |
DECLSPEC SDL_sem *SDLCALL | SDL_CreateSemaphore (Uint32 initial_value) |
DECLSPEC void SDLCALL | SDL_DestroySemaphore (SDL_sem *sem) |
DECLSPEC int SDLCALL | SDL_SemWait (SDL_sem *sem) |
DECLSPEC int SDLCALL | SDL_SemTryWait (SDL_sem *sem) |
DECLSPEC int SDLCALL | SDL_SemWaitTimeout (SDL_sem *sem, Uint32 ms) |
DECLSPEC int SDLCALL | SDL_SemPost (SDL_sem *sem) |
DECLSPEC Uint32 SDLCALL | SDL_SemValue (SDL_sem *sem) |
Condition variable functions | |
typedef struct SDL_cond | SDL_cond |
DECLSPEC SDL_cond *SDLCALL | SDL_CreateCond (void) |
DECLSPEC void SDLCALL | SDL_DestroyCond (SDL_cond *cond) |
DECLSPEC int SDLCALL | SDL_CondSignal (SDL_cond *cond) |
DECLSPEC int SDLCALL | SDL_CondBroadcast (SDL_cond *cond) |
DECLSPEC int SDLCALL | SDL_CondWait (SDL_cond *cond, SDL_mutex *mutex) |
DECLSPEC int SDLCALL | SDL_CondWaitTimeout (SDL_cond *cond, SDL_mutex *mutex, Uint32 ms) |
Functions to provide thread synchronization primitives.
Definition in file SDL_mutex.h.
#define SDL_MUTEX_MAXWAIT (~(Uint32)0) |
This is the timeout value which corresponds to never time out.
Definition at line 49 of file SDL_mutex.h.
#define SDL_MUTEX_TIMEDOUT 1 |
Synchronization functions which can time out return this value if they time out.
Definition at line 44 of file SDL_mutex.h.
#define SDL_mutexP | ( | m | ) | SDL_LockMutex(m) |
#define SDL_mutexV | ( | m | ) | SDL_UnlockMutex(m) |
Unlock the mutex.
Definition at line 89 of file SDL_mutex.h.
Definition at line 167 of file SDL_mutex.h.
Definition at line 59 of file SDL_mutex.h.
typedef struct SDL_semaphore SDL_sem |
Definition at line 107 of file SDL_mutex.h.
Restart all threads that are waiting on the condition variable.
Restart one of the threads that are waiting on the condition variable.
Wait on the condition variable, unlocking the provided mutex.
The mutex is re-locked once the condition variable is signaled.
Waits for at most ms
milliseconds, and returns 0 if the condition variable is signaled, SDL_MUTEX_TIMEDOUT if the condition is not signaled in the allotted time, and -1 on error.
Create a condition variable.
Typical use of condition variables:
Thread A: SDL_LockMutex(lock); while ( ! condition ) { SDL_CondWait(cond, lock); } SDL_UnlockMutex(lock);
Thread B: SDL_LockMutex(lock); ... condition = true; ... SDL_CondSignal(cond); SDL_UnlockMutex(lock);
There is some discussion whether to signal the condition variable with the mutex locked or not. There is some potential performance benefit to unlocking first on some platforms, but there are some potential race conditions depending on how your code is structured.
In general it's safer to signal the condition variable while the mutex is locked.
Create a semaphore, initialized with value, returns NULL on failure.
Atomically increases the semaphore's count (not blocking).
Non-blocking variant of SDL_SemWait().
This function suspends the calling thread until the semaphore pointed to by sem
has a positive count. It then atomically decreases the semaphore count.
Variant of SDL_SemWait() with a timeout in milliseconds.
Try to lock the mutex