summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorMatthias Vogelgesang <matthias.vogelgesang@ipe.fzk.de>2011-03-17 10:13:42 +0100
committerMatthias Vogelgesang <matthias.vogelgesang@ipe.fzk.de>2011-03-17 10:13:42 +0100
commit5b80e3c687fb2b47b06d9ffe6ac07bec475d812a (patch)
treee3b8fb492e3cd01d0a071e7872b50e1dee3cc7f1 /src
parent31b20f08150907fadc05e5054f4ffd04f68d2144 (diff)
downloadlibuca-5b80e3c687fb2b47b06d9ffe6ac07bec475d812a.tar.gz
libuca-5b80e3c687fb2b47b06d9ffe6ac07bec475d812a.tar.bz2
libuca-5b80e3c687fb2b47b06d9ffe6ac07bec475d812a.tar.xz
libuca-5b80e3c687fb2b47b06d9ffe6ac07bec475d812a.zip
Make uca_init() and uca_destroy() thread-safe via pthreads
Diffstat (limited to 'src')
-rw-r--r--src/CMakeLists.txt11
-rw-r--r--src/config.h.in2
-rw-r--r--src/uca.c47
3 files changed, 36 insertions, 24 deletions
diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt
index 9c25ca7..df1ed43 100644
--- a/src/CMakeLists.txt
+++ b/src/CMakeLists.txt
@@ -29,8 +29,7 @@ find_package(ClSerMe4)
# --- Miscellanous packages
find_package(PkgConfig)
-
-pkg_check_modules(MJSON mjson-1.2)
+find_package(Threads)
# --- Build options -----------------------------------------------------------
@@ -113,15 +112,13 @@ if (HAVE_DUMMY_CAMERA)
)
endif()
-if (MJSON_FOUND)
- set(HAVE_MJSON TRUE)
+if (Threads_FOUND)
+ set(HAVE_PTHREADS TRUE)
set(uca_LIBS
${uca_LIBS}
- ${MJSON_LIBRARIES}
+ ${CMAKE_THREAD_LIBS_INIT}
)
-
- include_directories(${MJSON_INCLUDE_DIRS})
endif()
# --- Configure step
diff --git a/src/config.h.in b/src/config.h.in
index dcf8696..43736b4 100644
--- a/src/config.h.in
+++ b/src/config.h.in
@@ -8,4 +8,4 @@
#cmakedefine HAVE_DUMMY_CAMERA
-#cmakedefine HAVE_MJSON
+#cmakedefine HAVE_PTHREADS
diff --git a/src/uca.c b/src/uca.c
index 8cbfc17..a7a1ea6 100644
--- a/src/uca.c
+++ b/src/uca.c
@@ -6,8 +6,8 @@
#include "uca-cam.h"
#include "uca-grabber.h"
-#ifdef HAVE_MJSON
-#include "json.h"
+#ifdef HAVE_PTHREADS
+#include <pthread.h>
#endif
#ifdef HAVE_DUMMY_CAMERA
@@ -30,10 +30,6 @@
#include "cameras/ipe.h"
#endif
-#ifdef HAVE_PHOTRON_FASTCAM
-#include "cameras/photron.h"
-#endif
-
const char *uca_unit_map[] = {
"px",
"bits",
@@ -90,10 +86,27 @@ static struct uca_property_t property_map[UCA_PROP_LAST+1] = {
{ NULL, 0, 0, 0 }
};
+
+#ifdef HAVE_PTHREADS
+static pthread_mutex_t g_uca_init_lock = PTHREAD_MUTEX_INITIALIZER;
+#define uca_lock() pthread_mutex_lock((&g_uca_init_lock))
+#define uca_unlock() pthread_mutex_unlock((&g_uca_init_lock))
+#else
+#define uca_lock(lock)
+#define uca_unlock(lock)
+#endif
+
+struct uca_t *g_uca = NULL;
+
struct uca_t *uca_init(const char *config_filename)
{
- struct uca_t *uca = (struct uca_t *) malloc(sizeof(struct uca_t));
- uca->cameras = NULL;
+ uca_lock();
+ if (g_uca != NULL) {
+ uca_unlock();
+ return g_uca;
+ }
+ g_uca = (struct uca_t *) malloc(sizeof(struct uca_t));
+ g_uca->cameras = NULL;
uca_grabber_init grabber_inits[] = {
#ifdef HAVE_ME4
@@ -112,9 +125,6 @@ struct uca_t *uca_init(const char *config_filename)
#ifdef HAVE_IPE_CAMERA
uca_ipe_init,
#endif
-#ifdef HAVE_PH
- uca_photron_init,
-#endif
#ifdef HAVE_DUMMY_CAMERA
uca_dummy_init,
#endif
@@ -137,7 +147,7 @@ struct uca_t *uca_init(const char *config_filename)
* therefore we also probe each camera against the NULL grabber. However,
* each camera must make sure to check for such a situation. */
- uca->grabbers = grabber;
+ g_uca->grabbers = grabber;
if (grabber != NULL)
grabber->next = NULL;
@@ -150,7 +160,7 @@ struct uca_t *uca_init(const char *config_filename)
uca_cam_init init = cam_inits[i];
if (init(&cam, grabber) != UCA_ERR_CAM_NOT_FOUND) {
if (current == NULL)
- uca->cameras = current = cam;
+ g_uca->cameras = current = cam;
else {
current->next = cam;
current = cam;
@@ -160,15 +170,19 @@ struct uca_t *uca_init(const char *config_filename)
i++;
}
- if (uca->cameras == NULL) {
- free(uca);
+ if (g_uca->cameras == NULL) {
+ free(g_uca);
+ g_uca = NULL;
+ uca_unlock();
return NULL;
}
- return uca;
+ uca_unlock();
+ return g_uca;
}
void uca_destroy(struct uca_t *uca)
{
+ uca_lock();
if (uca != NULL) {
struct uca_camera_t *cam = uca->cameras, *tmp;
while (cam != NULL) {
@@ -188,6 +202,7 @@ void uca_destroy(struct uca_t *uca)
free(uca);
}
+ uca_unlock();
}
enum uca_property_ids uca_get_property_id(const char *property_name)