Commit 93a72f1d authored by mmu_man's avatar mmu_man

added a lock/unlock_lib pair to allow extern progs to serialize access to lavc.


git-svn-id: file:///var/local/repositories/ffmpeg/trunk@3899 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent 7131ad34
......@@ -33,6 +33,25 @@ typedef struct ThreadContext{
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 @@ fail:
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);
}
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment