#include "base/time/time.h"
#include <threads.h>
#include <zircon/syscalls.h>
#include <zircon/threads.h>
#include "base/check_op.h"
#include "base/fuchsia/fuchsia_logging.h"
#include "base/time/time_override.h"
namespace base {
namespace subtle {
Time TimeNowIgnoringOverride() {
timespec ts;
int status = timespec_get(&ts, TIME_UTC);
CHECK(status != 0);
return Time::FromTimeSpec(ts);
}
Time TimeNowFromSystemTimeIgnoringOverride() {
return TimeNowIgnoringOverride();
}
}
namespace subtle {
TimeTicks TimeTicksNowIgnoringOverride() {
const zx_time_t nanos_since_boot = zx_clock_get_monotonic();
CHECK_NE(0, nanos_since_boot);
return TimeTicks::FromZxTime(nanos_since_boot);
}
TimeTicks TimeTicksLowResolutionNowIgnoringOverride() {
return TimeTicksNowIgnoringOverride();
}
}
TimeDelta TimeDelta::FromZxDuration(zx_duration_t nanos) {
return Nanoseconds(nanos);
}
zx_duration_t TimeDelta::ToZxDuration() const {
return InNanoseconds();
}
Time Time::FromZxTime(zx_time_t nanos_since_unix_epoch) {
return UnixEpoch() + Nanoseconds(nanos_since_unix_epoch);
}
zx_time_t Time::ToZxTime() const {
return (*this - UnixEpoch()).InNanoseconds();
}
TimeTicks::Clock TimeTicks::GetClock() {
return Clock::FUCHSIA_ZX_CLOCK_MONOTONIC;
}
bool TimeTicks::IsHighResolution() {
return true;
}
bool TimeTicks::IsConsistentAcrossProcesses() {
return true;
}
TimeTicks TimeTicks::FromZxTime(zx_time_t nanos_since_boot) {
return TimeTicks() + Nanoseconds(nanos_since_boot);
}
zx_time_t TimeTicks::ToZxTime() const {
return (*this - TimeTicks()).InNanoseconds();
}
namespace subtle {
ThreadTicks ThreadTicksNowIgnoringOverride() {
zx_info_thread_stats_t info;
zx_status_t status = zx_object_get_info(thrd_get_zx_handle(thrd_current()),
ZX_INFO_THREAD_STATS, &info,
sizeof(info), nullptr, nullptr);
ZX_CHECK(status == ZX_OK, status);
return ThreadTicks() + Nanoseconds(info.total_runtime);
}
}
}