mirror of
https://git.postgresql.org/git/postgresql.git
synced 2024-12-21 08:29:39 +08:00
192 lines
5.9 KiB
Plaintext
192 lines
5.9 KiB
Plaintext
# Macros to detect C compiler features
|
|
# $PostgreSQL: pgsql/config/c-compiler.m4,v 1.11 2003/11/29 19:51:17 pgsql Exp $
|
|
|
|
|
|
# PGAC_C_SIGNED
|
|
# -------------
|
|
# Check if the C compiler understands signed types.
|
|
AC_DEFUN([PGAC_C_SIGNED],
|
|
[AC_CACHE_CHECK(for signed types, pgac_cv_c_signed,
|
|
[AC_TRY_COMPILE([],
|
|
[signed char c; signed short s; signed int i;],
|
|
[pgac_cv_c_signed=yes],
|
|
[pgac_cv_c_signed=no])])
|
|
if test x"$pgac_cv_c_signed" = xno ; then
|
|
AC_DEFINE(signed,, [Define to empty if the C compiler does not understand signed types.])
|
|
fi])# PGAC_C_SIGNED
|
|
|
|
|
|
|
|
# PGAC_TYPE_64BIT_INT(TYPE)
|
|
# -------------------------
|
|
# Check if TYPE is a working 64 bit integer type. Set HAVE_TYPE_64 to
|
|
# yes or no respectively, and define HAVE_TYPE_64 if yes.
|
|
AC_DEFUN([PGAC_TYPE_64BIT_INT],
|
|
[define([Ac_define], [translit([have_$1_64], [a-z *], [A-Z_P])])dnl
|
|
define([Ac_cachevar], [translit([pgac_cv_type_$1_64], [ *], [_p])])dnl
|
|
AC_CACHE_CHECK([whether $1 is 64 bits], [Ac_cachevar],
|
|
[AC_TRY_RUN(
|
|
[typedef $1 int64;
|
|
|
|
/*
|
|
* These are globals to discourage the compiler from folding all the
|
|
* arithmetic tests down to compile-time constants.
|
|
*/
|
|
int64 a = 20000001;
|
|
int64 b = 40000005;
|
|
|
|
int does_int64_work()
|
|
{
|
|
int64 c,d;
|
|
|
|
if (sizeof(int64) != 8)
|
|
return 0; /* definitely not the right size */
|
|
|
|
/* Do perfunctory checks to see if 64-bit arithmetic seems to work */
|
|
c = a * b;
|
|
d = (c + b) / b;
|
|
if (d != a+1)
|
|
return 0;
|
|
return 1;
|
|
}
|
|
main() {
|
|
exit(! does_int64_work());
|
|
}],
|
|
[Ac_cachevar=yes],
|
|
[Ac_cachevar=no],
|
|
[# If cross-compiling, check the size reported by the compiler and
|
|
# trust that the arithmetic works.
|
|
AC_COMPILE_IFELSE([AC_LANG_BOOL_COMPILE_TRY([], [sizeof($1) == 8])],
|
|
Ac_cachevar=yes,
|
|
Ac_cachevar=no)])])
|
|
|
|
Ac_define=$Ac_cachevar
|
|
if test x"$Ac_cachevar" = xyes ; then
|
|
AC_DEFINE(Ac_define,, [Define to 1 if `]$1[' works and is 64 bits.])
|
|
fi
|
|
undefine([Ac_define])dnl
|
|
undefine([Ac_cachevar])dnl
|
|
])# PGAC_TYPE_64BIT_INT
|
|
|
|
|
|
|
|
# PGAC_CHECK_ALIGNOF(TYPE, [INCLUDES = DEFAULT-INCLUDES])
|
|
# -----------------------------------------------------
|
|
# Find the alignment requirement of the given type. Define the result
|
|
# as ALIGNOF_TYPE. This macro works even when cross compiling.
|
|
# (Modelled after AC_CHECK_SIZEOF.)
|
|
|
|
AC_DEFUN([PGAC_CHECK_ALIGNOF],
|
|
[AS_LITERAL_IF([$1], [],
|
|
[AC_FATAL([$0: requires literal arguments])])dnl
|
|
AC_CHECK_TYPE([$1], [], [], [$2])
|
|
AC_CACHE_CHECK([alignment of $1], [AS_TR_SH([pgac_cv_alignof_$1])],
|
|
[if test "$AS_TR_SH([ac_cv_type_$1])" = yes; then
|
|
_AC_COMPUTE_INT([((char*) & pgac_struct.field) - ((char*) & pgac_struct)],
|
|
[AS_TR_SH([pgac_cv_alignof_$1])],
|
|
[AC_INCLUDES_DEFAULT([$2])
|
|
struct { char filler; $1 field; } pgac_struct;],
|
|
[AC_MSG_ERROR([cannot compute alignment of $1, 77])])
|
|
else
|
|
AS_TR_SH([pgac_cv_alignof_$1])=0
|
|
fi])dnl
|
|
AC_DEFINE_UNQUOTED(AS_TR_CPP(alignof_$1),
|
|
[$AS_TR_SH([pgac_cv_alignof_$1])],
|
|
[The alignment requirement of a `$1'.])
|
|
])# PGAC_CHECK_ALIGNOF
|
|
|
|
|
|
# PGAC_C_FUNCNAME_SUPPORT
|
|
# -----------------------
|
|
# Check if the C compiler understands __func__ (C99) or __FUNCTION__ (gcc).
|
|
# Define HAVE_FUNCNAME__FUNC or HAVE_FUNCNAME__FUNCTION accordingly.
|
|
AC_DEFUN([PGAC_C_FUNCNAME_SUPPORT],
|
|
[AC_CACHE_CHECK(for __func__, pgac_cv_funcname_func_support,
|
|
[AC_TRY_COMPILE([#include <stdio.h>],
|
|
[printf("%s\n", __func__);],
|
|
[pgac_cv_funcname_func_support=yes],
|
|
[pgac_cv_funcname_func_support=no])])
|
|
if test x"$pgac_cv_funcname_func_support" = xyes ; then
|
|
AC_DEFINE(HAVE_FUNCNAME__FUNC, 1,
|
|
[Define to 1 if your compiler understands __func__.])
|
|
else
|
|
AC_CACHE_CHECK(for __FUNCTION__, pgac_cv_funcname_function_support,
|
|
[AC_TRY_COMPILE([#include <stdio.h>],
|
|
[printf("%s\n", __FUNCTION__);],
|
|
[pgac_cv_funcname_function_support=yes],
|
|
[pgac_cv_funcname_function_support=no])])
|
|
if test x"$pgac_cv_funcname_function_support" = xyes ; then
|
|
AC_DEFINE(HAVE_FUNCNAME__FUNCTION, 1,
|
|
[Define to 1 if your compiler understands __FUNCTION__.])
|
|
fi
|
|
fi])# PGAC_C_FUNCNAME_SUPPORT
|
|
|
|
|
|
# PGAC_PROG_CC_NO_STRICT_ALIASING
|
|
# -------------------------------
|
|
# Find out how to turn off strict aliasing in the C compiler.
|
|
AC_DEFUN([PGAC_PROG_CC_NO_STRICT_ALIASING],
|
|
[AC_CACHE_CHECK([how to turn off strict aliasing in $CC],
|
|
pgac_cv_prog_cc_no_strict_aliasing,
|
|
[pgac_save_CFLAGS=$CFLAGS
|
|
if test "$GCC" = yes; then
|
|
pgac_try="-fno-strict-aliasing"
|
|
else
|
|
# Maybe fill in later...
|
|
pgac_try=
|
|
fi
|
|
|
|
for pgac_flag in $pgac_try; do
|
|
CFLAGS="$pgac_save_CFLAGS $pgac_flag"
|
|
_AC_COMPILE_IFELSE([AC_LANG_PROGRAM()],
|
|
[pgac_cv_prog_cc_no_strict_aliasing=$pgac_try
|
|
break])
|
|
done
|
|
|
|
CFLAGS=$pgac_save_CFLAGS
|
|
])
|
|
|
|
if test "$ac_env_CFLAGS_set" != set; then
|
|
CFLAGS="$CFLAGS $pgac_cv_prog_cc_no_strict_aliasing"
|
|
fi])# PGAC_PROG_CC_NO_STRICT_ALIASING
|
|
|
|
|
|
# The below backpatches the following Autoconf change:
|
|
#
|
|
# 2002-03-28 Kevin Ryde <user42@zip.com.au>
|
|
#
|
|
# * lib/autoconf/c.m4 (AC_C_INLINE): Test with a typedef return value,
|
|
# to avoid versions of HP C which don't allow that.
|
|
#
|
|
# When we upgrade to Autoconf >= 2.53a then we can drop this and rely
|
|
# on the standard macro.
|
|
|
|
# AC_C_INLINE
|
|
# -----------
|
|
# Do nothing if the compiler accepts the inline keyword.
|
|
# Otherwise define inline to __inline__ or __inline if one of those work,
|
|
# otherwise define inline to be empty.
|
|
AC_DEFUN([AC_C_INLINE],
|
|
[AC_REQUIRE([AC_PROG_CC_STDC])dnl
|
|
AC_CACHE_CHECK([for inline], ac_cv_c_inline,
|
|
[ac_cv_c_inline=no
|
|
for ac_kw in inline __inline__ __inline; do
|
|
AC_COMPILE_IFELSE([AC_LANG_SOURCE(
|
|
[#ifndef __cplusplus
|
|
typedef int foo_t;
|
|
static $ac_kw foo_t static_foo () {return 0; }
|
|
$ac_kw int foo () {return 0; }
|
|
#endif
|
|
])],
|
|
[ac_cv_c_inline=$ac_kw; break])
|
|
done
|
|
])
|
|
case $ac_cv_c_inline in
|
|
inline | yes) ;;
|
|
no) AC_DEFINE(inline,,
|
|
[Define as `__inline' if that's what the C compiler calls it,
|
|
or to nothing if it is not supported.]) ;;
|
|
*) AC_DEFINE_UNQUOTED(inline, $ac_cv_c_inline) ;;
|
|
esac
|
|
])# AC_C_INLINE
|