| /** @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 - 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. | |
| **/ | |
| #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 { | |
| /// | |
| /// The size of the EFI_FILE_INFO structure, including the Null-terminated 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 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 |