--- a/src/stress.c
+++ b/src/stress.c
@@ -262,6 +262,7 @@ main (int argc, char **argv)
 
       /* Calculate the backoff value so we get good fork throughput.  */
       backoff = do_backoff * forks;
+      struct timespec b = {backoff / 1000000, (backoff % 1000000) * 1000};
       dbg (stdout, "using backoff sleep of %llius\n", backoff);
 
       /* If we are supposed to respect a timeout, calculate it.  */
@@ -296,7 +297,7 @@ main (int argc, char **argv)
             {
             case 0:            /* child */
               alarm (timeout);
-              usleep (backoff);
+              nanosleep(&b, NULL);
               if (do_dryrun)
                 exit (0);
               exit (hogcpu ());
@@ -317,7 +318,7 @@ main (int argc, char **argv)
             {
             case 0:            /* child */
               alarm (timeout);
-              usleep (backoff);
+              nanosleep(&b,&b);
               if (do_dryrun)
                 exit (0);
               exit (hogio ());
@@ -337,7 +338,7 @@ main (int argc, char **argv)
             {
             case 0:            /* child */
               alarm (timeout);
-              usleep (backoff);
+              nanosleep(&b, &b);
               if (do_dryrun)
                 exit (0);
               exit (hogvm
@@ -358,7 +359,7 @@ main (int argc, char **argv)
             {
             case 0:            /* child */
               alarm (timeout);
-              usleep (backoff);
+              nanosleep(&b, &b);
               if (do_dryrun)
                 exit (0);
               exit (hoghdd (do_hdd_bytes));