[atomic] Remove old Intel primitives implementation
This commit is contained in:
parent
711c241f6c
commit
7099a6dca1
|
@ -21,7 +21,7 @@ jobs:
|
||||||
TOKEN: ${{ secrets.COVERITY_SCAN_TOKEN }}
|
TOKEN: ${{ secrets.COVERITY_SCAN_TOKEN }}
|
||||||
|
|
||||||
# ideally we should've used meson and ninja here but it complains about coverage or something
|
# ideally we should've used meson and ninja here but it complains about coverage or something
|
||||||
- run: cov-analysis-linux64/bin/cov-build --dir cov-int clang src/hb-*.cc -DHAVE_FREETYPE -DHAVE_GRAPHITE2 -DHAVE_GLIB -DHAVE_ICU `pkg-config --cflags freetype2 graphite2 glib-2.0 icu-uc` -DHAVE_INTEL_ATOMIC_PRIMITIVES -DHAVE_ROUNDF -DHAVE_SYS_MMAN_H -DHAVE_UNISTD_H -DHAVE_GETPAGESIZE -DHB_EXPERIMENTAL_API -c
|
- run: cov-analysis-linux64/bin/cov-build --dir cov-int clang src/hb-*.cc -DHAVE_FREETYPE -DHAVE_GRAPHITE2 -DHAVE_GLIB -DHAVE_ICU `pkg-config --cflags freetype2 graphite2 glib-2.0 icu-uc` -DHAVE_ROUNDF -DHAVE_SYS_MMAN_H -DHAVE_UNISTD_H -DHAVE_GETPAGESIZE -DHB_EXPERIMENTAL_API -c
|
||||||
|
|
||||||
- run: tar czvf harfbuzz.tgz cov-int
|
- run: tar czvf harfbuzz.tgz cov-int
|
||||||
|
|
||||||
|
|
|
@ -407,20 +407,6 @@ if (HB_HAVE_GOBJECT)
|
||||||
endif ()
|
endif ()
|
||||||
|
|
||||||
## Atomic ops availability detection
|
## Atomic ops availability detection
|
||||||
file(WRITE "${PROJECT_BINARY_DIR}/try_compile_intel_atomic_primitives.c"
|
|
||||||
" void memory_barrier (void) { __sync_synchronize (); }
|
|
||||||
int atomic_add (int *i) { return __sync_fetch_and_add (i, 1); }
|
|
||||||
int mutex_trylock (int *m) { return __sync_lock_test_and_set (m, 1); }
|
|
||||||
void mutex_unlock (int *m) { __sync_lock_release (m); }
|
|
||||||
int main () { return 0; }
|
|
||||||
")
|
|
||||||
try_compile(HB_HAVE_INTEL_ATOMIC_PRIMITIVES
|
|
||||||
${PROJECT_BINARY_DIR}/try_compile_intel_atomic_primitives
|
|
||||||
${PROJECT_BINARY_DIR}/try_compile_intel_atomic_primitives.c)
|
|
||||||
if (HB_HAVE_INTEL_ATOMIC_PRIMITIVES)
|
|
||||||
add_definitions(-DHAVE_INTEL_ATOMIC_PRIMITIVES)
|
|
||||||
endif ()
|
|
||||||
|
|
||||||
file(WRITE "${PROJECT_BINARY_DIR}/try_compile_solaris_atomic_ops.c"
|
file(WRITE "${PROJECT_BINARY_DIR}/try_compile_solaris_atomic_ops.c"
|
||||||
" #include <atomic.h>
|
" #include <atomic.h>
|
||||||
/* This requires Solaris Studio 12.2 or newer: */
|
/* This requires Solaris Studio 12.2 or newer: */
|
||||||
|
|
16
configure.ac
16
configure.ac
|
@ -417,22 +417,6 @@ AM_CONDITIONAL(HAVE_CORETEXT, $have_coretext)
|
||||||
|
|
||||||
dnl ===========================================================================
|
dnl ===========================================================================
|
||||||
|
|
||||||
AC_CACHE_CHECK([for Intel atomic primitives], hb_cv_have_intel_atomic_primitives, [
|
|
||||||
hb_cv_have_intel_atomic_primitives=false
|
|
||||||
AC_TRY_LINK([
|
|
||||||
void memory_barrier (void) { __sync_synchronize (); }
|
|
||||||
int atomic_add (int *i) { return __sync_fetch_and_add (i, 1); }
|
|
||||||
int mutex_trylock (int *m) { return __sync_lock_test_and_set (m, 1); }
|
|
||||||
void mutex_unlock (int *m) { __sync_lock_release (m); }
|
|
||||||
], [], hb_cv_have_intel_atomic_primitives=true
|
|
||||||
)
|
|
||||||
])
|
|
||||||
if $hb_cv_have_intel_atomic_primitives; then
|
|
||||||
AC_DEFINE(HAVE_INTEL_ATOMIC_PRIMITIVES, 1, [Have Intel __sync_* atomic primitives])
|
|
||||||
fi
|
|
||||||
|
|
||||||
dnl ===========================================================================
|
|
||||||
|
|
||||||
AC_CACHE_CHECK([for Solaris atomic operations], hb_cv_have_solaris_atomic_ops, [
|
AC_CACHE_CHECK([for Solaris atomic operations], hb_cv_have_solaris_atomic_ops, [
|
||||||
hb_cv_have_solaris_atomic_ops=false
|
hb_cv_have_solaris_atomic_ops=false
|
||||||
AC_TRY_LINK([
|
AC_TRY_LINK([
|
||||||
|
|
|
@ -1,6 +0,0 @@
|
||||||
void memory_barrier (void) { __sync_synchronize (); }
|
|
||||||
int atomic_add (int *i) { return __sync_fetch_and_add (i, 1); }
|
|
||||||
int mutex_trylock (int *m) { return __sync_lock_test_and_set (m, 1); }
|
|
||||||
void mutex_unlock (int *m) { __sync_lock_release (m); }
|
|
||||||
|
|
||||||
int main(void) { return 0;}
|
|
|
@ -334,10 +334,6 @@ foreach check : check_funcs
|
||||||
endif
|
endif
|
||||||
endforeach
|
endforeach
|
||||||
|
|
||||||
if cpp.links(files('meson-cc-tests/intel-atomic-primitives-test.c'), name: 'Intel atomics')
|
|
||||||
conf.set('HAVE_INTEL_ATOMIC_PRIMITIVES', 1)
|
|
||||||
endif
|
|
||||||
|
|
||||||
if cpp.links(files('meson-cc-tests/solaris-atomic-operations.c'), name: 'Solaris atomic ops')
|
if cpp.links(files('meson-cc-tests/solaris-atomic-operations.c'), name: 'Solaris atomic ops')
|
||||||
conf.set('HAVE_SOLARIS_ATOMIC_OPS', 1)
|
conf.set('HAVE_SOLARIS_ATOMIC_OPS', 1)
|
||||||
endif
|
endif
|
||||||
|
|
|
@ -123,15 +123,6 @@ static_assert ((sizeof (LONG) == sizeof (int)), "");
|
||||||
#define hb_atomic_ptr_impl_cmpexch(P,O,N) (InterlockedCompareExchangePointer ((P), (N), (O)) == (O))
|
#define hb_atomic_ptr_impl_cmpexch(P,O,N) (InterlockedCompareExchangePointer ((P), (N), (O)) == (O))
|
||||||
|
|
||||||
|
|
||||||
#elif !defined(HB_NO_MT) && defined(HAVE_INTEL_ATOMIC_PRIMITIVES)
|
|
||||||
|
|
||||||
#define _hb_memory_barrier() __sync_synchronize ()
|
|
||||||
|
|
||||||
#define hb_atomic_int_impl_add(AI, V) __sync_fetch_and_add ((AI), (V))
|
|
||||||
|
|
||||||
#define hb_atomic_ptr_impl_cmpexch(P,O,N) __sync_bool_compare_and_swap ((P), (O), (N))
|
|
||||||
|
|
||||||
|
|
||||||
#elif !defined(HB_NO_MT) && defined(HAVE_SOLARIS_ATOMIC_OPS)
|
#elif !defined(HB_NO_MT) && defined(HAVE_SOLARIS_ATOMIC_OPS)
|
||||||
|
|
||||||
#include <atomic.h>
|
#include <atomic.h>
|
||||||
|
|
Loading…
Reference in New Issue