/** @file | |
Provides a GUID and a data structure that can be used with EFI_FILE_PROTOCOL.SetInfo() | |
and EFI_FILE_PROTOCOL.GetInfo() to set or get generic file information. | |
This GUID is defined in UEFI specification. | |
Copyright (c) 2006 - 2008, Intel Corporation | |
All rights reserved. This program and the accompanying materials | |
are licensed and made available under the terms and conditions of the BSD License | |
which 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. | |
**/ | |
#ifndef __FILE_INFO_H__ | |
#define __FILE_INFO_H__ | |
#define EFI_FILE_INFO_ID \ | |
{ \ | |
0x9576e92, 0x6d3f, 0x11d2, {0x8e, 0x39, 0x0, 0xa0, 0xc9, 0x69, 0x72, 0x3b } \ | |
} | |
typedef struct { | |
/// | |
/// Size of the EFI_FILE_INFO structure, including the Nullterminated Unicode FileName string. | |
/// | |
UINT64 Size; | |
/// | |
/// The size of the file in bytes. | |
/// | |
UINT64 FileSize; | |
/// | |
/// PhysicalSize The amount of physical space the file consumes on the file system volume. | |
/// | |
UINT64 PhysicalSize; | |
/// | |
/// The time the file was created. | |
/// | |
EFI_TIME CreateTime; | |
/// | |
/// The time when the file was last accessed. | |
/// | |
EFI_TIME LastAccessTime; | |
/// | |
/// The time when the file's contents were last modified. | |
/// | |
EFI_TIME ModificationTime; | |
/// | |
/// The attribute bits for the file. | |
/// | |
UINT64 Attribute; | |
/// | |
/// The Null-terminated Unicode name of the file. | |
/// | |
CHAR16 FileName[1]; | |
} EFI_FILE_INFO; | |
/// | |
/// The FileName field of the EFI_FILE_INFO data structure is variable length. | |
/// Whenever code needs to know the size of the EFI_FILE_INFO data structure, it needs to | |
/// be the size of the data structure without the FileName field. The following macro | |
/// computes this size correctly no matter how big the FileName array is declared. | |
/// This is required to make the EFI_FILE_INFO data structure ANSI compilant. | |
/// | |
#define SIZE_OF_EFI_FILE_INFO OFFSET_OF (EFI_FILE_INFO, FileName) | |
extern EFI_GUID gEfiFileInfoGuid; | |
#endif |