mirror of https://github.com/acidanthera/audk.git
72 lines
2.4 KiB
C
72 lines
2.4 KiB
C
/** @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
|