Commit e599d1ed authored by vasil's avatar vasil

branches/zip:

Simplify the compile time checks by splittig them into 5 independent checks:

* Whether GCC atomics are available
* Whether pthread_t can be used by GCC atomics
* Whether Solaris libc atomics are available
* Whether pthread_t can be used by Solaris libs atomics
* Checking the size of pthread_t
parent 881c6ef4
...@@ -38,19 +38,11 @@ MYSQL_PLUGIN_ACTIONS(innobase, [ ...@@ -38,19 +38,11 @@ MYSQL_PLUGIN_ACTIONS(innobase, [
irix*|osf*|sysv5uw7*|openbsd*) irix*|osf*|sysv5uw7*|openbsd*)
CFLAGS="$CFLAGS -DUNIV_MUST_NOT_INLINE";; CFLAGS="$CFLAGS -DUNIV_MUST_NOT_INLINE";;
*solaris*|*SunOS*) *solaris*|*SunOS*)
# Begin Solaris atomic function checks
AC_CHECK_FUNCS(atomic_cas_ulong atomic_cas_32 \
atomic_cas_64 atomic_add_long,
AC_DEFINE(
[HAVE_SOLARIS_ATOMICS],
[1],
[Define to 1 if Solaris supports \
atomic functions.]))
### End Solaris atomic function checks
CFLAGS="$CFLAGS -DUNIV_SOLARIS";; CFLAGS="$CFLAGS -DUNIV_SOLARIS";;
esac esac
INNODB_DYNAMIC_CFLAGS="-DMYSQL_DYNAMIC_PLUGIN" INNODB_DYNAMIC_CFLAGS="-DMYSQL_DYNAMIC_PLUGIN"
case "$target_cpu" in case "$target_cpu" in
x86_64) x86_64)
# The AMD64 ABI forbids absolute addresses in shared libraries # The AMD64 ABI forbids absolute addresses in shared libraries
...@@ -63,6 +55,7 @@ MYSQL_PLUGIN_ACTIONS(innobase, [ ...@@ -63,6 +55,7 @@ MYSQL_PLUGIN_ACTIONS(innobase, [
AC_SUBST(INNODB_DYNAMIC_CFLAGS) AC_SUBST(INNODB_DYNAMIC_CFLAGS)
AC_MSG_CHECKING(whether GCC atomic builtins are available) AC_MSG_CHECKING(whether GCC atomic builtins are available)
# either define HAVE_IB_GCC_ATOMIC_BUILTINS or not
AC_TRY_RUN( AC_TRY_RUN(
[ [
int main() int main()
...@@ -113,6 +106,7 @@ MYSQL_PLUGIN_ACTIONS(innobase, [ ...@@ -113,6 +106,7 @@ MYSQL_PLUGIN_ACTIONS(innobase, [
) )
AC_MSG_CHECKING(whether pthread_t can be used by GCC atomic builtins) AC_MSG_CHECKING(whether pthread_t can be used by GCC atomic builtins)
# either define HAVE_ATOMIC_PTHREAD_T or not
AC_TRY_RUN( AC_TRY_RUN(
[ [
#include <pthread.h> #include <pthread.h>
...@@ -142,38 +136,62 @@ MYSQL_PLUGIN_ACTIONS(innobase, [ ...@@ -142,38 +136,62 @@ MYSQL_PLUGIN_ACTIONS(innobase, [
] ]
) )
# Try using solaris atomics on SunOS if GCC atomics are not available AC_MSG_CHECKING(whether Solaris libc atomic functions are available)
AC_CHECK_DECLS( # either define HAVE_SOLARIS_ATOMICS or not
[HAVE_ATOMIC_PTHREAD_T], AC_CHECK_FUNCS(atomic_add_long \
[ atomic_cas_32 \
AC_MSG_NOTICE(no need to check pthread_t size) atomic_cas_64 \
], atomic_cas_ulong,
[
AC_CHECK_DECLS( AC_DEFINE([HAVE_SOLARIS_ATOMICS], [1],
[HAVE_SOLARIS_ATOMICS], [Define to 1 if Solaris libc atomic functions \
[ are available])
AC_MSG_CHECKING(checking if pthread_t type is integral) )
AC_MSG_CHECKING(whether pthread_t can be used by Solaris libc atomic functions)
# either define HAVE_ATOMIC_PTHREAD_T or not
AC_TRY_RUN( AC_TRY_RUN(
[ [
#include <pthread.h> #include <pthread.h>
int main() #include <string.h>
{
pthread_t x = 0; int main(int argc, char** argv) {
return(0); pthread_t x1;
pthread_t x2;
pthread_t x3;
memset(&x1, 0x0, sizeof(x1));
memset(&x2, 0x0, sizeof(x2));
memset(&x3, 0x0, sizeof(x3));
if (sizeof(pthread_t) == 4) {
atomic_cas_32(&x1, x2, x3);
} else if (sizeof(pthread_t) == 8) {
atomic_cas_64(&x1, x2, x3);
} else {
return(1);
} }
], ],
[ [
AC_DEFINE([HAVE_ATOMIC_PTHREAD_T], [1], AC_DEFINE([HAVE_ATOMIC_PTHREAD_T], [1],
[pthread_t can be used by solaris atomics]) [pthread_t can be used by solaris atomics])
AC_MSG_RESULT(yes) AC_MSG_RESULT(yes)
# size of pthread_t is needed for typed solaris atomics
AC_CHECK_SIZEOF([pthread_t], [], [#include <pthread.h>])
], ],
[ [
AC_MSG_RESULT(no) AC_MSG_RESULT(no)
]) ]
]) )
])
# this is needed to know which one of atomic_cas_32() or atomic_cas_64()
# to use in the source
AC_CHECK_SIZEOF([pthread_t], [], [#include <pthread.h>])
# Check for x86 PAUSE instruction # Check for x86 PAUSE instruction
AC_MSG_CHECKING(for x86 PAUSE instruction) AC_MSG_CHECKING(for x86 PAUSE instruction)
# We have to actually try running the test program, because of a bug # We have to actually try running the test program, because of a bug
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment