X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=src%2Fhb-mutex-private.hh;h=91c94388af499f1dc8e28a1b89007e46b8c8152c;hb=b9452bfc1696457e156e79037c863903da5454fc;hp=32b387c524a6a3caee72a09cc0c5d9b5abf56554;hpb=45bfa99034512e886d75b1d45a5a649647f4711f;p=framework%2Fuifw%2Fharfbuzz.git diff --git a/src/hb-mutex-private.hh b/src/hb-mutex-private.hh index 32b387c..91c9438 100644 --- a/src/hb-mutex-private.hh +++ b/src/hb-mutex-private.hh @@ -45,113 +45,67 @@ HB_BEGIN_DECLS #include -typedef volatile int hb_atomic_int_t; -#define hb_atomic_int_fetch_and_add(AI, V) g_atomic_int_exchange_and_add (&(AI), V) -#define hb_atomic_int_get(AI) g_atomic_int_get (&(AI)) -#define hb_atomic_int_set(AI, V) g_atomic_int_set (&(AI), V) - -typedef GStaticMutex hb_mutex_t; -#define HB_MUTEX_INIT G_STATIC_MUTEX_INIT -#define hb_mutex_init(M) g_static_mutex_init (M) -#define hb_mutex_lock(M) g_static_mutex_lock (M) -#define hb_mutex_trylock(M) g_static_mutex_trylock (M) -#define hb_mutex_unlock(M) g_static_mutex_unlock (M) -#define hb_mutex_free(M) g_static_mutex_free (M) +typedef GStaticMutex hb_mutex_impl_t; +#define HB_MUTEX_IMPL_INIT G_STATIC_MUTEX_INIT +#define hb_mutex_impl_init(M) g_static_mutex_init (M) +#define hb_mutex_impl_lock(M) g_static_mutex_lock (M) +#define hb_mutex_impl_unlock(M) g_static_mutex_unlock (M) +#define hb_mutex_impl_free(M) g_static_mutex_free (M) #elif defined(_MSC_VER) -#include - -typedef long hb_atomic_int_t; -#define hb_atomic_int_fetch_and_add(AI, V) _InterlockedExchangeAdd (&(AI), V) -#define hb_atomic_int_get(AI) (_ReadBarrier (), (AI)) -#define hb_atomic_int_set(AI, V) ((void) _InterlockedExchange (&(AI), (V))) - #include -typedef CRITICAL_SECTION hb_mutex_t; -#define HB_MUTEX_INIT { NULL, 0, 0, NULL, NULL, 0 } -#define hb_mutex_init(M) InitializeCriticalSection (M) -#define hb_mutex_lock(M) EnterCriticalSection (M) -#define hb_mutex_trylock(M) TryEnterCriticalSection (M) -#define hb_mutex_unlock(M) LeaveCriticalSection (M) -#define hb_mutex_free(M) DeleteCriticalSection (M) +typedef CRITICAL_SECTION hb_mutex_impl_t; +#define HB_MUTEX_IMPL_INIT { NULL, 0, 0, NULL, NULL, 0 } +#define hb_mutex_impl_init(M) InitializeCriticalSection (M) +#define hb_mutex_impl_lock(M) EnterCriticalSection (M) +#define hb_mutex_impl_unlock(M) LeaveCriticalSection (M) +#define hb_mutex_impl_free(M) DeleteCriticalSection (M) #else #warning "Could not find any system to define platform macros, library will NOT be thread-safe" -typedef volatile int hb_atomic_int_t; -#define hb_atomic_int_fetch_and_add(AI, V) ((AI) += (V), (AI) - (V)) -#define hb_atomic_int_get(AI) (AI) -#define hb_atomic_int_set(AI, V) ((void) ((AI) = (V))) - -typedef volatile int hb_mutex_t; -#define HB_MUTEX_INIT 0 -#define hb_mutex_init(M) ((void) (*(M) = 0)) -#define hb_mutex_lock(M) ((void) (*(M) = 1)) -#define hb_mutex_trylock(M) (*(M) = 1, 1) -#define hb_mutex_unlock(M) ((void) (*(M) = 0)) -#define hb_mutex_free(M) ((void) (*(M) = 2)) +typedef volatile int hb_mutex_impl_t; +#define HB_MUTEX_IMPL_INIT 0 +#define hb_mutex_impl_init(M) ((void) (*(M) = 0)) +#define hb_mutex_impl_lock(M) ((void) (*(M) = 1)) +#define hb_mutex_impl_unlock(M) ((void) (*(M) = 0)) +#define hb_mutex_impl_free(M) ((void) (*(M) = 2)) #endif -struct hb_static_mutex_t : hb_mutex_t +struct hb_mutex_t { - hb_static_mutex_t (void) { - hb_mutex_init (this); - } + hb_mutex_impl_t m; - inline void lock (void) { hb_mutex_lock (this); } - inline void unlock (void) { hb_mutex_unlock (this); } + inline void init (void) { hb_mutex_impl_init (&m); } + inline void lock (void) { hb_mutex_impl_lock (&m); } + inline void unlock (void) { hb_mutex_impl_unlock (&m); } + inline void free (void) { hb_mutex_impl_free (&m); } }; +#define HB_MUTEX_INIT {HB_MUTEX_IMPL_INIT} +#define hb_mutex_init(M) (M)->init () +#define hb_mutex_lock(M) (M)->lock () +#define hb_mutex_unlock(M) (M)->unlock () +#define hb_mutex_free(M) (M)->free () -HB_END_DECLS - -template -struct hb_static_threadsafe_set_t +struct hb_static_mutex_t : hb_mutex_t { - hb_lockable_set_t set; - hb_static_mutex_t lock; - - template - inline item_t *replace_or_insert (T v) - { - return set.replace_or_insert (v, lock); - } - - template - inline void remove (T v) - { - set.remove (v, lock); - } - - template - inline bool find (T v, item_t *i) - { - return set.find (v, i, lock); - } - - template - inline item_t *find_or_insert (T v) - { - return set.find_or_insert (v, lock); - } - - void finish (void) - { - set.finish (lock); - } -}; + hb_static_mutex_t (void) { this->init (); } + ~hb_static_mutex_t (void) { this->free (); } + private: + NO_COPY (hb_static_mutex_t); +}; -HB_BEGIN_DECLS HB_END_DECLS