iPXE
FileInfo.h
Go to the documentation of this file.
1/** @file
2 Provides a GUID and a data structure that can be used with EFI_FILE_PROTOCOL.SetInfo()
3 and EFI_FILE_PROTOCOL.GetInfo() to set or get generic file information.
4 This GUID is defined in UEFI specification.
5
6Copyright (c) 2006 - 2018, Intel Corporation. All rights reserved.<BR>
7SPDX-License-Identifier: BSD-2-Clause-Patent
8
9**/
10
11#pragma once
12
13FILE_LICENCE ( BSD2_PATENT );
14FILE_SECBOOT ( PERMITTED );
15
16#define EFI_FILE_INFO_ID \
17 { \
18 0x9576e92, 0x6d3f, 0x11d2, {0x8e, 0x39, 0x0, 0xa0, 0xc9, 0x69, 0x72, 0x3b } \
19 }
20
21typedef struct {
22 ///
23 /// The size of the EFI_FILE_INFO structure, including the Null-terminated FileName string.
24 ///
26 ///
27 /// The size of the file in bytes.
28 ///
30 ///
31 /// PhysicalSize The amount of physical space the file consumes on the file system volume.
32 ///
34 ///
35 /// The time the file was created.
36 ///
38 ///
39 /// The time when the file was last accessed.
40 ///
42 ///
43 /// The time when the file's contents were last modified.
44 ///
46 ///
47 /// The attribute bits for the file.
48 ///
50 ///
51 /// The Null-terminated name of the file.
52 /// For a root directory, the name is an empty string.
53 ///
56
57///
58/// The FileName field of the EFI_FILE_INFO data structure is variable length.
59/// Whenever code needs to know the size of the EFI_FILE_INFO data structure, it needs to
60/// be the size of the data structure without the FileName field. The following macro
61/// computes this size correctly no matter how big the FileName array is declared.
62/// This is required to make the EFI_FILE_INFO data structure ANSI compilant.
63///
64#define SIZE_OF_EFI_FILE_INFO OFFSET_OF (EFI_FILE_INFO, FileName)
65
unsigned long long UINT64
8-byte unsigned value.
unsigned short CHAR16
2-byte Character.
EFI_GUID gEfiFileInfoGuid
GUID EFI_GUID
128-bit buffer containing a unique identifier value.
#define FILE_LICENCE(_licence)
Declare a particular licence as applying to a file.
Definition compiler.h:921
#define FILE_SECBOOT(_status)
Declare a file's UEFI Secure Boot permission status.
Definition compiler.h:951
EFI_TIME ModificationTime
The time when the file's contents were last modified.
Definition FileInfo.h:45
UINT64 PhysicalSize
PhysicalSize The amount of physical space the file consumes on the file system volume.
Definition FileInfo.h:33
EFI_TIME CreateTime
The time the file was created.
Definition FileInfo.h:37
UINT64 Size
The size of the EFI_FILE_INFO structure, including the Null-terminated FileName string.
Definition FileInfo.h:25
UINT64 Attribute
The attribute bits for the file.
Definition FileInfo.h:49
CHAR16 FileName[1]
The Null-terminated name of the file.
Definition FileInfo.h:54
EFI_TIME LastAccessTime
The time when the file was last accessed.
Definition FileInfo.h:41
UINT64 FileSize
The size of the file in bytes.
Definition FileInfo.h:29
EFI Time Abstraction: Year: 1900 - 9999 Month: 1 - 12 Day: 1 - 31 Hour: 0 - 23 Minute: 0 - 59 Second:...