Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[efi] Expose downloaded images via EFI_SIMPLE_FILE_SYSTEM_PROTOCOL
Expose iPXE's images as a UEFI file system, allowing the booted image to access all images downloaded by iPXE. This functionality is complementary to the custom iPXE download protocol. The iPXE download protocol allows a booted image to utilise iPXE to download arbitrary URIs, but requires the booted image to specifically support the custom iPXE download protocol. The new functionality limits the booted image to accessing only files that were already downloaded by iPXE (e.g. as part of a script), but can work with any generic UEFI image (e.g. the UEFI shell). Both protocols are provided simultaneously, and are attached to the SNP device handle. Signed-off-by: Michael Brown <mcb30@ipxe.org>
- Loading branch information
Showing
10 changed files
with
1,546 additions
and
115 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,73 @@ | ||
/** @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__ | ||
|
||
FILE_LICENCE ( BSD3 ); | ||
|
||
#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 |
Oops, something went wrong.