Improve test-skeleton.c to clean up after dead parent.

This commit is contained in:
Ulrich Drepper 2009-08-14 00:42:51 -07:00
parent ae0d545003
commit 85fda49b96
2 changed files with 19 additions and 3 deletions

View File

@ -1,3 +1,10 @@
2009-08-14 Ulrich Drepper <drepper@redhat.com>
* test-skeleton.c (signal_handler): Renamed from timeout_handler.
Also handle SIGINT. In that case only do the cleanup and then
re-raise the signal.
(main): Install handler for SIGINT.
2009-08-10 SUGIOKA Toshinobu <sugioka@itonet.co.jp> 2009-08-10 SUGIOKA Toshinobu <sugioka@itonet.co.jp>
* stdlib/longlong.h [__sh__] (udiv_qrnnd, sub_ddmmss): Add "t" to * stdlib/longlong.h [__sh__] (udiv_qrnnd, sub_ddmmss): Add "t" to

View File

@ -1,5 +1,5 @@
/* Skeleton for test programs. /* Skeleton for test programs.
Copyright (C) 1998,2000-2004, 2005 Free Software Foundation, Inc. Copyright (C) 1998,2000-2004, 2005, 2009 Free Software Foundation, Inc.
This file is part of the GNU C Library. This file is part of the GNU C Library.
Contributed by Ulrich Drepper <drepper@cygnus.com>, 1998. Contributed by Ulrich Drepper <drepper@cygnus.com>, 1998.
@ -132,7 +132,7 @@ create_temp_file (const char *base, char **filename)
/* Timeout handler. We kill the child and exit with an error. */ /* Timeout handler. We kill the child and exit with an error. */
static void static void
__attribute__ ((noreturn)) __attribute__ ((noreturn))
timeout_handler (int sig __attribute__ ((unused))) signal_handler (int sig __attribute__ ((unused)))
{ {
int killed; int killed;
int status; int status;
@ -167,6 +167,12 @@ timeout_handler (int sig __attribute__ ((unused)))
CLEANUP_HANDLER; CLEANUP_HANDLER;
#endif #endif
if (sig == SIGINT)
{
signal (sig, SIG_DFL);
raise (sig);
}
/* If we expected this signal: good! */ /* If we expected this signal: good! */
#ifdef EXPECTED_SIGNAL #ifdef EXPECTED_SIGNAL
if (EXPECTED_SIGNAL == SIGALRM) if (EXPECTED_SIGNAL == SIGALRM)
@ -325,9 +331,12 @@ main (int argc, char *argv[])
/* Default timeout is two seconds. */ /* Default timeout is two seconds. */
# define TIMEOUT 2 # define TIMEOUT 2
#endif #endif
signal (SIGALRM, timeout_handler); signal (SIGALRM, signal_handler);
alarm (TIMEOUT * timeoutfactor); alarm (TIMEOUT * timeoutfactor);
/* Make sure we clean up if the wrapper gets interrupted. */
signal (SIGINT, signal_handler);
/* Wait for the regular termination. */ /* Wait for the regular termination. */
termpid = TEMP_FAILURE_RETRY (waitpid (pid, &status, 0)); termpid = TEMP_FAILURE_RETRY (waitpid (pid, &status, 0));
if (termpid == -1) if (termpid == -1)