mirror of
https://https.git.savannah.gnu.org/git/gnulib.git
synced 2026-04-28 14:43:36 +00:00
* m4/btowc.m4 (gl_FUNC_BTOWC): Add cross-compilation guess for native Windows. * m4/c-stack.m4 (AC_SYS_XSI_STACK_OVERFLOW_HEURISTIC): Likewise. * m4/calloc.m4 (_AC_FUNC_CALLOC_IF): Likewise. * m4/canonicalize.m4 (gl_FUNC_REALPATH_WORKS): Likewise. * m4/cbrtf.m4 (gl_FUNC_CBRTF_WORKS): Likewise. * m4/cbrtl.m4 (gl_FUNC_CBRTL, gl_FUNC_CBRTL_WORKS): Likewise. * m4/ceil.m4 (gl_FUNC_CEIL): Likewise. * m4/ceilf.m4 (gl_FUNC_CEILF): Likewise. * m4/ceill.m4 (gl_FUNC_CEILL): Likewise. * m4/d-ino.m4 (gl_CHECK_TYPE_STRUCT_DIRENT_D_INO): Likewise. * m4/dup.m4 (gl_FUNC_DUP): Likewise. * m4/expl.m4 (gl_FUNC_EXPL): Likewise. * m4/exp2.m4 (gl_FUNC_EXP2_WORKS): Likewise. * m4/exp2l.m4 (gl_FUNC_EXP2L): Likewise. * m4/expm1.m4 (gl_FUNC_EXPM1): Likewise. * m4/expm1f.m4 (gl_FUNC_EXPM1F_WORKS): Likewise. * m4/exponentl.m4 (gl_LONG_DOUBLE_EXPONENT_LOCATION): Likewise. * m4/fabsl.m4 (gl_FUNC_FABSL_WORKS): Likewise. * m4/fchdir.m4 (gl_FUNC_FCHDIR): Likewise. * m4/fcntl-o.m4 (gl_FCNTL_O_FLAGS): Likewise. * m4/float_h.m4 (gl_FLOAT_H): Likewise. * m4/floor.m4 (gl_FUNC_FLOOR): Likewise. * m4/floorf.m4 (gl_FUNC_FLOORF): Likewise. * m4/fma.m4 (gl_FUNC_FMA_WORKS): Likewise. * m4/fmaf.m4 (gl_FUNC_FMAF_WORKS): Likewise. * m4/fmal.m4 (gl_FUNC_FMAL_WORKS): Likewise. * m4/fmod.m4 (gl_FUNC_FMOD): Likewise. * m4/fmodf.m4 (gl_FUNC_FMODF): Likewise. * m4/fmodl.m4 (gl_FUNC_FMODL): Likewise. * m4/frexp.m4 (gl_FUNC_FREXP_WORKS): Likewise. * m4/frexpf.m4 (gl_FUNC_FREXPF_WORKS): Likewise. * m4/ftello.m4 (gl_FUNC_FTELLO): Likewise. * m4/gettimeofday.m4 (gl_FUNC_GETTIMEOFDAY_CLOBBER): Likewise. * m4/hypot.m4 (gl_FUNC_HYPOT): Likewise. * m4/hypotf.m4 (gl_FUNC_HYPOTF, gl_FUNC_HYPOTF_WORKS): Likewise. * m4/hypotl.m4 (gl_FUNC_HYPOTL, gl_FUNC_HYPOTL_WORKS): Likewise. * m4/ilogb.m4 (gl_FUNC_ILOGB_WORKS): Likewise. * m4/ilogbf.m4 (gl_FUNC_ILOGBF_WORKS): Likewise. * m4/isfinite.m4 (gl_ISFINITEL_WORKS): Likewise. * m4/isinf.m4 (gl_ISINFL_WORKS): Likewise. * m4/isnanf.m4 (gl_ISNANF_WORKS): Likewise. * m4/isnanl.m4 (gl_FUNC_ISNANL_WORKS): Likewise. * m4/ldexpl.m4 (gl_FUNC_LDEXPL_WORKS): Likewise. * m4/log.m4 (gl_FUNC_LOG, gl_FUNC_LOG_WORKS): Likewise. * m4/logf.m4 (gl_FUNC_LOGF, gl_FUNC_LOGF_WORKS): Likewise. * m4/logl.m4 (gl_FUNC_LOGL_WORKS): Likewise. * m4/log10.m4 (gl_FUNC_LOG10, gl_FUNC_LOG10_WORKS): Likewise. * m4/log10f.m4 (gl_FUNC_LOG10F, gl_FUNC_LOG10F_WORKS): Likewise. * m4/log10l.m4 (gl_FUNC_LOG10L_WORKS): Likewise. * m4/log1p.m4 (gl_FUNC_LOG1P): Likewise. * m4/log1pf.m4 (gl_FUNC_LOG1PF, gl_FUNC_LOG1PF_WORKS): Likewise. * m4/log1pl.m4 (gl_FUNC_LOG1PL): Likewise. * m4/log2.m4 (gl_FUNC_LOG2, gl_FUNC_LOG2_WORKS): Likewise. * m4/log2f.m4 (gl_FUNC_LOG2F, gl_FUNC_LOG2F_WORKS): Likewise. * m4/log2l.m4 (gl_FUNC_LOG2L_WORKS): Likewise. * m4/logb.m4 (gl_FUNC_LOGB_WORKS): Likewise. * m4/logbf.m4 (gl_FUNC_LOGBF_WORKS): Likewise. * m4/logbl.m4 (gl_FUNC_LOGBL_WORKS): Likewise. * m4/lstat.m4 (gl_FUNC_LSTAT_FOLLOWS_SLASHED_SYMLINK): Likewise. * m4/mbrtowc.m4 (gl_MBRTOWC_EMPTY_INPUT, gl_MBRTOWC_C_LOCALE): Likewise. * m4/mkdir.m4 (gl_FUNC_MKDIR): Likewise. * m4/mkstemp.m4 (gl_FUNC_MKSTEMP): Likewise. * m4/mktime.m4 (gl_FUNC_MKTIME_WORKS): Likewise. * m4/modf.m4 (gl_FUNC_MODF): Likewise. * m4/modff.m4 (gl_FUNC_MODFF): Likewise. * m4/modfl.m4 (gl_FUNC_MODFL): Likewise. * m4/nanosleep.m4 (gl_FUNC_NANOSLEEP): Likewise. * m4/perror.m4 (gl_FUNC_PERROR): Likewise. * m4/popen.m4 (gl_FUNC_POPEN): Likewise. * m4/posix_spawn.m4 (gl_FUNC_POSIX_SPAWN_FILE_ACTIONS_ADDCLOSE, gl_FUNC_POSIX_SPAWN_FILE_ACTIONS_ADDDUP2, gl_FUNC_POSIX_SPAWN_FILE_ACTIONS_ADDOPEN): Likewise. * m4/ptsname_r.m4 (gl_PREREQ_PTSNAME_R): Likewise. * m4/putenv.m4 (gl_FUNC_PUTENV): Likewise. * m4/regex.m4 (gl_REGEX): Likewise. * m4/remainder.m4 (gl_FUNC_REMAINDER): Likewise. * m4/remainderf.m4 (gl_FUNC_REMAINDERF, gl_FUNC_REMAINDERF_WORKS): Likewise. * m4/remainderl.m4 (gl_FUNC_REMAINDERL, gl_FUNC_REMAINDERL_WORKS): Likewise. * m4/rename.m4 (gl_FUNC_RENAME): Likewise. * m4/rmdir-errno.m4 (gl_FUNC_RMDIR_NOTEMPTY): Likewise. * m4/rmdir.m4 (gl_FUNC_RMDIR): Likewise. * m4/round.m4 (gl_FUNC_ROUND): Likewise. * m4/roundf.m4 (gl_FUNC_ROUNDF): Likewise. * m4/roundl.m4 (gl_FUNC_ROUNDL): Likewise. * m4/signbit.m4 (gl_SIGNBIT): Likewise. * m4/sleep.m4 (gl_FUNC_SLEEP): Likewise. * m4/sqrtl.m4 (gl_FUNC_SQRTL_WORKS): Likewise. * m4/stdint.m4 (gl_STDINT_H): Likewise. * m4/strerror.m4 (gl_FUNC_STRERROR_0): Likewise. * m4/strncat.m4 (gl_FUNC_STRNCAT): Likewise. * m4/strtod.m4 (gl_FUNC_STRTOD): Likewise. * m4/strtoimax.m4 (gl_FUNC_STRTOIMAX): Likewise. * m4/strtok_r.m4 (gl_FUNC_STRTOK_R): Likewise. * m4/trunc.m4 (gl_FUNC_TRUNC): Likewise. * m4/truncf.m4 (gl_FUNC_TRUNCF): Likewise. * m4/truncl.m4 (gl_FUNC_TRUNCL): Likewise. * m4/tsearch.m4 (gl_FUNC_TSEARCH): Likewise. * m4/tzset.m4 (gl_FUNC_TZSET_CLOBBER): Likewise. * m4/ungetc.m4 (gl_FUNC_UNGETC_WORKS): Likewise. * m4/unlink-busy.m4 (gl_FUNC_UNLINK_BUSY_TEXT): Likewise. * m4/unlink.m4 (gl_FUNC_UNLINK): Likewise. * m4/usleep.m4 (gl_FUNC_USLEEP): Likewise. * m4/utimes.m4 (gl_FUNC_UTIMES): Likewise. * m4/wcrtomb.m4 (gl_FUNC_WCRTOMB): Likewise. * m4/wcsrtombs.m4 (gl_WCSRTOMBS_TERMINATION, gl_WCSRTOMBS_NULL): Likewise. * m4/wctob.m4 (gl_FUNC_WCTOB): Likewise. * m4/chown.m4 (AC_FUNC_CHOWN): Add cross-compilation guess for native Windows. Enable also on Autoconf 2.70. * m4/printf.m4 (gl_PRINTF_SIZES_C99, gl_PRINTF_LONG_DOUBLE, gl_PRINTF_INFINITE, gl_PRINTF_INFINITE_LONG_DOUBLE, gl_PRINTF_DIRECTIVE_A, gl_PRINTF_DIRECTIVE_F, gl_PRINTF_DIRECTIVE_N, gl_PRINTF_DIRECTIVE_LS, gl_PRINTF_FLAG_LEFTADJUST, gl_PRINTF_FLAG_ZERO, gl_SNPRINTF_TRUNCATION_C99, gl_SNPRINTF_RETVAL_C99, gl_SNPRINTF_DIRECTIVE_N, gl_SNPRINTF_SIZE1): Add cross-compilation guess for native Windows. (gl_PRINTF_POSITIONS, gl_PRINTF_FLAG_GROUPING, gl_VSNPRINTF_ZEROSIZE_C99): Add comment.
366 lines
12 KiB
Plaintext
366 lines
12 KiB
Plaintext
# Check prerequisites for compiling lib/c-stack.c.
|
|
|
|
# Copyright (C) 2002-2004, 2008-2017 Free Software Foundation, Inc.
|
|
# This file is free software; the Free Software Foundation
|
|
# gives unlimited permission to copy and/or distribute it,
|
|
# with or without modifications, as long as this notice is preserved.
|
|
|
|
# Written by Paul Eggert.
|
|
|
|
# serial 16
|
|
|
|
AC_DEFUN([AC_SYS_XSI_STACK_OVERFLOW_HEURISTIC],
|
|
[
|
|
AC_REQUIRE([AC_CANONICAL_HOST])
|
|
AC_CHECK_FUNCS_ONCE([setrlimit])
|
|
AC_CHECK_HEADERS_ONCE([ucontext.h])
|
|
|
|
dnl List of signals that are sent when an invalid virtual memory address
|
|
dnl is accessed, or when the stack overflows.
|
|
dnl Either { SIGSEGV } or { SIGSEGV, SIGBUS }.
|
|
case "$host_os" in
|
|
sunos4* | freebsd* | dragonfly* | openbsd* | mirbsd* | netbsd* | kfreebsd* | knetbsd*) # BSD systems
|
|
FAULT_YIELDS_SIGBUS=1 ;;
|
|
hpux*) # HP-UX
|
|
FAULT_YIELDS_SIGBUS=1 ;;
|
|
macos* | darwin*) # Mac OS X
|
|
FAULT_YIELDS_SIGBUS=1 ;;
|
|
gnu*) # Hurd
|
|
FAULT_YIELDS_SIGBUS=1 ;;
|
|
*)
|
|
FAULT_YIELDS_SIGBUS=0 ;;
|
|
esac
|
|
AC_DEFINE_UNQUOTED([FAULT_YIELDS_SIGBUS], [$FAULT_YIELDS_SIGBUS],
|
|
[Define to 1 if an invalid memory address access may yield a SIGBUS.])
|
|
|
|
AC_CACHE_CHECK([for working C stack overflow detection],
|
|
[ac_cv_sys_stack_overflow_works],
|
|
[AC_RUN_IFELSE([AC_LANG_SOURCE(
|
|
[[
|
|
#include <unistd.h>
|
|
#include <signal.h>
|
|
#if HAVE_SETRLIMIT
|
|
# include <sys/types.h>
|
|
# include <sys/time.h>
|
|
# include <sys/resource.h>
|
|
#endif
|
|
#ifndef SIGSTKSZ
|
|
# define SIGSTKSZ 16384
|
|
#endif
|
|
|
|
static union
|
|
{
|
|
char buffer[2 * SIGSTKSZ];
|
|
long double ld;
|
|
long u;
|
|
void *p;
|
|
} alternate_signal_stack;
|
|
|
|
static void
|
|
segv_handler (int signo)
|
|
{
|
|
_exit (0);
|
|
}
|
|
|
|
static int
|
|
c_stack_action ()
|
|
{
|
|
stack_t st;
|
|
struct sigaction act;
|
|
int r;
|
|
|
|
st.ss_flags = 0;
|
|
/* Use the midpoint to avoid Irix sigaltstack bug. */
|
|
st.ss_sp = alternate_signal_stack.buffer + SIGSTKSZ;
|
|
st.ss_size = SIGSTKSZ;
|
|
r = sigaltstack (&st, 0);
|
|
if (r != 0)
|
|
return 1;
|
|
|
|
sigemptyset (&act.sa_mask);
|
|
act.sa_flags = SA_NODEFER | SA_ONSTACK | SA_RESETHAND;
|
|
act.sa_handler = segv_handler;
|
|
#if FAULT_YIELDS_SIGBUS
|
|
if (sigaction (SIGBUS, &act, 0) < 0)
|
|
return 2;
|
|
#endif
|
|
if (sigaction (SIGSEGV, &act, 0) < 0)
|
|
return 3;
|
|
return 0;
|
|
}
|
|
static volatile int *
|
|
recurse_1 (volatile int n, volatile int *p)
|
|
{
|
|
if (n >= 0)
|
|
*recurse_1 (n + 1, p) += n;
|
|
return p;
|
|
}
|
|
static int
|
|
recurse (volatile int n)
|
|
{
|
|
int sum = 0;
|
|
return *recurse_1 (n, &sum);
|
|
}
|
|
int
|
|
main ()
|
|
{
|
|
int result;
|
|
#if HAVE_SETRLIMIT && defined RLIMIT_STACK
|
|
/* Before starting the endless recursion, try to be friendly
|
|
to the user's machine. On some Linux 2.2.x systems, there
|
|
is no stack limit for user processes at all. We don't want
|
|
to kill such systems. */
|
|
struct rlimit rl;
|
|
rl.rlim_cur = rl.rlim_max = 0x100000; /* 1 MB */
|
|
setrlimit (RLIMIT_STACK, &rl);
|
|
#endif
|
|
|
|
result = c_stack_action ();
|
|
if (result != 0)
|
|
return result;
|
|
return recurse (0);
|
|
}
|
|
]])],
|
|
[ac_cv_sys_stack_overflow_works=yes],
|
|
[ac_cv_sys_stack_overflow_works=no],
|
|
[case "$host_os" in
|
|
# Guess no on native Windows.
|
|
mingw*) ac_cv_sys_stack_overflow_works="guessing no" ;;
|
|
*) ac_cv_sys_stack_overflow_works=cross-compiling ;;
|
|
esac
|
|
])
|
|
])
|
|
|
|
if test "$ac_cv_sys_stack_overflow_works" = yes; then
|
|
AC_DEFINE([HAVE_STACK_OVERFLOW_HANDLING], [1],
|
|
[Define to 1 if extending the stack slightly past the limit causes
|
|
a SIGSEGV which can be handled on an alternate stack established
|
|
with sigaltstack.])
|
|
|
|
dnl The ss_sp field of a stack_t is, according to POSIX, the lowest address
|
|
dnl of the memory block designated as an alternate stack. But IRIX 5.3
|
|
dnl interprets it as the highest address!
|
|
AC_CACHE_CHECK([for correct stack_t interpretation],
|
|
[gl_cv_sigaltstack_low_base], [
|
|
AC_RUN_IFELSE([
|
|
AC_LANG_SOURCE([[
|
|
#include <stdlib.h>
|
|
#include <signal.h>
|
|
#if HAVE_SYS_SIGNAL_H
|
|
# include <sys/signal.h>
|
|
#endif
|
|
#ifndef SIGSTKSZ
|
|
# define SIGSTKSZ 16384
|
|
#endif
|
|
volatile char *stack_lower_bound;
|
|
volatile char *stack_upper_bound;
|
|
static void check_stack_location (volatile char *addr)
|
|
{
|
|
if (addr >= stack_lower_bound && addr <= stack_upper_bound)
|
|
exit (0);
|
|
else
|
|
exit (1);
|
|
}
|
|
static void stackoverflow_handler (int sig)
|
|
{
|
|
char dummy;
|
|
check_stack_location (&dummy);
|
|
}
|
|
int main ()
|
|
{
|
|
char mystack[2 * SIGSTKSZ];
|
|
stack_t altstack;
|
|
struct sigaction action;
|
|
/* Install the alternate stack. */
|
|
altstack.ss_sp = mystack + SIGSTKSZ;
|
|
altstack.ss_size = SIGSTKSZ;
|
|
stack_lower_bound = (char *) altstack.ss_sp;
|
|
stack_upper_bound = (char *) altstack.ss_sp + altstack.ss_size - 1;
|
|
altstack.ss_flags = 0; /* no SS_DISABLE */
|
|
if (sigaltstack (&altstack, NULL) < 0)
|
|
exit (2);
|
|
/* Install the SIGSEGV handler. */
|
|
sigemptyset (&action.sa_mask);
|
|
action.sa_handler = &stackoverflow_handler;
|
|
action.sa_flags = SA_ONSTACK;
|
|
if (sigaction (SIGSEGV, &action, (struct sigaction *) NULL) < 0)
|
|
exit(3);
|
|
/* Provoke a SIGSEGV. */
|
|
raise (SIGSEGV);
|
|
exit (4);
|
|
}]])],
|
|
[gl_cv_sigaltstack_low_base=yes],
|
|
[gl_cv_sigaltstack_low_base=no],
|
|
[gl_cv_sigaltstack_low_base=cross-compiling])])
|
|
if test "$gl_cv_sigaltstack_low_base" = no; then
|
|
AC_DEFINE([SIGALTSTACK_SS_REVERSED], [1],
|
|
[Define if sigaltstack() interprets the stack_t.ss_sp field
|
|
incorrectly, as the highest address of the alternate stack range
|
|
rather than as the lowest address.])
|
|
fi
|
|
|
|
AC_CACHE_CHECK([for precise C stack overflow detection],
|
|
[ac_cv_sys_xsi_stack_overflow_heuristic],
|
|
[AC_RUN_IFELSE([AC_LANG_SOURCE(
|
|
[[
|
|
#include <unistd.h>
|
|
#include <signal.h>
|
|
#if HAVE_UCONTEXT_H
|
|
# include <ucontext.h>
|
|
#endif
|
|
#if HAVE_SETRLIMIT
|
|
# include <sys/types.h>
|
|
# include <sys/time.h>
|
|
# include <sys/resource.h>
|
|
#endif
|
|
#ifndef SIGSTKSZ
|
|
# define SIGSTKSZ 16384
|
|
#endif
|
|
|
|
static union
|
|
{
|
|
char buffer[2 * SIGSTKSZ];
|
|
long double ld;
|
|
long u;
|
|
void *p;
|
|
} alternate_signal_stack;
|
|
|
|
#if STACK_DIRECTION
|
|
# define find_stack_direction(ptr) STACK_DIRECTION
|
|
#else
|
|
static int
|
|
find_stack_direction (char const *addr)
|
|
{
|
|
char dummy;
|
|
return (! addr ? find_stack_direction (&dummy)
|
|
: addr < &dummy ? 1 : -1);
|
|
}
|
|
#endif
|
|
|
|
static void
|
|
segv_handler (int signo, siginfo_t *info, void *context)
|
|
{
|
|
if (0 < info->si_code)
|
|
{
|
|
/* For XSI heuristics to work, we need uc_stack to describe
|
|
the interrupted stack (as on Solaris), and not the
|
|
currently executing stack (as on Linux). */
|
|
ucontext_t const *user_context = context;
|
|
char const *stack_min = user_context->uc_stack.ss_sp;
|
|
size_t stack_size = user_context->uc_stack.ss_size;
|
|
char const *faulting_address = info->si_addr;
|
|
size_t s = faulting_address - stack_min;
|
|
size_t page_size = sysconf (_SC_PAGESIZE);
|
|
if (find_stack_direction (0) < 0)
|
|
s += page_size;
|
|
if (s < stack_size + page_size)
|
|
_exit (0);
|
|
_exit (4);
|
|
}
|
|
_exit (5);
|
|
}
|
|
|
|
static int
|
|
c_stack_action ()
|
|
{
|
|
stack_t st;
|
|
struct sigaction act;
|
|
int r;
|
|
|
|
st.ss_flags = 0;
|
|
/* Use the midpoint to avoid Irix sigaltstack bug. */
|
|
st.ss_sp = alternate_signal_stack.buffer + SIGSTKSZ;
|
|
st.ss_size = SIGSTKSZ;
|
|
r = sigaltstack (&st, 0);
|
|
if (r != 0)
|
|
return 1;
|
|
|
|
sigemptyset (&act.sa_mask);
|
|
act.sa_flags = SA_NODEFER | SA_ONSTACK | SA_RESETHAND | SA_SIGINFO;
|
|
act.sa_sigaction = segv_handler;
|
|
#if FAULT_YIELDS_SIGBUS
|
|
if (sigaction (SIGBUS, &act, 0) < 0)
|
|
return 2;
|
|
#endif
|
|
if (sigaction (SIGSEGV, &act, 0) < 0)
|
|
return 3;
|
|
return 0;
|
|
}
|
|
static volatile int *
|
|
recurse_1 (volatile int n, volatile int *p)
|
|
{
|
|
if (n >= 0)
|
|
*recurse_1 (n + 1, p) += n;
|
|
return p;
|
|
}
|
|
static int
|
|
recurse (volatile int n)
|
|
{
|
|
int sum = 0;
|
|
return *recurse_1 (n, &sum);
|
|
}
|
|
int
|
|
main ()
|
|
{
|
|
int result;
|
|
#if HAVE_SETRLIMIT && defined RLIMIT_STACK
|
|
/* Before starting the endless recursion, try to be friendly
|
|
to the user's machine. On some Linux 2.2.x systems, there
|
|
is no stack limit for user processes at all. We don't want
|
|
to kill such systems. */
|
|
struct rlimit rl;
|
|
rl.rlim_cur = rl.rlim_max = 0x100000; /* 1 MB */
|
|
setrlimit (RLIMIT_STACK, &rl);
|
|
#endif
|
|
|
|
result = c_stack_action ();
|
|
if (result != 0)
|
|
return result;
|
|
return recurse (0);
|
|
}
|
|
]])],
|
|
[ac_cv_sys_xsi_stack_overflow_heuristic=yes],
|
|
[ac_cv_sys_xsi_stack_overflow_heuristic=no],
|
|
[ac_cv_sys_xsi_stack_overflow_heuristic=cross-compiling])])
|
|
|
|
if test $ac_cv_sys_xsi_stack_overflow_heuristic = yes; then
|
|
AC_DEFINE([HAVE_XSI_STACK_OVERFLOW_HEURISTIC], [1],
|
|
[Define to 1 if extending the stack slightly past the limit causes
|
|
a SIGSEGV, and an alternate stack can be established with sigaltstack,
|
|
and the signal handler is passed a context that specifies the
|
|
run time stack. This behavior is defined by POSIX 1003.1-2001
|
|
with the X/Open System Interface (XSI) option
|
|
and is a standardized way to implement a SEGV-based stack
|
|
overflow detection heuristic.])
|
|
fi
|
|
fi])
|
|
|
|
|
|
AC_DEFUN([gl_PREREQ_C_STACK],
|
|
[AC_REQUIRE([AC_SYS_XSI_STACK_OVERFLOW_HEURISTIC])
|
|
AC_REQUIRE([gl_LIBSIGSEGV])
|
|
|
|
# for STACK_DIRECTION
|
|
AC_REQUIRE([AC_FUNC_ALLOCA])
|
|
|
|
AC_CHECK_FUNCS_ONCE([sigaltstack])
|
|
AC_CHECK_DECLS([sigaltstack], , , [[#include <signal.h>]])
|
|
|
|
AC_CHECK_HEADERS_ONCE([unistd.h ucontext.h])
|
|
|
|
AC_CHECK_TYPES([stack_t], , , [#include <signal.h>])
|
|
|
|
dnl c-stack does not need -lsigsegv if the system has XSI heuristics.
|
|
if test "$gl_cv_lib_sigsegv" = yes \
|
|
&& test $"ac_cv_sys_xsi_stack_overflow_heuristic" != yes ; then
|
|
AC_SUBST([LIBCSTACK], [$LIBSIGSEGV])
|
|
AC_SUBST([LTLIBCSTACK], [$LTLIBSIGSEGV])
|
|
fi
|
|
])
|
|
|
|
AC_DEFUN([gl_C_STACK],
|
|
[
|
|
dnl Prerequisites of lib/c-stack.c.
|
|
gl_PREREQ_C_STACK
|
|
])
|