summaryrefslogtreecommitdiff
path: root/Zend/acinclude.m4
diff options
context:
space:
mode:
authorChristian Seiler <cseiler@php.net>2008-12-02 21:06:50 +0000
committerChristian Seiler <cseiler@php.net>2008-12-02 21:06:50 +0000
commitcb98d43a6a4800b563bbbf8040fa14e110e0f115 (patch)
tree673b77e5772a72e27529d6b04f62b11bb14c50e2 /Zend/acinclude.m4
parent00cb5de0ab834ba1d989590ea33c57e891b1dbe5 (diff)
downloadphp-git-cb98d43a6a4800b563bbbf8040fa14e110e0f115.tar.gz
- MFH: Fixed autoconf 2.13 issues with FP checks.
Diffstat (limited to 'Zend/acinclude.m4')
-rw-r--r--Zend/acinclude.m4193
1 files changed, 69 insertions, 124 deletions
diff --git a/Zend/acinclude.m4 b/Zend/acinclude.m4
index d507f1780e..37068a316b 100644
--- a/Zend/acinclude.m4
+++ b/Zend/acinclude.m4
@@ -110,31 +110,20 @@ dnl x87 floating point internal precision control checks
dnl See: http://wiki.php.net/rfc/rounding
AC_DEFUN([ZEND_CHECK_FLOAT_PRECISION],[
AC_MSG_CHECKING([for usable _FPU_SETCW])
- AC_LINK_IFELSE([[
- #include <stdio.h>
- #include <string.h>
- #include <fpu_control.h>
-
- double div (double a, double b) {
- fpu_control_t fpu_oldcw, fpu_cw;
- volatile double result;
-
- _FPU_GETCW(fpu_oldcw);
- fpu_cw = (fpu_oldcw & ~_FPU_EXTENDED & ~_FPU_SINGLE) | _FPU_DOUBLE;
- _FPU_SETCW(fpu_cw);
- result = a / b;
- _FPU_SETCW(fpu_oldcw);
- return result;
- }
-
- int main (int argc, char **argv) {
- double d = div (2877.0, 1000000.0);
- char buf[255];
- sprintf(buf, "%.30f", d);
- /* see if the result is actually in double precision */
- return strncmp(buf, "0.00287699", 10) == 0 ? 0 : 1;
- }
- ]], [ac_cfp_have__fpu_setcw=yes], [ac_cfp_have__fpu_setcw=no])
+ AC_TRY_LINK([
+ #include <fpu_control.h>
+ ],[
+ fpu_control_t fpu_oldcw, fpu_cw;
+ volatile double result;
+ double a = 2877.0;
+ volatile double b = 1000000.0;
+
+ _FPU_GETCW(fpu_oldcw);
+ fpu_cw = (fpu_oldcw & ~_FPU_EXTENDED & ~_FPU_SINGLE) | _FPU_DOUBLE;
+ _FPU_SETCW(fpu_cw);
+ result = a / b;
+ _FPU_SETCW(fpu_oldcw);
+ ], [ac_cfp_have__fpu_setcw=yes], [ac_cfp_have__fpu_setcw=no])
if test "$ac_cfp_have__fpu_setcw" = "yes" ; then
AC_DEFINE(HAVE__FPU_SETCW, 1, [whether _FPU_SETCW is present and usable])
AC_MSG_RESULT(yes)
@@ -143,30 +132,19 @@ AC_DEFUN([ZEND_CHECK_FLOAT_PRECISION],[
fi
AC_MSG_CHECKING([for usable fpsetprec])
- AC_LINK_IFELSE([[
- #include <stdio.h>
- #include <string.h>
- #include <machine/ieeefp.h>
-
- double div (double a, double b) {
- fp_prec_t fpu_oldprec;
- volatile double result;
-
- fpu_oldprec = fpgetprec();
- fpsetprec(FP_PD);
- result = a / b;
- fpsetprec(fpu_oldprec);
- return result;
- }
-
- int main (int argc, char **argv) {
- double d = div (2877.0, 1000000.0);
- char buf[255];
- sprintf(buf, "%.30f", d);
- /* see if the result is actually in double precision */
- return strncmp(buf, "0.00287699", 10) == 0 ? 0 : 1;
- }
- ]], [ac_cfp_have_fpsetprec=yes], [ac_cfp_have_fpsetprec=no])
+ AC_TRY_LINK([
+ #include <machine/ieeefp.h>
+ ],[
+ fp_prec_t fpu_oldprec;
+ volatile double result;
+ double a = 2877.0;
+ volatile double b = 1000000.0;
+
+ fpu_oldprec = fpgetprec();
+ fpsetprec(FP_PD);
+ result = a / b;
+ fpsetprec(fpu_oldprec);
+ ], [ac_cfp_have_fpsetprec=yes], [ac_cfp_have_fpsetprec=no])
if test "$ac_cfp_have_fpsetprec" = "yes" ; then
AC_DEFINE(HAVE_FPSETPREC, 1, [whether fpsetprec is present and usable])
AC_MSG_RESULT(yes)
@@ -175,30 +153,19 @@ AC_DEFUN([ZEND_CHECK_FLOAT_PRECISION],[
fi
AC_MSG_CHECKING([for usable _controlfp])
- AC_LINK_IFELSE([[
- #include <stdio.h>
- #include <string.h>
- #include <float.h>
-
- double div (double a, double b) {
- unsigned int fpu_oldcw;
- volatile double result;
-
- fpu_oldcw = _controlfp(0, 0);
- _controlfp(_PC_53, _MCW_PC);
- result = a / b;
- _controlfp(fpu_oldcw, _MCW_PC);
- return result;
- }
-
- int main (int argc, char **argv) {
- double d = div (2877.0, 1000000.0);
- char buf[255];
- sprintf(buf, "%.30f", d);
- /* see if the result is actually in double precision */
- return strncmp(buf, "0.00287699", 10) == 0 ? 0 : 1;
- }
- ]], [ac_cfp_have__controlfp=yes], [ac_cfp_have__controlfp=no])
+ AC_TRY_LINK([
+ #include <float.h>
+ ],[
+ unsigned int fpu_oldcw;
+ volatile double result;
+ double a = 2877.0;
+ volatile double b = 1000000.0;
+
+ fpu_oldcw = _controlfp(0, 0);
+ _controlfp(_PC_53, _MCW_PC);
+ result = a / b;
+ _controlfp(fpu_oldcw, _MCW_PC);
+ ], [ac_cfp_have__controlfp=yes], [ac_cfp_have__controlfp=no])
if test "$ac_cfp_have__controlfp" = "yes" ; then
AC_DEFINE(HAVE__CONTROLFP, 1, [whether _controlfp is present usable])
AC_MSG_RESULT(yes)
@@ -207,31 +174,20 @@ AC_DEFUN([ZEND_CHECK_FLOAT_PRECISION],[
fi
AC_MSG_CHECKING([for usable _controlfp_s])
- AC_LINK_IFELSE([[
- #include <stdio.h>
- #include <string.h>
+ AC_TRY_LINK([
#include <float.h>
-
- double div (double a, double b) {
- unsigned int fpu_oldcw, fpu_cw;
- volatile double result;
-
- _controlfp_s(&fpu_cw, 0, 0);
- fpu_oldcw = fpu_cw;
- _controlfp_s(&fpu_cw, _PC_53, _MCW_PC);
- result = a / b;
- _controlfp_s(&fpu_cw, fpu_oldcw, _MCW_PC);
- return result;
- }
-
- int main (int argc, char **argv) {
- double d = div (2877.0, 1000000.0);
- char buf[255];
- sprintf(buf, "%.30f", d);
- /* see if the result is actually in double precision */
- return strncmp(buf, "0.00287699", 10) == 0 ? 0 : 1;
- }
- ]], [ac_cfp_have__controlfp_s=yes], [ac_cfp_have__controlfp_s=no])
+ ],[
+ unsigned int fpu_oldcw, fpu_cw;
+ volatile double result;
+ double a = 2877.0;
+ volatile double b = 1000000.0;
+
+ _controlfp_s(&fpu_cw, 0, 0);
+ fpu_oldcw = fpu_cw;
+ _controlfp_s(&fpu_cw, _PC_53, _MCW_PC);
+ result = a / b;
+ _controlfp_s(&fpu_cw, fpu_oldcw, _MCW_PC);
+ ], [ac_cfp_have__controlfp_s=yes], [ac_cfp_have__controlfp_s=no])
if test "$ac_cfp_have__controlfp_s" = "yes" ; then
AC_DEFINE(HAVE__CONTROLFP_S, 1, [whether _controlfp_s is present and usable])
AC_MSG_RESULT(yes)
@@ -240,33 +196,22 @@ AC_DEFUN([ZEND_CHECK_FLOAT_PRECISION],[
fi
AC_MSG_CHECKING([whether FPU control word can be manipulated by inline assembler])
- AC_LINK_IFELSE([[
- #include <stdio.h>
- #include <string.h>
-
- double div (double a, double b) {
- unsigned int oldcw, cw;
- volatile double result;
-
- __asm__ __volatile__ ("fnstcw %0" : "=m" (*&oldcw));
- cw = (oldcw & ~0x0 & ~0x300) | 0x200;
- __asm__ __volatile__ ("fldcw %0" : : "m" (*&cw));
-
- result = a / b;
-
- __asm__ __volatile__ ("fldcw %0" : : "m" (*&oldcw));
-
- return result;
- }
-
- int main (int argc, char **argv) {
- double d = div (2877.0, 1000000.0);
- char buf[255];
- sprintf(buf, "%.30f", d);
- /* see if the result is actually in double precision */
- return strncmp(buf, "0.00287699", 10) == 0 ? 0 : 1;
- }
- ]], [ac_cfp_have_fpu_inline_asm_x86=yes], [ac_cfp_have_fpu_inline_asm_x86=no])
+ AC_TRY_LINK([
+ /* nothing */
+ ],[
+ unsigned int oldcw, cw;
+ volatile double result;
+ double a = 2877.0;
+ volatile double b = 1000000.0;
+
+ __asm__ __volatile__ ("fnstcw %0" : "=m" (*&oldcw));
+ cw = (oldcw & ~0x0 & ~0x300) | 0x200;
+ __asm__ __volatile__ ("fldcw %0" : : "m" (*&cw));
+
+ result = a / b;
+
+ __asm__ __volatile__ ("fldcw %0" : : "m" (*&oldcw));
+ ], [ac_cfp_have_fpu_inline_asm_x86=yes], [ac_cfp_have_fpu_inline_asm_x86=no])
if test "$ac_cfp_have_fpu_inline_asm_x86" = "yes" ; then
AC_DEFINE(HAVE_FPU_INLINE_ASM_X86, 1, [whether FPU control word can be manipulated by inline assembler])
AC_MSG_RESULT(yes)