X-Git-Url: http://erislabs.net/gitweb/?a=blobdiff_plain;f=lib%2Fnanosleep.c;h=7a7cc02fd987c9cf8d77ec0f0533b11b6ce80c20;hb=fa3486514bd8f15f8eb4c49821d0356b52e5a335;hp=456e745ca044545c618647db06a86cd005440630;hpb=57fdfd3f8ec62b105c53bcdf6f127c35c7fe7391;p=gnulib.git diff --git a/lib/nanosleep.c b/lib/nanosleep.c index 456e745ca..7a7cc02fd 100644 --- a/lib/nanosleep.c +++ b/lib/nanosleep.c @@ -1,6 +1,6 @@ /* Provide a replacement for the POSIX nanosleep function. - Copyright (C) 1999, 2000, 2002, 2004, 2005, 2006, 2007 Free + Copyright (C) 1999, 2000, 2002, 2004, 2005, 2006, 2007, 2008 Free Software Foundation, Inc. This program is free software: you can redistribute it and/or modify @@ -22,14 +22,13 @@ #include +#include "sig-handler.h" #include "timespec.h" #include #include #include -#if HAVE_SYS_SELECT_H -# include -#endif +#include #include #include @@ -43,7 +42,7 @@ enum { BILLION = 1000 * 1000 * 1000 }; #if HAVE_BUG_BIG_NANOSLEEP -void +static void getnow (struct timespec *t) { # if defined CLOCK_MONOTONIC && HAVE_CLOCK_GETTIME @@ -104,10 +103,6 @@ rpl_nanosleep (const struct timespec *requested_delay, # define SIGCONT SIGTERM # endif -# if ! HAVE_SIGINTERRUPT -# define siginterrupt(sig, flag) /* empty */ -# endif - static sig_atomic_t volatile suspended; /* Handle SIGCONT. */ @@ -152,22 +147,18 @@ rpl_nanosleep (const struct timespec *requested_delay, /* set up sig handler */ if (! initialized) { -# ifdef SA_NOCLDSTOP - struct sigaction oldact, newact; - newact.sa_handler = sighandler; - sigemptyset (&newact.sa_mask); - newact.sa_flags = 0; + struct sigaction oldact; sigaction (SIGCONT, NULL, &oldact); - if (oldact.sa_handler != SIG_IGN) - sigaction (SIGCONT, &newact, NULL); -# else - if (signal (SIGCONT, SIG_IGN) != SIG_IGN) + if (get_handler (&oldact) != SIG_IGN) { - signal (SIGCONT, sighandler); - siginterrupt (SIGCONT, 1); + struct sigaction newact; + + newact.sa_handler = sighandler; + sigemptyset (&newact.sa_mask); + newact.sa_flags = 0; + sigaction (SIGCONT, &newact, NULL); } -# endif initialized = true; }