[vlc-devel] commit: Add a centralized avcodec lock ( Rémi Denis-Courmont )

git version control git at videolan.org
Thu Mar 12 16:41:54 CET 2009


vlc | branch: master | Rémi Denis-Courmont <remi at remlab.net> | Thu Mar 12 17:27:37 2009 +0200| [6f037fa47876b4270133259f2d5f5ae545b2689a] | committer: Rémi Denis-Courmont 

Add a centralized avcodec lock

avcodec is used from at least three different plugins: avcodec,
switcher (which seems dead though) and indirectly in avformat. We need
to have a common interlock for all of these.

> http://git.videolan.org/gitweb.cgi/vlc.git/?a=commit;h=6f037fa47876b4270133259f2d5f5ae545b2689a
---

 include/vlc_avcodec.h |   36 ++++++++++++++++++++++++++++++++++++
 src/Makefile.am       |    1 +
 src/libvlc.c          |   12 ++++++++++++
 src/libvlccore.sym    |    1 +
 4 files changed, 50 insertions(+), 0 deletions(-)

diff --git a/include/vlc_avcodec.h b/include/vlc_avcodec.h
new file mode 100644
index 0000000..fc5a3a9
--- /dev/null
+++ b/include/vlc_avcodec.h
@@ -0,0 +1,36 @@
+/*****************************************************************************
+ * vlc_avcodec.h: VLC thread support for FFMPEG/libavcodec
+ *****************************************************************************
+ * Copyright (C) 2009 Rémi Denis-Courmont
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 02110-1301, USA.
+ *****************************************************************************/
+
+#ifndef VLC_AVCODEC_H
+# define VLC_AVCODEC_H 1
+
+VLC_EXPORT( void, vlc_avcodec_mutex, (bool) );
+
+static inline void vlc_avcodec_lock (void)
+{
+    vlc_avcodec_mutex (true);
+}
+
+static inline void vlc_avcodec_unlock (void)
+{
+    vlc_avcodec_mutex (false);
+}
+
+#endif
diff --git a/src/Makefile.am b/src/Makefile.am
index ef2f3e3..eabdb6c 100644
--- a/src/Makefile.am
+++ b/src/Makefile.am
@@ -41,6 +41,7 @@ pluginsinclude_HEADERS = \
 	../include/vlc_acl.h \
 	../include/vlc_aout.h \
 	../include/vlc_arrays.h \
+	../include/vlc_avcodec.h \
 	../include/vlc_bits.h \
 	../include/vlc_block.h \
 	../include/vlc_block_helper.h \
diff --git a/src/libvlc.c b/src/libvlc.c
index 2f1e641..e4a1a8e 100644
--- a/src/libvlc.c
+++ b/src/libvlc.c
@@ -2130,3 +2130,15 @@ static void InitDeviceValues( libvlc_int_t *p_vlc )
     (void)p_vlc;
 #endif /* HAVE_HAL */
 }
+
+#include <vlc_avcodec.h>
+
+void vlc_avcodec_mutex (bool acquire)
+{
+    static vlc_mutex_t lock = VLC_STATIC_MUTEX;
+
+    if (acquire)
+        vlc_mutex_lock (&lock);
+    else
+        vlc_mutex_unlock (&lock);
+}
diff --git a/src/libvlccore.sym b/src/libvlccore.sym
index 2419796..db21b46 100644
--- a/src/libvlccore.sym
+++ b/src/libvlccore.sym
@@ -409,6 +409,7 @@ var_SetChecked
 __var_TriggerCallback
 __var_Type
 video_format_FixRgb
+vlc_avcodec_mutex
 vlc_b64_decode
 vlc_b64_decode_binary
 vlc_b64_decode_binary_to_buffer




More information about the vlc-devel mailing list