Add gcc intrinsics implementations for atomic and mutex
This commit is contained in:
parent
d970d2899b
commit
cdafe3a7d8
|
@ -52,8 +52,8 @@ AC_SUBST(HB_LIBTOOL_VERSION_INFO)
|
||||||
dnl GTK_DOC_CHECK([1.15],[--flavour no-tmpl])
|
dnl GTK_DOC_CHECK([1.15],[--flavour no-tmpl])
|
||||||
|
|
||||||
# Functions and headers
|
# Functions and headers
|
||||||
AC_CHECK_FUNCS(atexit mprotect sysconf getpagesize mmap _setmode isatty)
|
AC_CHECK_FUNCS(atexit mprotect sysconf getpagesize sched_yield mmap _setmode isatty)
|
||||||
AC_CHECK_HEADERS(unistd.h sys/mman.h io.h)
|
AC_CHECK_HEADERS(unistd.h sys/mman.h sched.h io.h)
|
||||||
|
|
||||||
# Compiler flags
|
# Compiler flags
|
||||||
AC_CANONICAL_HOST
|
AC_CANONICAL_HOST
|
||||||
|
|
|
@ -72,13 +72,20 @@ typedef int hb_atomic_int_t;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
#else
|
#elif !defined(HB_NO_MT)
|
||||||
|
|
||||||
|
#define HB_ATOMIC_INT_NIL 1 /* Warn that fallback implementation is in use. */
|
||||||
|
typedef volatile int hb_atomic_int_t;
|
||||||
|
#define hb_atomic_int_add(AI, V) (((AI) += (V)) - (V))
|
||||||
|
|
||||||
|
|
||||||
|
#else /* HB_NO_MT */
|
||||||
|
|
||||||
#define HB_ATOMIC_INT_NIL 1
|
|
||||||
typedef int hb_atomic_int_t;
|
typedef int hb_atomic_int_t;
|
||||||
#define hb_atomic_int_add(AI, V) (((AI) += (V)) - (V))
|
#define hb_atomic_int_add(AI, V) (((AI) += (V)) - (V))
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
/* TODO Add tracing. */
|
||||||
|
|
||||||
#endif /* HB_ATOMIC_PRIVATE_HH */
|
#endif /* HB_ATOMIC_PRIVATE_HH */
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
/*
|
/*
|
||||||
* Copyright © 2007 Chris Wilson
|
* Copyright © 2007 Chris Wilson
|
||||||
* Copyright © 2009,2010 Red Hat, Inc.
|
* Copyright © 2009,2010 Red Hat, Inc.
|
||||||
* Copyright © 2011 Google, Inc.
|
* Copyright © 2011,2012 Google, Inc.
|
||||||
*
|
*
|
||||||
* This is part of HarfBuzz, a text shaping library.
|
* This is part of HarfBuzz, a text shaping library.
|
||||||
*
|
*
|
||||||
|
@ -53,7 +53,7 @@ typedef CRITICAL_SECTION hb_mutex_impl_t;
|
||||||
#define hb_mutex_impl_finish(M) DeleteCriticalSection (M)
|
#define hb_mutex_impl_finish(M) DeleteCriticalSection (M)
|
||||||
|
|
||||||
|
|
||||||
#elif !defined(HB_NO_MT) && defined(__APPLE__)
|
#elif !defined(HB_NO_MT) && (defined(HAVE_PTHREAD) || defined(__APPLE__))
|
||||||
|
|
||||||
#include <pthread.h>
|
#include <pthread.h>
|
||||||
typedef pthread_mutex_t hb_mutex_impl_t;
|
typedef pthread_mutex_t hb_mutex_impl_t;
|
||||||
|
@ -75,15 +75,50 @@ typedef GStaticMutex hb_mutex_impl_t;
|
||||||
#define hb_mutex_impl_finish(M) g_static_mutex_free (M)
|
#define hb_mutex_impl_finish(M) g_static_mutex_free (M)
|
||||||
|
|
||||||
|
|
||||||
#else
|
#elif !defined(HB_NO_MT) && defined(__GNUC__)
|
||||||
|
|
||||||
#define HB_MUTEX_IMPL_NIL 1
|
#if defined(HAVE_SCHED_H) && defined(HAVE_SCHED_YIELD)
|
||||||
|
# include <sched.h>
|
||||||
|
# define HB_SCHED_YIELD() sched_yield ()
|
||||||
|
#else
|
||||||
|
# define HB_SCHED_YIELD() HB_STMT_START {} HB_STMT_END
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* This actually is not a totally awful implementation. */
|
||||||
typedef volatile int hb_mutex_impl_t;
|
typedef volatile int hb_mutex_impl_t;
|
||||||
#define HB_MUTEX_IMPL_INIT 0
|
#define HB_MUTEX_IMPL_INIT 0
|
||||||
#define hb_mutex_impl_init(M) ((void) (*(M) = 0))
|
#define hb_mutex_impl_init(M) *(M) = 0
|
||||||
#define hb_mutex_impl_lock(M) ((void) (*(M) = 1))
|
#define hb_mutex_impl_lock(M) HB_STMT_START { while (__sync_lock_test_and_set((M), 1)) HB_SCHED_YIELD (); } HB_STMT_END
|
||||||
#define hb_mutex_impl_unlock(M) ((void) (*(M) = 0))
|
#define hb_mutex_impl_unlock(M) __sync_lock_release (M)
|
||||||
#define hb_mutex_impl_finish(M) ((void) (*(M) = 2))
|
#define hb_mutex_impl_finish(M) HB_STMT_START {} HB_STMT_END
|
||||||
|
|
||||||
|
|
||||||
|
#elif !defined(HB_NO_MT)
|
||||||
|
|
||||||
|
#if defined(HAVE_SCHED_H) && defined(HAVE_SCHED_YIELD)
|
||||||
|
# include <sched.h>
|
||||||
|
# define HB_SCHED_YIELD() sched_yield ()
|
||||||
|
#else
|
||||||
|
# define HB_SCHED_YIELD() HB_STMT_START {} HB_STMT_END
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#define HB_MUTEX_INT_NIL 1 /* Warn that fallback implementation is in use. */
|
||||||
|
typedef volatile int hb_mutex_impl_t;
|
||||||
|
#define HB_MUTEX_IMPL_INIT 0
|
||||||
|
#define hb_mutex_impl_init(M) *(M) = 0
|
||||||
|
#define hb_mutex_impl_lock(M) HB_STMT_START { while (*(M)) HB_SCHED_YIELD (); (*(M))++; } HB_STMT_END
|
||||||
|
#define hb_mutex_impl_unlock(M) (*(M))--;
|
||||||
|
#define hb_mutex_impl_finish(M) HB_STMT_START {} HB_STMT_END
|
||||||
|
|
||||||
|
|
||||||
|
#else /* HB_NO_MT */
|
||||||
|
|
||||||
|
typedef int hb_mutex_impl_t;
|
||||||
|
#define HB_MUTEX_IMPL_INIT 0
|
||||||
|
#define hb_mutex_impl_init(M) HB_STMT_START {} HB_STMT_END
|
||||||
|
#define hb_mutex_impl_lock(M) HB_STMT_START {} HB_STMT_END
|
||||||
|
#define hb_mutex_impl_unlock(M) HB_STMT_START {} HB_STMT_END
|
||||||
|
#define hb_mutex_impl_finish(M) HB_STMT_START {} HB_STMT_END
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@ -91,6 +126,8 @@ typedef volatile int hb_mutex_impl_t;
|
||||||
#define HB_MUTEX_INIT {HB_MUTEX_IMPL_INIT}
|
#define HB_MUTEX_INIT {HB_MUTEX_IMPL_INIT}
|
||||||
struct hb_mutex_t
|
struct hb_mutex_t
|
||||||
{
|
{
|
||||||
|
/* TODO Add tracing. */
|
||||||
|
|
||||||
hb_mutex_impl_t m;
|
hb_mutex_impl_t m;
|
||||||
|
|
||||||
inline void init (void) { hb_mutex_impl_init (&m); }
|
inline void init (void) { hb_mutex_impl_init (&m); }
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
/*
|
/*
|
||||||
* Copyright © 2007 Chris Wilson
|
* Copyright © 2007 Chris Wilson
|
||||||
* Copyright © 2009,2010 Red Hat, Inc.
|
* Copyright © 2009,2010 Red Hat, Inc.
|
||||||
* Copyright © 2011 Google, Inc.
|
* Copyright © 2011,2012 Google, Inc.
|
||||||
*
|
*
|
||||||
* This is part of HarfBuzz, a text shaping library.
|
* This is part of HarfBuzz, a text shaping library.
|
||||||
*
|
*
|
||||||
|
@ -68,6 +68,8 @@ struct hb_reference_count_t
|
||||||
#define HB_USER_DATA_ARRAY_INIT {HB_LOCKABLE_SET_INIT}
|
#define HB_USER_DATA_ARRAY_INIT {HB_LOCKABLE_SET_INIT}
|
||||||
struct hb_user_data_array_t
|
struct hb_user_data_array_t
|
||||||
{
|
{
|
||||||
|
/* TODO Add tracing. */
|
||||||
|
|
||||||
struct hb_user_data_item_t {
|
struct hb_user_data_item_t {
|
||||||
hb_user_data_key_t *key;
|
hb_user_data_key_t *key;
|
||||||
void *data;
|
void *data;
|
||||||
|
|
|
@ -28,23 +28,23 @@
|
||||||
#include "hb-mutex-private.hh"
|
#include "hb-mutex-private.hh"
|
||||||
|
|
||||||
|
|
||||||
#if !defined(HB_NO_MT) && defined(HB_ATOMIC_INT_NIL)
|
#if defined(HB_ATOMIC_INT_NIL)
|
||||||
#ifdef _MSC_VER
|
#ifdef _MSC_VER
|
||||||
#pragma message("Could not find any system to define atomic_int macros, library will NOT be thread-safe")
|
#pragma message("Could not find any system to define atomic_int macros, library may NOT be thread-safe")
|
||||||
#else
|
#else
|
||||||
#warning "Could not find any system to define atomic_int macros, library will NOT be thread-safe"
|
#warning "Could not find any system to define atomic_int macros, library may NOT be thread-safe"
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if !defined(HB_NO_MT) && defined(HB_MUTEX_IMPL_NIL)
|
#if defined(HB_MUTEX_IMPL_NIL)
|
||||||
#ifdef _MSC_VER
|
#ifdef _MSC_VER
|
||||||
#pragma message("Could not find any system to define mutex macros, library will NOT be thread-safe")
|
#pragma message("Could not find any system to define mutex macros, library may NOT be thread-safe")
|
||||||
#else
|
#else
|
||||||
#warning "Could not find any system to define mutex macros, library will NOT be thread-safe"
|
#warning "Could not find any system to define mutex macros, library may NOT be thread-safe"
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if !defined(HB_NO_MT) && (defined(HB_ATOMIC_INT_NIL) || defined(HB_MUTEX_IMPL_NIL))
|
#if defined(HB_ATOMIC_INT_NIL) || defined(HB_MUTEX_IMPL_NIL)
|
||||||
#ifdef _MSC_VER
|
#ifdef _MSC_VER
|
||||||
#pragma message("To suppress these warnings, define HB_NO_MT")
|
#pragma message("To suppress these warnings, define HB_NO_MT")
|
||||||
#else
|
#else
|
||||||
|
|
Loading…
Reference in New Issue