OLD | NEW |
1 // Copyright (c) 2009 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2009 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 // | 4 // |
5 // High resolution timer functions for use in Linux. | 5 // High resolution timer functions for use in Linux. |
6 | 6 |
7 #include "chrome/browser/sync/util/highres_timer.h" | 7 #include "chrome/browser/sync/util/highres_timer.h" |
8 | 8 |
9 const uint64 MICROS_IN_MILLI = 1000L; | 9 const uint64 MICROS_IN_MILLI = 1000L; |
10 const uint64 MICROS_IN_HALF_MILLI = 500L; | 10 const uint64 MICROS_IN_HALF_MILLI = 500L; |
11 const uint64 MICROS_IN_HALF_SECOND = 500000L; | 11 const uint64 MICROS_IN_HALF_SECOND = 500000L; |
12 | 12 |
13 uint64 HighresTimer::GetElapsedMs() const { | 13 uint64 HighresTimer::GetElapsedMs() const { |
14 uint64 end_time = GetCurrentTicks(); | 14 uint64 end_time = GetCurrentTicks(); |
15 | 15 |
16 // Scale to ms and round to nearest ms - rounding is important because | 16 // Scale to ms and round to nearest ms - rounding is important because |
17 // otherwise the truncation error may accumulate e.g. in sums. | 17 // otherwise the truncation error may accumulate e.g. in sums. |
18 return (uint64(end_time - start_ticks_) + MICROS_IN_HALF_MILLI) / | 18 return (uint64(end_time - start_ticks_) + MICROS_IN_HALF_MILLI) / |
19 MICROS_IN_MILLI; | 19 MICROS_IN_MILLI; |
20 } | 20 } |
21 | 21 |
22 uint64 HighresTimer::GetElapsedSec() const { | 22 uint64 HighresTimer::GetElapsedSec() const { |
23 uint64 end_time = GetCurrentTicks(); | 23 uint64 end_time = GetCurrentTicks(); |
24 | 24 |
25 // Scale to ms and round to nearest ms - rounding is important because | 25 // Scale to ms and round to nearest ms - rounding is important because |
26 // otherwise the truncation error may accumulate e.g. in sums. | 26 // otherwise the truncation error may accumulate e.g. in sums. |
27 return (uint64(end_time - start_ticks_) + MICROS_IN_HALF_SECOND) / | 27 return (uint64(end_time - start_ticks_) + MICROS_IN_HALF_SECOND) / |
28 MICROS_IN_SECOND; | 28 MICROS_IN_SECOND; |
29 } | 29 } |
OLD | NEW |