summaryrefslogtreecommitdiff
path: root/StdLib/LibC/Time/TimeEfi.c
blob: 50f2deec057a326aad92814ba49bdfb255bc5063 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
/** @file
  Transformations between the EFI_TIME structure and struct tm or time_t.

  Copyright (c) 2010, Intel Corporation. All rights reserved.<BR>
  This program and the accompanying materials are licensed and made available under
  the terms and conditions of the BSD License that accompanies this distribution.
  The full text of the license may be found at
  http://opensource.org/licenses/bsd-license.php.

  THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,
  WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.

**/
#include  <Uefi.h>

#include  <LibConfig.h>

#include  <time.h>
#include  "tzfile.h"
#include  <MainData.h>

/** Convert an EFI_TIME structure into a C Standard tm structure.

    @param[in]    ET    Pointer to the EFI_TIME structure to convert.
    @param[out]   BT    Pointer to the tm structure to receive the converted time.
*/
void
Efi2Tm(
  IN      EFI_TIME  *ET,
     OUT  struct tm *BT
  )
{
  // Convert EFI time to broken-down time.
  BT->tm_year = ET->Year - TM_YEAR_BASE;
  BT->tm_mon = ET->Month - 1;   // BD time is zero based, EFI is 1 based
  BT->tm_mday = ET->Day;
  BT->tm_hour = ET->Hour;
  BT->tm_min = ET->Minute;
  BT->tm_sec = ET->Second;
  BT->tm_isdst = -1;
  BT->tm_zoneoff = ET->TimeZone;
  BT->tm_daylight = ET->Daylight;
  BT->tm_Nano = ET->Nanosecond;
}

/** Convert an EFI_TIME structure into a time_t value.

    @param[in]  EfiBDtime   Pointer to the EFI_TIME structure to convert.

    @return   The EFI_TIME converted into a time_t value.
*/
time_t
Efi2Time(
  IN  EFI_TIME *EfiBDtime
  )
{
  Efi2Tm( EfiBDtime, &gMD->BDTime);

  return mktime( &gMD->BDTime);
}

/** Convert a C Standard tm structure into an EFI_TIME structure.

    @param[in]    BT    Pointer to the tm structure to convert.
    @param[out]   ET    Pointer to an EFI_TIME structure to receive the converted time.
*/
void
Tm2Efi(
  IN      struct tm *BT,
     OUT  EFI_TIME  *ET
  )
{
  ET->Year        = (UINT16)BT->tm_year + TM_YEAR_BASE;
  ET->Month       = (UINT8)BT->tm_mon + 1;
  ET->Day         = (UINT8)BT->tm_mday;
  ET->Hour        = (UINT8)BT->tm_hour;
  ET->Minute      = (UINT8)BT->tm_min;
  ET->Second      = (UINT8)BT->tm_sec;
  ET->Nanosecond  = (UINT32)BT->tm_Nano;
  ET->TimeZone    = (INT16)BT->tm_zoneoff;
  ET->Daylight    = (UINT8)BT->tm_daylight;
}

/** Convert a time_t value into an EFI_TIME structure.

    @param[in]    CalTime   Calendar time as a time_t value.

    @return   Returns a newly malloced EFI_TIME structure containing
              the converted calendar time.

    @post     It is the responsibility of the caller to free the
              returned structure before the application exits.
*/
EFI_TIME*
Time2Efi(
  IN  time_t CalTime
  )
{
  struct tm *IT;
  EFI_TIME  *ET   = NULL;

  IT = gmtime(&CalTime);
  if(IT != NULL) {
    ET = malloc(sizeof(EFI_TIME));
    if(ET != NULL) {
      Tm2Efi(IT, ET);
    }
  }
  return ET;
}