Index: runtime/bin/utils_linux.cc |
diff --git a/runtime/bin/utils_linux.cc b/runtime/bin/utils_linux.cc |
index 66e6929371936be9c7595e94f094a8fab0acdc06..9918c3a7a294b2e9d92848dc7577b10481321252 100644 |
--- a/runtime/bin/utils_linux.cc |
+++ b/runtime/bin/utils_linux.cc |
@@ -96,7 +96,16 @@ int64_t TimerUtils::GetCurrentTimeMicros() { |
} |
void TimerUtils::Sleep(int64_t millis) { |
- usleep(millis * 1000); |
+ // We must loop here because SIGPROF will interrupt usleep. |
+ int64_t micros = millis * 1000; |
+ int64_t start = GetCurrentTimeMicros(); |
+ while (micros > 0) { |
+ usleep(micros); |
+ int64_t now = GetCurrentTimeMicros(); |
+ int64_t delta = now - start; |
siva
2013/10/28 05:19:21
ASSERT(delta >= 0);
Cutch
2013/11/04 20:36:05
Done.
|
+ start = now; |
+ micros -= delta; |
+ } |
} |
} // namespace bin |