2017-05-03 17:54:56 +02:00
|
|
|
/** @file
|
|
|
|
*
|
|
|
|
* Copyright (c) 2016, Hisilicon Limited. All rights reserved.
|
2019-06-13 17:48:28 +02:00
|
|
|
* Copyright (c) 2016-2019, Linaro Limited. All rights reserved.
|
2021-01-06 17:09:00 +01:00
|
|
|
* Copyright (c) 2021, Ampere Computing LLC. All rights reserved.
|
2017-05-03 17:54:56 +02:00
|
|
|
*
|
2019-04-04 01:03:38 +02:00
|
|
|
* SPDX-License-Identifier: BSD-2-Clause-Patent
|
2017-05-03 17:54:56 +02:00
|
|
|
*
|
|
|
|
**/
|
|
|
|
|
|
|
|
#ifndef _TIME_BASE_LIB_H_
|
|
|
|
#define _TIME_BASE_LIB_H_
|
|
|
|
|
|
|
|
#include <Uefi/UefiBaseType.h>
|
|
|
|
|
2020-07-24 18:37:42 +02:00
|
|
|
//
|
|
|
|
// Convenience macros to obtain a build date
|
|
|
|
//
|
|
|
|
// These macros should work for any compiler that follows ISO/IEC 9899,
|
|
|
|
// in which case __DATE__ is defined as a "Mmm dd yyyy" 11 chars string,
|
|
|
|
// but add an explicit filter for compilers that have been validated.
|
|
|
|
//
|
2021-12-05 23:53:56 +01:00
|
|
|
#if (defined (__GNUC__) || defined (_MSC_VER) || defined (__clang__))
|
|
|
|
#define TIME_BUILD_YEAR (__DATE__[7] == '?' ? 1900\
|
2020-07-24 18:37:42 +02:00
|
|
|
: (((__DATE__[7] - '0') * 1000 ) \
|
|
|
|
+ (__DATE__[8] - '0') * 100 \
|
|
|
|
+ (__DATE__[9] - '0') * 10 \
|
|
|
|
+ __DATE__[10] - '0'))
|
2021-12-05 23:53:56 +01:00
|
|
|
#define TIME_BUILD_MONTH ( __DATE__ [2] == '?' ? 1 \
|
2020-07-24 18:37:42 +02:00
|
|
|
: __DATE__ [2] == 'n' ? ( \
|
|
|
|
__DATE__ [1] == 'a' ? 1 : 6) \
|
|
|
|
: __DATE__ [2] == 'b' ? 2 \
|
|
|
|
: __DATE__ [2] == 'r' ? ( \
|
|
|
|
__DATE__ [0] == 'M' ? 3 : 4) \
|
|
|
|
: __DATE__ [2] == 'y' ? 5 \
|
|
|
|
: __DATE__ [2] == 'l' ? 7 \
|
|
|
|
: __DATE__ [2] == 'g' ? 8 \
|
|
|
|
: __DATE__ [2] == 'p' ? 9 \
|
|
|
|
: __DATE__ [2] == 't' ? 10 \
|
|
|
|
: __DATE__ [2] == 'v' ? 11 \
|
|
|
|
: 12)
|
2021-12-05 23:53:56 +01:00
|
|
|
#define TIME_BUILD_DAY ( __DATE__[4] == '?' ? 1 \
|
2020-07-24 18:37:42 +02:00
|
|
|
: ((__DATE__[4] == ' ' ? 0 : \
|
|
|
|
((__DATE__[4] - '0') * 10)) \
|
|
|
|
+ __DATE__[5] - '0'))
|
|
|
|
#endif
|
|
|
|
|
2017-05-03 17:54:56 +02:00
|
|
|
// Define EPOCH (1970-JANUARY-01) in the Julian Date representation
|
2021-12-05 23:53:56 +01:00
|
|
|
#define EPOCH_JULIAN_DATE 2440588
|
2017-05-03 17:54:56 +02:00
|
|
|
|
|
|
|
// Seconds per unit
|
2021-12-05 23:53:56 +01:00
|
|
|
#define SEC_PER_MIN ((UINTN) 60)
|
|
|
|
#define SEC_PER_HOUR ((UINTN) 3600)
|
|
|
|
#define SEC_PER_DAY ((UINTN) 86400)
|
2017-05-03 17:54:56 +02:00
|
|
|
|
2021-01-06 17:09:00 +01:00
|
|
|
/**
|
|
|
|
Check if it is a leap year.
|
|
|
|
|
|
|
|
@param Time The UEFI time to be checked.
|
|
|
|
|
|
|
|
@retval TRUE It is a leap year.
|
|
|
|
@retval FALSE It is NOT a leap year.
|
|
|
|
|
|
|
|
**/
|
2017-05-03 17:54:56 +02:00
|
|
|
BOOLEAN
|
|
|
|
EFIAPI
|
|
|
|
IsLeapYear (
|
|
|
|
IN EFI_TIME *Time
|
|
|
|
);
|
|
|
|
|
2021-01-06 17:09:00 +01:00
|
|
|
/**
|
|
|
|
Check if the day in the UEFI time is valid.
|
|
|
|
|
|
|
|
@param Time The UEFI time to be checked.
|
|
|
|
|
|
|
|
@retval TRUE Valid.
|
|
|
|
@retval FALSE Invalid.
|
|
|
|
|
|
|
|
**/
|
2017-05-03 17:54:56 +02:00
|
|
|
BOOLEAN
|
|
|
|
EFIAPI
|
|
|
|
IsDayValid (
|
|
|
|
IN EFI_TIME *Time
|
|
|
|
);
|
|
|
|
|
2021-01-06 17:09:02 +01:00
|
|
|
/**
|
|
|
|
Check if the time zone is valid.
|
|
|
|
Valid values are between -1440 and 1440 or 2047 (EFI_UNSPECIFIED_TIMEZONE).
|
|
|
|
|
|
|
|
@param TimeZone The time zone to be checked.
|
|
|
|
|
|
|
|
@retval TRUE Valid.
|
|
|
|
@retval FALSE Invalid.
|
|
|
|
|
|
|
|
**/
|
|
|
|
BOOLEAN
|
|
|
|
EFIAPI
|
|
|
|
IsValidTimeZone (
|
|
|
|
IN INT16 TimeZone
|
|
|
|
);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Check if the daylight is valid.
|
|
|
|
Valid values are:
|
|
|
|
0 : Time is not affected.
|
|
|
|
1 : Time is affected, and has not been adjusted for daylight savings.
|
|
|
|
3 : Time is affected, and has been adjusted for daylight savings.
|
|
|
|
All other values are invalid.
|
|
|
|
|
|
|
|
@param Daylight The daylight to be checked.
|
|
|
|
|
|
|
|
@retval TRUE Valid.
|
|
|
|
@retval FALSE Invalid.
|
|
|
|
|
|
|
|
**/
|
|
|
|
BOOLEAN
|
|
|
|
EFIAPI
|
|
|
|
IsValidDaylight (
|
|
|
|
IN INT8 Daylight
|
|
|
|
);
|
|
|
|
|
2021-01-06 17:09:00 +01:00
|
|
|
/**
|
|
|
|
Check if the UEFI time is valid.
|
|
|
|
|
|
|
|
@param Time The UEFI time to be checked.
|
|
|
|
|
|
|
|
@retval TRUE Valid.
|
|
|
|
@retval FALSE Invalid.
|
|
|
|
|
|
|
|
**/
|
2017-05-03 17:54:56 +02:00
|
|
|
BOOLEAN
|
|
|
|
EFIAPI
|
|
|
|
IsTimeValid (
|
|
|
|
IN EFI_TIME *Time
|
|
|
|
);
|
|
|
|
|
|
|
|
/**
|
2021-01-06 17:09:00 +01:00
|
|
|
Converts Epoch seconds (elapsed since 1970 JANUARY 01, 00:00:00 UTC) to EFI_TIME.
|
|
|
|
|
|
|
|
@param EpochSeconds Epoch seconds.
|
|
|
|
@param Time The time converted to UEFI format.
|
|
|
|
|
|
|
|
**/
|
2017-05-03 17:54:56 +02:00
|
|
|
VOID
|
|
|
|
EFIAPI
|
|
|
|
EpochToEfiTime (
|
|
|
|
IN UINTN EpochSeconds,
|
|
|
|
OUT EFI_TIME *Time
|
|
|
|
);
|
|
|
|
|
|
|
|
/**
|
2021-01-06 17:09:00 +01:00
|
|
|
Converts EFI_TIME to Epoch seconds (elapsed since 1970 JANUARY 01, 00:00:00 UTC).
|
|
|
|
|
|
|
|
@param Time The UEFI time to be converted.
|
|
|
|
|
|
|
|
@return Number of seconds.
|
|
|
|
|
|
|
|
**/
|
2020-12-21 12:36:57 +01:00
|
|
|
UINTN
|
2017-05-03 17:54:56 +02:00
|
|
|
EFIAPI
|
|
|
|
EfiTimeToEpoch (
|
|
|
|
IN EFI_TIME *Time
|
|
|
|
);
|
|
|
|
|
2018-06-04 18:31:44 +02:00
|
|
|
/**
|
2021-01-06 17:09:00 +01:00
|
|
|
Get the day of the week from the UEFI time.
|
|
|
|
|
|
|
|
@param Time The UEFI time to be calculated.
|
|
|
|
|
|
|
|
@return The day of the week: Sunday=0, Monday=1, ... Saturday=6
|
|
|
|
|
|
|
|
**/
|
2018-06-04 18:31:44 +02:00
|
|
|
UINTN
|
|
|
|
EfiTimeToWday (
|
|
|
|
IN EFI_TIME *Time
|
|
|
|
);
|
|
|
|
|
2017-05-03 17:54:56 +02:00
|
|
|
#endif
|