summary |
shortlog |
log |
commit | commitdiff |
tree
raw |
patch |
inline | side by side (from parent 1:
4e991c2)
Don't assume usec_sleep() is extremely precise.
Signed-off-by: Jens Axboe <jens.axboe@oracle.com>
unsigned long s = usec_cycle - time_spent;
td->rate_pending_usleep += s;
unsigned long s = usec_cycle - time_spent;
td->rate_pending_usleep += s;
if (td->rate_pending_usleep >= 100000) {
if (td->rate_pending_usleep >= 100000) {
+ struct timeval t;
+
+ fio_gettime(&t, NULL);
usec_sleep(td, td->rate_pending_usleep);
usec_sleep(td, td->rate_pending_usleep);
- td->rate_pending_usleep = 0;
+ td->rate_pending_usleep -= utime_since_now(&t);
}
} else {
long overtime = time_spent - usec_cycle;
}
} else {
long overtime = time_spent - usec_cycle;