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);
+}
+
+
+