Commit 31ddad67b6a56969eba251d549b96539c0975586

Con Kolivas 2012-07-11T23:00:52

Merge pull request #263 from luke-jr/bugfix_nmsleep Bugfix: Calculate nsec in nmsleep correctly

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
diff --git a/util.c b/util.c
index c6b8204..822e61d 100644
--- a/util.c
+++ b/util.c
@@ -694,9 +694,11 @@ void nmsleep(unsigned int msecs)
 {
 	struct timespec twait, tleft;
 	int ret;
+	ldiv_t d;
 
-	tleft.tv_sec = msecs / 1000;
-	tleft.tv_nsec = (uint64_t)(msecs * 1000000) - (uint64_t)(twait.tv_sec / 1000000000);
+	d = ldiv(msecs, 1000);
+	tleft.tv_sec = d.quot;
+	tleft.tv_nsec = d.rem * 1000000;
 	do {
 		twait.tv_sec = tleft.tv_sec;
 		twait.tv_nsec = tleft.tv_nsec;