From 95192e8f55193ed0e4619c6192dbab1c23eb84d8 Mon Sep 17 00:00:00 2001 From: jilles Date: Tue, 28 May 2013 22:07:31 +0000 Subject: sleep: Improve nanosleep() error handling: * Work around kernel bugs that cause a spurious [EINTR] return if a debugger (such as truss(1)) is attached. * Write an error message if an error other than [EINTR] occurs. PR: bin/178664 --- bin/sleep/sleep.c | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) (limited to 'bin/sleep') diff --git a/bin/sleep/sleep.c b/bin/sleep/sleep.c index fa7deb2..0d41a42 100644 --- a/bin/sleep/sleep.c +++ b/bin/sleep/sleep.c @@ -43,6 +43,7 @@ __FBSDID("$FreeBSD$"); #include #include +#include #include #include #include @@ -87,8 +88,8 @@ main(int argc, char *argv[]) warnx("about %d second(s) left out of the original %d", (int)time_to_sleep.tv_sec, (int)original); report_requested = 0; - } else - break; + } else if (errno != EINTR) + err(1, "nanosleep"); } return (0); } -- cgit v1.1