[Ffmpeg-cvslog] r8727 - trunk/configure
mru
subversion
Fri Apr 13 22:16:13 CEST 2007
Author: mru
Date: Fri Apr 13 22:16:13 2007
New Revision: 8727
Modified:
trunk/configure
Log:
trap signals in tests that can crash
Modified: trunk/configure
==============================================================================
--- trunk/configure (original)
+++ trunk/configure Fri Apr 13 22:16:13 2007
@@ -485,6 +485,32 @@ check_exec(){
check_ld "$@" && { enabled cross_compile || $TMPE >>$logfile 2>&1; }
}
+check_exec_crash(){
+ code=`cat`
+
+ # exit() is not async signal safe. _Exit (C99) and _exit (POSIX)
+ # are safe but may not be available everywhere. Thus we use
+ # raise(SIGTERM) instead. The check is run in a subshell so we
+ # can redirect the "Terminated" message from the shell. SIGBUS
+ # is not defined by standard C so it is used conditionally.
+
+ (check_exec "$@") >>$logfile 2>&1 <<EOF
+#include <signal.h>
+static void sighandler(int sig){
+ raise(SIGTERM);
+}
+int main(){
+ signal(SIGILL, sighandler);
+ signal(SIGFPE, sighandler);
+ signal(SIGSEGV, sighandler);
+#ifdef SIGBUS
+ signal(SIGBUS, sighandler);
+#endif
+ { $code }
+}
+EOF
+}
+
require(){
name="$1"
header="$2"
@@ -1191,10 +1217,6 @@ ar="${cross_prefix}${ar}"
ranlib="${cross_prefix}${ranlib}"
strip="${cross_prefix}${strip}"
-# Disable core dumps so that intentional execution of broken apps doesn't
-# pollute the current directory.
-ulimit -c 0 >/dev/null 2>&1
-
# we need to build at least one lib type
if disabled_all static shared; then
cat <<EOF
@@ -1397,26 +1419,16 @@ if test "$?" != 0; then
fi
if test $arch = "x86_32" -o $arch = "x86_64"; then
- if test "$targetos" = mingw32 -o "$targetos" = cygwin; then
- cat <<EOF
-WARNING: The following test might cause a testapp to crash (intentionally)
-resulting in the appearance of a dialog box. Please click "Don't send" and
-ignore it.
-EOF
- fi
-
# check whether EBP is available on x86
# As 'i' is stored on the stack, this program will crash
# if the base pointer is used to access it because the
# base pointer is cleared in the inline assembly code.
- (check_exec) <<EOF >>$logfile 2>&1 && enable ebp_available
-int main(){
+ check_exec_crash <<EOF && enable ebp_available
volatile int i=0;
asm volatile (
"xorl %%ebp, %%ebp"
::: "%ebp");
return i;
-}
EOF
# check wether EBX is available on x86
More information about the ffmpeg-cvslog
mailing list