123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156 |
- Patch borrowed from
- http://code.google.com/p/minimyth/source/browse/trunk/gar-minimyth/script/db/mysql/files/mysql-5.1.47-ac_cache_check.patch?r=6493.
- It allows to override through ac_cv_* variables various checks that
- cannot be performed when cross-compiling.
- Signed-off-by: Thomas Petazzoni <thomas.petazzoni@free-electrons.com>
- ---
- storage/innodb_plugin/plug.in | 59 ++++++++++++++++++++++++++++--------------
- 1 file changed, 40 insertions(+), 19 deletions(-)
- Index: mysql-5.1.53/storage/innodb_plugin/plug.in
- ===================================================================
- --- mysql-5.1.53.orig/storage/innodb_plugin/plug.in
- +++ mysql-5.1.53/storage/innodb_plugin/plug.in
- @@ -53,9 +53,10 @@
- esac
- AC_SUBST(INNODB_DYNAMIC_CFLAGS)
-
- - AC_MSG_CHECKING(whether GCC atomic builtins are available)
- + AC_CACHE_CHECK([whether GCC atomic builtins are available],
- + [ac_cv_have_decl_HAVE_IB_GCC_ATOMIC_BUILTINS],
- # either define HAVE_IB_GCC_ATOMIC_BUILTINS or not
- - AC_TRY_RUN(
- + [AC_TRY_RUN(
- [
- int main()
- {
- @@ -95,18 +96,23 @@
- }
- ],
- [
- - AC_DEFINE([HAVE_IB_GCC_ATOMIC_BUILTINS], [1],
- - [GCC atomic builtins are available])
- AC_MSG_RESULT(yes)
- + ac_cv_have_decl_HAVE_IB_GCC_ATOMIC_BUILTINS=yes
- ],
- [
- AC_MSG_RESULT(no)
- + ac_cv_have_decl_HAVE_IB_GCC_ATOMIC_BUILTINS=no
- ]
- - )
- + )])
- + if test "x$ac_cv_have_decl_HAVE_IB_GCC_ATOMIC_BUILTINS"= "xyes" ; then
- + AC_DEFINE([HAVE_IB_GCC_ATOMIC_BUILTINS], [1],
- + [GCC atomic builtins are available])
- + fi
-
- - AC_MSG_CHECKING(whether pthread_t can be used by GCC atomic builtins)
- + AC_CACHE_CHECK([whether pthread_t can be used by GCC atomic builtins],
- + [ac_cv_have_decl_HAVE_IB_ATOMIC_PTHREAD_T_GCC],
- # either define HAVE_IB_ATOMIC_PTHREAD_T_GCC or not
- - AC_TRY_RUN(
- + [AC_TRY_RUN(
- [
- #include <pthread.h>
- #include <string.h>
- @@ -126,14 +132,18 @@
- }
- ],
- [
- - AC_DEFINE([HAVE_IB_ATOMIC_PTHREAD_T_GCC], [1],
- - [pthread_t can be used by GCC atomic builtins])
- AC_MSG_RESULT(yes)
- + ac_cv_have_decl_HAVE_IB_ATOMIC_PTHREAD_T_GCC=yes
- ],
- [
- AC_MSG_RESULT(no)
- + ac_cv_have_decl_HAVE_IB_ATOMIC_PTHREAD_T_GCC=no
- ]
- - )
- + )])
- + if test "x$ac_cv_have_decl_HAVE_IB_ATOMIC_PTHREAD_T_GCC"= "xyes" ; then
- + AC_DEFINE([HAVE_IB_ATOMIC_PTHREAD_T_GCC], [1],
- + [pthread_t can be used by GCC atomic builtins])
- + fi
-
- AC_MSG_CHECKING(whether Solaris libc atomic functions are available)
- # either define HAVE_IB_SOLARIS_ATOMICS or not
- @@ -148,9 +158,10 @@
- are available])
- )
-
- - AC_MSG_CHECKING(whether pthread_t can be used by Solaris libc atomic functions)
- + AC_CACHE_CHECK([whether pthread_t can be used by Solaris libc atomic functions],
- + [ac_cv_have_decl_HAVE_IB_ATOMIC_PTHREAD_T_SOLARIS],
- # either define HAVE_IB_ATOMIC_PTHREAD_T_SOLARIS or not
- - AC_TRY_RUN(
- + [AC_TRY_RUN(
- [
- #include <pthread.h>
- #include <string.h>
- @@ -181,28 +192,33 @@
- }
- ],
- [
- - AC_DEFINE([HAVE_IB_ATOMIC_PTHREAD_T_SOLARIS], [1],
- - [pthread_t can be used by solaris atomics])
- AC_MSG_RESULT(yes)
- + ac_cv_have_decl_HAVE_IB_ATOMIC_PTHREAD_T_SOLARIS=yes
- ],
- [
- AC_MSG_RESULT(no)
- + ac_cv_have_decl_HAVE_IB_ATOMIC_PTHREAD_T_SOLARIS=no
- ]
- - )
- + )])
- + if test "x$ac_cv_have_decl_HAVE_IB_ATOMIC_PTHREAD_T_SOLARIS"= "xyes" ; then
- + AC_DEFINE([HAVE_IB_ATOMIC_PTHREAD_T_SOLARIS], [1],
- + [pthread_t can be used by solaris atomics])
- + fi
-
- # 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
- - AC_MSG_CHECKING(for x86 PAUSE instruction)
- + AC_CACHE_CHECK([for x86 PAUSE instruction],
- + [ac_cv_have_decl_HAVE_IB_PAUSE_INSTRUCTION],
- # We have to actually try running the test program, because of a bug
- # in Solaris on x86_64, where it wrongly reports that PAUSE is not
- # supported when trying to run an application. See
- # http://bugs.opensolaris.org/bugdatabase/printableBug.do?bug_id=6478684
- # We use ib_ prefix to avoid collisoins if this code is added to
- # mysql's configure.in.
- - AC_TRY_RUN(
- + [AC_TRY_RUN(
- [
- int main() {
- __asm__ __volatile__ ("pause");
- @@ -210,16 +226,21 @@
- }
- ],
- [
- - AC_DEFINE([HAVE_IB_PAUSE_INSTRUCTION], [1], [Does x86 PAUSE instruction exist])
- AC_MSG_RESULT(yes)
- + ac_cv_have_decl_HAVE_IB_PAUSE_INSTRUCTION=yes
- ],
- [
- AC_MSG_RESULT(no)
- + ac_cv_have_decl_HAVE_IB_PAUSE_INSTRUCTION=no
- ],
- [
- AC_MSG_RESULT(no)
- + ac_cv_have_decl_HAVE_IB_PAUSE_INSTRUCTION=no
- ]
- - )
- + )])
- + if test "x$ac_cv_have_decl_HAVE_IB_PAUSE_INSTRUCTION"= "xyes" ; then
- + AC_DEFINE([HAVE_IB_PAUSE_INSTRUCTION], [1], [Does x86 PAUSE instruction exist])
- + fi
- ])
-
- # vim: set ft=config:
|