Chromium Code Reviews| Index: src/base/platform/time.cc |
| diff --git a/src/base/platform/time.cc b/src/base/platform/time.cc |
| index e7867e07955a1094ebd6135210f6b473cfd73339..12393b7e7c64d76cfe362463f214f4c8a3152ba3 100644 |
| --- a/src/base/platform/time.cc |
| +++ b/src/base/platform/time.cc |
| @@ -56,6 +56,17 @@ int64_t ComputeThreadTicks() { |
| V8_INLINE int64_t ClockNow(clockid_t clk_id) { |
| #if (defined(_POSIX_MONOTONIC_CLOCK) && _POSIX_MONOTONIC_CLOCK >= 0) || \ |
| defined(V8_OS_BSD) || defined(V8_OS_ANDROID) |
| +// On AIX clock_gettime for CLOCK_THREAD_CPUTIME_ID outputs time with |
| +// resolution of 10ms. thread_cputime API provides the time in ns |
| +#if defined(V8_OS_AIX) |
| + thread_cputime_t tc; |
| + if (clk_id == CLOCK_THREAD_CPUTIME_ID) { |
| + if (thread_cputime(-1, &tc) != 0) { |
| + UNREACHABLE(); |
| + return 0; |
| + } |
| + } |
| +#endif |
| struct timespec ts; |
|
lpy
2016/07/22 22:47:29
hmmmm, what happen when clk_id is CLOCK_THREAD_CPU
|
| if (clock_gettime(clk_id, &ts) != 0) { |
| UNREACHABLE(); |
| @@ -63,7 +74,15 @@ V8_INLINE int64_t ClockNow(clockid_t clk_id) { |
| } |
| v8::base::internal::CheckedNumeric<int64_t> result(ts.tv_sec); |
| result *= v8::base::Time::kMicrosecondsPerSecond; |
| +#if defined(V8_OS_AIX) |
| + if (clk_id == CLOCK_THREAD_CPUTIME_ID) { |
| + result += (tc.stime / v8::base::Time::kNanosecondsPerMicrosecond); |
| + } else { |
| result += (ts.tv_nsec / v8::base::Time::kNanosecondsPerMicrosecond); |
|
lpy
2016/07/22 22:47:30
wrong indentation.
|
| + } |
| +#else |
| + result += (ts.tv_nsec / v8::base::Time::kNanosecondsPerMicrosecond); |
| +#endif |
| return result.ValueOrDie(); |
| #else // Monotonic clock not supported. |
| return 0; |