blob: 4cfac57be0245e7cc8401a9ea1e855cdcd2c3b44 [file] [log] [blame]
The Android Open Source Projectcbb10112009-03-03 19:31:44 -08001/*
2 * Copyright (C) 2005 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
The Android Open Source Projectcbb10112009-03-03 19:31:44 -080017#include <utils/Timers.h>
The Android Open Source Projectcbb10112009-03-03 19:31:44 -080018
Yabin Cui4a6e5a32015-01-26 19:48:54 -080019#include <limits.h>
Elliott Hughes842e1cc2020-05-27 12:24:30 -070020#include <stdlib.h>
The Android Open Source Projectcbb10112009-03-03 19:31:44 -080021#include <time.h>
The Android Open Source Projectcbb10112009-03-03 19:31:44 -080022
Elliott Hughes842e1cc2020-05-27 12:24:30 -070023#include <android-base/macros.h>
Elliott Hughes4139da62021-05-18 13:10:07 -070024#include <utils/Log.h>
Elliott Hughes842e1cc2020-05-27 12:24:30 -070025
26static constexpr size_t clock_id_max = 5;
27
28static void checkClockId(int clock) {
Elliott Hughes4139da62021-05-18 13:10:07 -070029 LOG_ALWAYS_FATAL_IF(clock < 0 || clock >= clock_id_max, "invalid clock id");
Elliott Hughes842e1cc2020-05-27 12:24:30 -070030}
31
Brett Chabot1af6acc2019-09-17 13:23:59 -070032#if defined(__linux__)
Elliott Hughes842e1cc2020-05-27 12:24:30 -070033nsecs_t systemTime(int clock) {
34 checkClockId(clock);
35 static constexpr clockid_t clocks[] = {CLOCK_REALTIME, CLOCK_MONOTONIC,
36 CLOCK_PROCESS_CPUTIME_ID, CLOCK_THREAD_CPUTIME_ID,
37 CLOCK_BOOTTIME};
38 static_assert(clock_id_max == arraysize(clocks));
39 timespec t = {};
The Android Open Source Projectcbb10112009-03-03 19:31:44 -080040 clock_gettime(clocks[clock], &t);
41 return nsecs_t(t.tv_sec)*1000000000LL + t.tv_nsec;
Mark Salyzyn5bed8032014-04-30 11:10:46 -070042}
The Android Open Source Projectcbb10112009-03-03 19:31:44 -080043#else
Elliott Hughes842e1cc2020-05-27 12:24:30 -070044nsecs_t systemTime(int clock) {
45 // TODO: is this ever called with anything but REALTIME on mac/windows?
46 checkClockId(clock);
47
Narayan Kamathea659642014-04-10 18:40:55 +010048 // Clock support varies widely across hosts. Mac OS doesn't support
Elliott Hughes842e1cc2020-05-27 12:24:30 -070049 // CLOCK_BOOTTIME (and doesn't even have clock_gettime until 10.12).
50 // Windows is windows.
51 timeval t = {};
Yi Konge1731a42018-07-16 18:11:34 -070052 gettimeofday(&t, nullptr);
The Android Open Source Projectcbb10112009-03-03 19:31:44 -080053 return nsecs_t(t.tv_sec)*1000000000LL + nsecs_t(t.tv_usec)*1000LL;
The Android Open Source Projectcbb10112009-03-03 19:31:44 -080054}
Mark Salyzyn5bed8032014-04-30 11:10:46 -070055#endif
The Android Open Source Projectcbb10112009-03-03 19:31:44 -080056
Elliott Hughes4139da62021-05-18 13:10:07 -070057int toMillisecondTimeoutDelay(nsecs_t referenceTime, nsecs_t timeoutTime) {
58 if (timeoutTime <= referenceTime) return 0;
59
60 uint64_t timeoutDelay = uint64_t(timeoutTime - referenceTime);
61 if (timeoutDelay > uint64_t((INT_MAX - 1) * 1000000LL)) return -1;
62 return (timeoutDelay + 999999LL) / 1000000LL;
Jeff Brown43550ee2011-03-17 01:34:19 -070063}