aboutsummaryrefslogtreecommitdiffstats
path: root/libavformat/format.c
diff options
context:
space:
mode:
authorJames Almer <jamrial@gmail.com>2018-01-04 15:12:53 -0300
committerJames Almer <jamrial@gmail.com>2018-01-05 13:18:34 -0300
commit57960b1f2800e59a46de2b03f7b37ef6ef1c1e52 (patch)
tree4b2ab0b5fe6ec6b52cfbccbfbbab5ab70e09ec67 /libavformat/format.c
parent9ed4ebc530dde681943389b1f97db90b546ad38d (diff)
downloadffmpeg-57960b1f2800e59a46de2b03f7b37ef6ef1c1e52.tar.gz
avformat: use mutexes instead of atomics in av_register_{input,output}_format()
Reviewed-by: wm4 <nfxjfg@googlemail.com> Signed-off-by: James Almer <jamrial@gmail.com>
Diffstat (limited to 'libavformat/format.c')
-rw-r--r--libavformat/format.c34
1 files changed, 23 insertions, 11 deletions
diff --git a/libavformat/format.c b/libavformat/format.c
index 38ca2a3465..759b5b1ab4 100644
--- a/libavformat/format.c
+++ b/libavformat/format.c
@@ -19,10 +19,10 @@
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/
-#include "libavutil/atomic.h"
#include "libavutil/avstring.h"
#include "libavutil/bprint.h"
#include "libavutil/opt.h"
+#include "libavutil/thread.h"
#include "avio_internal.h"
#include "avformat.h"
@@ -58,28 +58,40 @@ AVOutputFormat *av_oformat_next(const AVOutputFormat *f)
return first_oformat;
}
+static AVMutex iformat_register_mutex = AV_MUTEX_INITIALIZER;
+
void av_register_input_format(AVInputFormat *format)
{
- AVInputFormat **p = last_iformat;
+ AVInputFormat **p;
+
+ ff_mutex_lock(&iformat_register_mutex);
+ p = last_iformat;
- // Note, format could be added after the first 2 checks but that implies that *p is no longer NULL
- while(p != &format->next && !format->next && avpriv_atomic_ptr_cas((void * volatile *)p, NULL, format))
+ while (*p)
p = &(*p)->next;
+ *p = format;
+ format->next = NULL;
+ last_iformat = &format->next;
- if (!format->next)
- last_iformat = &format->next;
+ ff_mutex_unlock(&iformat_register_mutex);
}
+static AVMutex oformat_register_mutex = AV_MUTEX_INITIALIZER;
+
void av_register_output_format(AVOutputFormat *format)
{
- AVOutputFormat **p = last_oformat;
+ AVOutputFormat **p;
+
+ ff_mutex_lock(&oformat_register_mutex);
+ p = last_oformat;
- // Note, format could be added after the first 2 checks but that implies that *p is no longer NULL
- while(p != &format->next && !format->next && avpriv_atomic_ptr_cas((void * volatile *)p, NULL, format))
+ while (*p)
p = &(*p)->next;
+ *p = format;
+ format->next = NULL;
+ last_oformat = &format->next;
- if (!format->next)
- last_oformat = &format->next;
+ ff_mutex_unlock(&oformat_register_mutex);
}
int av_match_ext(const char *filename, const char *extensions)