2021-06-27 21:25:29 +00:00
|
|
|
/***
|
|
|
|
Copyright (C) 2021 J Reece Wilson (a/k/a "Reece"). All rights reserved.
|
|
|
|
|
|
|
|
File: Time.hpp
|
|
|
|
Date: 2021-6-17
|
|
|
|
Author: Reece
|
|
|
|
***/
|
|
|
|
#pragma once
|
|
|
|
|
2022-04-07 04:35:17 +00:00
|
|
|
#if defined(AURORA_IS_POSIX_DERIVED)
|
|
|
|
#include <time.h>
|
|
|
|
#endif
|
|
|
|
|
2021-06-27 21:25:29 +00:00
|
|
|
namespace Aurora::Time
|
|
|
|
{
|
|
|
|
#if defined(AURORA_PLATFORM_WIN32)
|
|
|
|
|
2022-04-19 21:50:34 +00:00
|
|
|
static AuInt64 ConvertTimestamp(const FILETIME &ft)
|
2021-06-27 21:25:29 +00:00
|
|
|
{
|
|
|
|
ULARGE_INTEGER ull;
|
|
|
|
ull.LowPart = ft.dwLowDateTime;
|
|
|
|
ull.HighPart = ft.dwHighDateTime;
|
2022-04-18 22:45:02 +00:00
|
|
|
return (ull.QuadPart - 126'435'537'000'000'000ull) / 10'000ULL;
|
2021-06-27 21:25:29 +00:00
|
|
|
}
|
|
|
|
|
2023-05-03 07:57:21 +00:00
|
|
|
static AuInt64 ConvertTimestampNs(const FILETIME &ft)
|
|
|
|
{
|
|
|
|
ULARGE_INTEGER ull;
|
|
|
|
ull.LowPart = ft.dwLowDateTime;
|
|
|
|
ull.HighPart = ft.dwHighDateTime;
|
|
|
|
return (ull.QuadPart - 126'435'537'000'000'000ull) * 100ULL;
|
|
|
|
}
|
|
|
|
|
2022-04-19 21:50:34 +00:00
|
|
|
static AuInt64 ConvertTimestamp(AuUInt64 timeIn)
|
2022-05-03 17:42:14 +00:00
|
|
|
{
|
2022-04-18 22:45:02 +00:00
|
|
|
return (126'435'537'000'000'000ull) + (AuUInt64(timeIn) * 10000ULL);
|
|
|
|
}
|
2021-10-03 12:43:37 +00:00
|
|
|
|
2022-05-03 17:42:14 +00:00
|
|
|
static AuInt64 ConvertTimestampNs(AuUInt64 timeIn)
|
|
|
|
{
|
|
|
|
return (126'435'537'000'000'000ull) + (AuUInt64(timeIn) / 100ULL);
|
|
|
|
}
|
|
|
|
|
2021-09-06 10:58:08 +00:00
|
|
|
#elif defined(AURORA_IS_POSIX_DERIVED)
|
2021-06-27 21:25:29 +00:00
|
|
|
|
2023-11-04 04:43:55 +00:00
|
|
|
#if defined(AURORA_IS_XNU_DERIVED)
|
|
|
|
static dispatch_time_t DispatchTimeFromAuSteadyAbsNS(AuUInt64 uSteadyTimeABSNS)
|
|
|
|
{
|
|
|
|
AuUInt64 uRet {};
|
2023-12-01 04:45:29 +00:00
|
|
|
uRet = uSteadyTimeABSNS / (1000000000ull / SteadyClockFrequency());
|
2023-11-04 04:43:55 +00:00
|
|
|
uRet &= ~((1ull << 63ull) | (1ull << 62ull));
|
|
|
|
uRet |= (1ull << 63ull);
|
|
|
|
return (dispatch_time_t)uRet;
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2022-04-19 21:50:34 +00:00
|
|
|
static AuInt64 ConvertUnixTimespecToMs(const struct timespec &spec)
|
2021-06-27 21:25:29 +00:00
|
|
|
{
|
|
|
|
return ConvertUnixToAuroraMS(spec.tv_sec * 1000ULL + spec.tv_nsec / 1000000ULL);
|
|
|
|
}
|
|
|
|
|
2022-05-04 15:34:02 +00:00
|
|
|
static void ms2ts(struct timespec *ts, AuUInt64 ms)
|
2021-06-27 21:25:29 +00:00
|
|
|
{
|
|
|
|
ts->tv_sec = ms / 1000;
|
|
|
|
ts->tv_nsec = (ms % 1000) * 1000000;
|
|
|
|
}
|
|
|
|
|
2022-05-04 15:34:02 +00:00
|
|
|
static void ns2ts(struct timespec *ts, AuUInt64 ns)
|
|
|
|
{
|
|
|
|
ts->tv_sec = ns / 1'000'000'000ull;
|
|
|
|
ts->tv_nsec = ns % 1'000'000'000ull;
|
|
|
|
}
|
|
|
|
|
2021-10-03 12:43:37 +00:00
|
|
|
static void ms2tsabs(struct timespec *ts, unsigned long ms)
|
|
|
|
{
|
2022-11-28 16:01:08 +00:00
|
|
|
::clock_gettime(CLOCK_MONOTONIC, ts);
|
2022-04-07 04:35:17 +00:00
|
|
|
|
|
|
|
auto baseNS = ((AuUInt64)ms * (AuUInt64)1'000'000) + (AuUInt64)ts->tv_nsec;
|
|
|
|
auto remainderNS = (AuUInt64)baseNS % (AuUInt64)1'000'000'000;
|
|
|
|
|
|
|
|
ts->tv_sec += baseNS / 1'000'000'000ull;
|
|
|
|
ts->tv_nsec = remainderNS;
|
2021-10-03 12:43:37 +00:00
|
|
|
}
|
|
|
|
|
2022-11-28 16:01:08 +00:00
|
|
|
static void ms2tsabsRealtime(struct timespec *ts, unsigned long ms)
|
|
|
|
{
|
|
|
|
::clock_gettime(CLOCK_REALTIME, ts);
|
|
|
|
|
|
|
|
auto baseNS = ((AuUInt64)ms * (AuUInt64)1'000'000) + (AuUInt64)ts->tv_nsec;
|
|
|
|
auto remainderNS = (AuUInt64)baseNS % (AuUInt64)1'000'000'000;
|
|
|
|
|
|
|
|
ts->tv_sec += baseNS / 1'000'000'000ull;
|
|
|
|
ts->tv_nsec = remainderNS;
|
|
|
|
}
|
|
|
|
|
2023-08-11 15:51:42 +00:00
|
|
|
static void monoabsns2ts(struct timespec *ts, unsigned long long ns)
|
|
|
|
{
|
|
|
|
auto remainderNS = (AuUInt64)ns % (AuUInt64)1'000'000'000;
|
|
|
|
ts->tv_sec = ns / 1'000'000'000ull;
|
|
|
|
ts->tv_nsec = remainderNS;
|
|
|
|
}
|
|
|
|
|
2022-04-19 21:50:34 +00:00
|
|
|
static void auabsns2ts(struct timespec *ts, unsigned long long ns)
|
|
|
|
{
|
2022-04-20 13:17:37 +00:00
|
|
|
auto baseNS = ns + AuMSToNS<AuUInt64>(999'080'100'000);
|
2022-04-19 21:50:34 +00:00
|
|
|
auto remainderNS = (AuUInt64)baseNS % (AuUInt64)1'000'000'000;
|
|
|
|
|
2023-08-11 15:51:42 +00:00
|
|
|
ts->tv_sec = baseNS / 1'000'000'000ull;
|
2022-04-19 21:50:34 +00:00
|
|
|
ts->tv_nsec = remainderNS;
|
|
|
|
}
|
|
|
|
|
|
|
|
static void auabsms2ts(struct timespec *ts, unsigned long ms)
|
|
|
|
{
|
2022-04-20 13:17:37 +00:00
|
|
|
auabsns2ts(ts, AuMSToNS<AuUInt64>(ms));
|
2022-04-19 21:50:34 +00:00
|
|
|
}
|
2022-04-20 13:17:37 +00:00
|
|
|
|
2022-04-12 21:26:15 +00:00
|
|
|
static void ms2tvabs(struct timeval *tv, unsigned long ms)
|
|
|
|
{
|
|
|
|
timespec ts;
|
2022-11-28 16:01:08 +00:00
|
|
|
::clock_gettime(CLOCK_REALTIME, &ts);
|
2022-04-12 21:26:15 +00:00
|
|
|
|
|
|
|
auto baseNS = ((AuUInt64)ms * (AuUInt64)1'000'000) + (AuUInt64)ts.tv_nsec;
|
|
|
|
auto remainderNS = (AuUInt64)baseNS % (AuUInt64)1'000'000'000;
|
|
|
|
|
2022-04-12 21:33:43 +00:00
|
|
|
tv->tv_sec = ts.tv_sec;
|
2022-04-12 21:26:15 +00:00
|
|
|
tv->tv_sec += baseNS / 1'000'000'000ull;
|
|
|
|
tv->tv_usec = remainderNS / 1'000ull;
|
|
|
|
}
|
|
|
|
|
|
|
|
static void ms2tv(struct timeval *tv, unsigned long ms)
|
|
|
|
{
|
|
|
|
tv->tv_sec = ms / 1'000ull;
|
|
|
|
tv->tv_usec = (ms % 1'000ull) * 1'000ull;
|
|
|
|
}
|
|
|
|
|
2022-04-09 15:53:14 +00:00
|
|
|
static void ms2tsabsmono(struct timespec *ts, unsigned long ms)
|
|
|
|
{
|
|
|
|
clock_gettime(CLOCK_MONOTONIC, ts);
|
|
|
|
|
|
|
|
auto baseNS = ((AuUInt64)ms * (AuUInt64)1'000'000) + (AuUInt64)ts->tv_nsec;
|
|
|
|
auto remainderNS = (AuUInt64)baseNS % (AuUInt64)1'000'000'000;
|
|
|
|
|
|
|
|
ts->tv_sec += baseNS / 1'000'000'000ull;
|
|
|
|
ts->tv_nsec = remainderNS;
|
|
|
|
}
|
|
|
|
|
2021-06-27 21:25:29 +00:00
|
|
|
#endif
|
|
|
|
}
|