diff options
| author | Matthias Vogelgesang <matthias.vogelgesang@ipe.fzk.de> | 2011-03-17 10:13:42 +0100 | 
|---|---|---|
| committer | Matthias Vogelgesang <matthias.vogelgesang@ipe.fzk.de> | 2011-03-17 10:13:42 +0100 | 
| commit | 5b80e3c687fb2b47b06d9ffe6ac07bec475d812a (patch) | |
| tree | e3b8fb492e3cd01d0a071e7872b50e1dee3cc7f1 | |
| parent | 31b20f08150907fadc05e5054f4ffd04f68d2144 (diff) | |
| download | uca-5b80e3c687fb2b47b06d9ffe6ac07bec475d812a.tar.gz uca-5b80e3c687fb2b47b06d9ffe6ac07bec475d812a.tar.bz2 uca-5b80e3c687fb2b47b06d9ffe6ac07bec475d812a.tar.xz uca-5b80e3c687fb2b47b06d9ffe6ac07bec475d812a.zip | |
Make uca_init() and uca_destroy() thread-safe via pthreads
| -rw-r--r-- | src/CMakeLists.txt | 11 | ||||
| -rw-r--r-- | src/config.h.in | 2 | ||||
| -rw-r--r-- | src/uca.c | 47 | 
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 @@ -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) | 
