Mercurial > libavcodec.hg
changeset 2469:df02930c138b libavcodec
added a lock/unlock_lib pair to allow extern progs to serialize access to lavc.
author | mmu_man |
---|---|
date | Sat, 29 Jan 2005 20:09:33 +0000 |
parents | 1addaf6facbb |
children | 06aafb585f69 |
files | beosthread.c |
diffstat | 1 files changed, 47 insertions(+), 0 deletions(-) [+] |
line wrap: on
line diff
--- a/beosthread.c Fri Jan 28 19:54:10 2005 +0000 +++ b/beosthread.c Sat Jan 29 20:09:33 2005 +0000 @@ -33,6 +33,25 @@ int ret; }ThreadContext; +// it's odd Be never patented that :D +struct benaphore { + vint32 atom; + sem_id sem; +}; +static inline int lock_ben(struct benaphore *ben) +{ + if (atomic_add(&ben->atom, 1) > 0) + return acquire_sem(ben->sem); + return B_OK; +} +static inline int unlock_ben(struct benaphore *ben) +{ + if (atomic_add(&ben->atom, -1) > 1) + return release_sem(ben->sem); + return B_OK; +} + +static struct benaphore av_thread_lib_ben; static int32 ff_thread_func(void *v){ ThreadContext *c= v; @@ -131,3 +150,31 @@ avcodec_thread_free(s); return -1; } + +/* provide a mean to serialize calls to avcodec_*() for thread safety. */ + +int avcodec_thread_lock_lib(void) +{ + return lock_ben(&av_thread_lib_ben); +} + +int avcodec_thread_unlock_lib(void) +{ + return unlock_ben(&av_thread_lib_ben); +} + +/* our versions of _init and _fini (which are called by those actually from crt.o) */ + +void initialize_after(void) +{ + av_thread_lib_ben.atom = 0; + av_thread_lib_ben.sem = create_sem(0, "libavcodec benaphore"); +} + +void uninitialize_before(void) +{ + delete_sem(av_thread_lib_ben.sem); +} + + +