From 2dc33d421eaa01c42a337f5f0dedc62db17f3874 Mon Sep 17 00:00:00 2001 From: Jim Meyering Date: Sun, 26 Dec 1999 09:40:16 +0000 Subject: *** empty log message *** --- lib/nanosleep.c | 40 ++++++++++++++++++++++++++++++++++++++-- 1 file changed, 38 insertions(+), 2 deletions(-) (limited to 'lib/nanosleep.c') diff --git a/lib/nanosleep.c b/lib/nanosleep.c index b833c01f4..b51f648c7 100644 --- a/lib/nanosleep.c +++ b/lib/nanosleep.c @@ -18,8 +18,9 @@ /* written by Jim Meyering */ #include - +#include #include +#include #include /* FIXME: is including both like this kosher? */ @@ -27,6 +28,26 @@ static interrupted; +/* Handle SIGCONT. */ + +static void +sighandler (int sig) +{ +#ifdef SA_INTERRUPT + struct sigaction sigact; + + sigact.sa_handler = SIG_DFL; + sigemptyset (&sigact.sa_mask); + sigact.sa_flags = 0; + sigaction (sig, &sigact, NULL); +#else + signal (sig, SIG_DFL); +#endif + + suspended = 1; + kill (getpid (), sig); +} + /* Sleep for USEC microseconds. */ static void @@ -42,10 +63,25 @@ int nanosleep (const struct timespec *requested_delay, struct timespec *remaining_delay) { +#ifdef SA_INTERRUPT + struct sigaction oldact, newact; +#endif + interrupted = 0; /* set up sig handler -- but maybe only do this the first time? */ - /* FIXME */ +#ifdef SA_INTERRUPT + newact.sa_handler = sighandler; + sigemptyset (&newact.sa_mask); + newact.sa_flags = 0; + + sigaction (SIGCONT, NULL, &oldact); + if (oldact.sa_handler != SIG_IGN) + sigaction (SIGCONT, &newact, NULL); +#else + if (signal (SIGCONT, SIG_IGN) != SIG_IGN) + signal (SIGCONT, sighandler); +#endif usleep (requested_delay); -- cgit v1.2.3-54-g00ecf