You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
25 lines
859 B
25 lines
859 B
4 months ago
|
/* Copyright (c) 2010 The Chromium OS Authors. All rights reserved.
|
||
|
* Use of this source code is governed by a BSD-style license that can be
|
||
|
* found in the LICENSE file.
|
||
|
*/
|
||
|
|
||
|
#include "timer_utils.h"
|
||
|
|
||
|
void StartTimer(ClockTimerState* ct) {
|
||
|
clock_gettime(CLOCK_REALTIME, &ct->start_time);
|
||
|
}
|
||
|
|
||
|
void StopTimer(ClockTimerState* ct) {
|
||
|
clock_gettime(CLOCK_REALTIME, &ct->end_time);
|
||
|
}
|
||
|
|
||
|
uint32_t GetDurationMsecs(ClockTimerState* ct) {
|
||
|
uint64_t start = ((uint64_t) ct->start_time.tv_sec * 1000000000 +
|
||
|
(uint64_t) ct->start_time.tv_nsec);
|
||
|
uint64_t end = ((uint64_t) ct->end_time.tv_sec * 1000000000 +
|
||
|
(uint64_t) ct->end_time.tv_nsec);
|
||
|
uint64_t duration_msecs = (end - start) / 1000000U; /* Nanoseconds ->
|
||
|
* Milliseconds. */
|
||
|
return (uint32_t) duration_msecs;
|
||
|
}
|