![]() |
libgpac
Documentation of the core library of GPAC
|
Thread processing. More...
Macros | |
#define | safe_int_inc(__v) __sync_add_and_fetch((int *) (__v), 1) |
#define | safe_int_dec(__v) __sync_sub_and_fetch((int *) (__v), 1) |
#define | safe_int_add(__v, inc_val) __sync_add_and_fetch((int *) (__v), inc_val) |
#define | safe_int_sub(__v, dec_val) __sync_sub_and_fetch((int *) (__v), dec_val) |
#define | safe_int64_add(__v, inc_val) __sync_add_and_fetch((int64_t *) (__v), inc_val) |
#define | safe_int64_sub(__v, dec_val) __sync_sub_and_fetch((int64_t *) (__v), dec_val) |
Typedefs | |
typedef u32(* | gf_thread_run) (void *par) |
thread run function callback More... | |
Enumerations | |
enum | { GF_THREAD_STATUS_STOP = 0 , GF_THREAD_STATUS_RUN = 1 , GF_THREAD_STATUS_DEAD = 2 } |
Thread states. More... | |
enum | { GF_THREAD_PRIORITY_IDLE =0 , GF_THREAD_PRIORITY_LESS_IDLE , GF_THREAD_PRIORITY_LOWEST , GF_THREAD_PRIORITY_LOW , GF_THREAD_PRIORITY_NORMAL , GF_THREAD_PRIORITY_HIGH , GF_THREAD_PRIORITY_HIGHEST , GF_THREAD_PRIORITY_REALTIME , GF_THREAD_PRIORITY_REALTIME_END =255 } |
Functions | |
GF_Thread * | gf_th_new (const char *name) |
thread constructor More... | |
void | gf_th_del (GF_Thread *th) |
thread destructor More... | |
GF_Err | gf_th_run (GF_Thread *th, gf_thread_run run, void *par) |
thread execution More... | |
void | gf_th_stop (GF_Thread *th) |
thread stopping More... | |
u32 | gf_th_status (GF_Thread *th) |
thread status query More... | |
void | gf_th_set_priority (GF_Thread *th, s32 priority) |
thread priority More... | |
u32 | gf_th_id () |
current thread ID More... | |
Thread processing.
The thread object allows executing some code independently of the main process of your application.
#define safe_int_inc | ( | __v | ) | __sync_add_and_fetch((int *) (__v), 1) |
atomic integer increment
#define safe_int_dec | ( | __v | ) | __sync_sub_and_fetch((int *) (__v), 1) |
atomic integer decrement
#define safe_int_add | ( | __v, | |
inc_val | |||
) | __sync_add_and_fetch((int *) (__v), inc_val) |
atomic integer addition
#define safe_int_sub | ( | __v, | |
dec_val | |||
) | __sync_sub_and_fetch((int *) (__v), dec_val) |
atomic integer subtraction
#define safe_int64_add | ( | __v, | |
inc_val | |||
) | __sync_add_and_fetch((int64_t *) (__v), inc_val) |
atomic large integer addition
#define safe_int64_sub | ( | __v, | |
dec_val | |||
) | __sync_sub_and_fetch((int64_t *) (__v), dec_val) |
atomic large integer subtraction
typedef u32(* gf_thread_run) (void *par) |
thread run function callback
The gf_thread_run type is the type for the callback of the gf_thread_run function
par | opaque user data |
anonymous enum |
anonymous enum |
thread priorities
GF_Thread* gf_th_new | ( | const char * | name | ) |
thread constructor
Constructs a new thread object
name | log name of the thread if any |
void gf_th_del | ( | GF_Thread * | th | ) |
thread destructor
Kills the thread if running and destroys the object
th | the thread object |
GF_Err gf_th_run | ( | GF_Thread * | th, |
gf_thread_run | run, | ||
void * | par | ||
) |
thread execution
Executes the thread with the given function
th | the thread object |
run | the function this thread will call |
par | the argument to the function the thread will call |
void gf_th_stop | ( | GF_Thread * | th | ) |
thread stopping
Waits for the thread exit until return
th | the thread object |
u32 gf_th_status | ( | GF_Thread * | th | ) |
thread status query
Gets the thread status
th | the thread object |
void gf_th_set_priority | ( | GF_Thread * | th, |
s32 | priority | ||
) |
thread priority
Sets the thread execution priority level.
th | the thread object |
priority | the desired priority |
u32 gf_th_id | ( | ) |
current thread ID
Gets the ID of the current thread the caller is in.