Use AC_CACHE_CHECK for float precision checks (#14663)

- AC_CACHE_CHECK simplifies message checkings and can speed up the
  consequtive configure -C checks
- AC_DEFINE descriptions style synced
- Used php_cv_* cache variables style
- Reduced over-quoted arguments to AC_LANG_PROGRAM
- Sync macro help text
This commit is contained in:
Peter Kokot 2024-06-28 23:23:06 +02:00 committed by GitHub
parent bf7be07e7d
commit 7f8e8a08d2
No known key found for this signature in database
GPG key ID: B5690EEEBB952194

View file

@ -6,11 +6,10 @@ dnl
dnl x87 floating point internal precision control checks dnl x87 floating point internal precision control checks
dnl See: http://wiki.php.net/rfc/rounding dnl See: http://wiki.php.net/rfc/rounding
dnl dnl
AC_DEFUN([ZEND_CHECK_FLOAT_PRECISION],[ AC_DEFUN([ZEND_CHECK_FLOAT_PRECISION], [dnl
AC_MSG_CHECKING([for usable _FPU_SETCW]) AC_CACHE_CHECK([for usable _FPU_SETCW],
AC_LINK_IFELSE([AC_LANG_PROGRAM([[ [php_cv_have__fpu_setcw],
#include <fpu_control.h> [AC_LINK_IFELSE([AC_LANG_PROGRAM([#include <fpu_control.h>], [dnl
]],[[
fpu_control_t fpu_oldcw, fpu_cw; fpu_control_t fpu_oldcw, fpu_cw;
volatile double result; volatile double result;
double a = 2877.0; double a = 2877.0;
@ -22,18 +21,16 @@ AC_DEFUN([ZEND_CHECK_FLOAT_PRECISION],[
result = a / b; result = a / b;
_FPU_SETCW(fpu_oldcw); _FPU_SETCW(fpu_oldcw);
(void)result; (void)result;
]])],[ac_cfp_have__fpu_setcw=yes],[ac_cfp_have__fpu_setcw=no]) ])],
if test "$ac_cfp_have__fpu_setcw" = "yes" ; then [php_cv_have__fpu_setcw=yes],
AC_DEFINE(HAVE__FPU_SETCW, 1, [whether _FPU_SETCW is present and usable]) [php_cv_have__fpu_setcw=no])])
AC_MSG_RESULT(yes) AS_VAR_IF([php_cv_have__fpu_setcw], [yes],
else [AC_DEFINE([HAVE__FPU_SETCW], [1],
AC_MSG_RESULT(no) [Define to 1 if _FPU_SETCW is present and usable.])])
fi
AC_MSG_CHECKING([for usable fpsetprec]) AC_CACHE_CHECK([for usable fpsetprec],
AC_LINK_IFELSE([AC_LANG_PROGRAM([[ [php_cv_have_fpsetprec],
#include <machine/ieeefp.h> [AC_LINK_IFELSE([AC_LANG_PROGRAM([#include <machine/ieeefp.h>], [dnl
]],[[
fp_prec_t fpu_oldprec; fp_prec_t fpu_oldprec;
volatile double result; volatile double result;
double a = 2877.0; double a = 2877.0;
@ -44,18 +41,16 @@ AC_DEFUN([ZEND_CHECK_FLOAT_PRECISION],[
result = a / b; result = a / b;
fpsetprec(fpu_oldprec); fpsetprec(fpu_oldprec);
(void)result; (void)result;
]])], [ac_cfp_have_fpsetprec=yes], [ac_cfp_have_fpsetprec=no]) ])],
if test "$ac_cfp_have_fpsetprec" = "yes" ; then [php_cv_have_fpsetprec=yes],
AC_DEFINE(HAVE_FPSETPREC, 1, [whether fpsetprec is present and usable]) [php_cv_have_fpsetprec=no])])
AC_MSG_RESULT(yes) AS_VAR_IF([php_cv_have_fpsetprec], [yes],
else [AC_DEFINE([HAVE_FPSETPREC], [1],
AC_MSG_RESULT(no) [Define to 1 if fpsetprec is present and usable.])])
fi
AC_MSG_CHECKING([for usable _controlfp]) AC_CACHE_CHECK([for usable _controlfp],
AC_LINK_IFELSE([AC_LANG_PROGRAM([[ [php_cv_have__controlfp],
#include <float.h> [AC_LINK_IFELSE([AC_LANG_PROGRAM([#include <float.h>], [dnl
]],[[
unsigned int fpu_oldcw; unsigned int fpu_oldcw;
volatile double result; volatile double result;
double a = 2877.0; double a = 2877.0;
@ -66,18 +61,16 @@ AC_DEFUN([ZEND_CHECK_FLOAT_PRECISION],[
result = a / b; result = a / b;
_controlfp(fpu_oldcw, _MCW_PC); _controlfp(fpu_oldcw, _MCW_PC);
(void)result; (void)result;
]])], [ac_cfp_have__controlfp=yes], [ac_cfp_have__controlfp=no]) ])],
if test "$ac_cfp_have__controlfp" = "yes" ; then [php_cv_have__controlfp=yes],
AC_DEFINE(HAVE__CONTROLFP, 1, [whether _controlfp is present usable]) [php_cv_have__controlfp=no])])
AC_MSG_RESULT(yes) AS_VAR_IF([php_cv_have__controlfp], [yes],
else [AC_DEFINE([HAVE__CONTROLFP], [1],
AC_MSG_RESULT(no) [Define to 1 if _controlfp is present and usable.])])
fi
AC_MSG_CHECKING([for usable _controlfp_s]) AC_CACHE_CHECK([for usable _controlfp_s],
AC_LINK_IFELSE([AC_LANG_PROGRAM([[ [php_cv_have__controlfp_s],
#include <float.h> [AC_LINK_IFELSE([AC_LANG_PROGRAM([#include <float.h>], [dnl
]],[[
unsigned int fpu_oldcw, fpu_cw; unsigned int fpu_oldcw, fpu_cw;
volatile double result; volatile double result;
double a = 2877.0; double a = 2877.0;
@ -89,18 +82,16 @@ AC_DEFUN([ZEND_CHECK_FLOAT_PRECISION],[
result = a / b; result = a / b;
_controlfp_s(&fpu_cw, fpu_oldcw, _MCW_PC); _controlfp_s(&fpu_cw, fpu_oldcw, _MCW_PC);
(void)result; (void)result;
]])], [ac_cfp_have__controlfp_s=yes], [ac_cfp_have__controlfp_s=no]) ])],
if test "$ac_cfp_have__controlfp_s" = "yes" ; then [php_cv_have__controlfp_s=yes],
AC_DEFINE(HAVE__CONTROLFP_S, 1, [whether _controlfp_s is present and usable]) [php_cv_have__controlfp_s=no])])
AC_MSG_RESULT(yes) AS_VAR_IF([php_cv_have__controlfp_s], [yes],
else [AC_DEFINE([HAVE__CONTROLFP_S], [1],
AC_MSG_RESULT(no) [Define to 1 if _controlfp_s is present and usable.])])
fi
AC_MSG_CHECKING([whether FPU control word can be manipulated by inline assembler]) AC_CACHE_CHECK([whether FPU control word can be manipulated by inline assembler],
AC_LINK_IFELSE([AC_LANG_PROGRAM([[ [php_cv_have_fpu_inline_asm_x86],
/* nothing */ [AC_LINK_IFELSE([AC_LANG_PROGRAM([], [dnl
]],[[
unsigned int oldcw, cw; unsigned int oldcw, cw;
volatile double result; volatile double result;
double a = 2877.0; double a = 2877.0;
@ -112,13 +103,12 @@ AC_DEFUN([ZEND_CHECK_FLOAT_PRECISION],[
result = a / b; result = a / b;
__asm__ __volatile__ ("fldcw %0" : : "m" (*&oldcw)); __asm__ __volatile__ ("fldcw %0" : : "m" (*&oldcw));
(void)result; (void)result;
]])], [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 [php_cv_have_fpu_inline_asm_x86=yes],
AC_DEFINE(HAVE_FPU_INLINE_ASM_X86, 1, [whether FPU control word can be manipulated by inline assembler]) [php_cv_have_fpu_inline_asm_x86=no])])
AC_MSG_RESULT(yes) AS_VAR_IF([php_cv_have_fpu_inline_asm_x86], [yes],
else [AC_DEFINE([HAVE_FPU_INLINE_ASM_X86], [1],
AC_MSG_RESULT(no) [Define to 1 if FPU control word can be manipulated by inline assembler.])])
fi
]) ])
dnl dnl