mirror of
https://github.com/CloverHackyColor/CloverBootloader.git
synced 2025-01-03 18:07:41 +01:00
179 lines
4.9 KiB
C
179 lines
4.9 KiB
C
|
/** @file
|
||
|
Copyright (C) 2019, vit9696. All rights reserved.
|
||
|
|
||
|
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 BOOT_MANAGEMENET_INTERNAL_H
|
||
|
#define BOOT_MANAGEMENET_INTERNAL_H
|
||
|
|
||
|
#include <Uefi.h>
|
||
|
|
||
|
#include <Library/OcAppleDiskImageLib.h>
|
||
|
#include <Library/OcBootManagementLib.h>
|
||
|
|
||
|
#include <Protocol/AppleBootPolicy.h>
|
||
|
#include <Protocol/DevicePath.h>
|
||
|
#include <Protocol/SimpleFileSystem.h>
|
||
|
|
||
|
#define OC_CUSTOM_FS_HANDLE ((EFI_HANDLE)(UINTN) 0x2007C5F5U)
|
||
|
|
||
|
typedef struct {
|
||
|
EFI_DEVICE_PATH_PROTOCOL *DevicePath;
|
||
|
OC_APPLE_DISK_IMAGE_CONTEXT *DmgContext;
|
||
|
EFI_HANDLE BlockIoHandle;
|
||
|
} INTERNAL_DMG_LOAD_CONTEXT;
|
||
|
|
||
|
typedef struct {
|
||
|
EFI_HANDLE Device;
|
||
|
UINTN NumBootInstances;
|
||
|
UINTN HdPrefixSize;
|
||
|
EFI_DEVICE_PATH_PROTOCOL *HdDevicePath;
|
||
|
EFI_DEVICE_PATH_PROTOCOL *BootDevicePath;
|
||
|
BOOLEAN IsExternal;
|
||
|
BOOLEAN SkipRecovery;
|
||
|
} INTERNAL_DEV_PATH_SCAN_INFO;
|
||
|
|
||
|
EFI_STATUS
|
||
|
InternalCheckScanPolicy (
|
||
|
IN EFI_HANDLE Handle,
|
||
|
IN UINT32 Policy,
|
||
|
OUT BOOLEAN *External OPTIONAL
|
||
|
);
|
||
|
|
||
|
EFI_DEVICE_PATH_PROTOCOL *
|
||
|
InternalLoadDmg (
|
||
|
IN OUT INTERNAL_DMG_LOAD_CONTEXT *Context,
|
||
|
IN UINT32 Policy
|
||
|
);
|
||
|
|
||
|
VOID
|
||
|
InternalUnloadDmg (
|
||
|
IN INTERNAL_DMG_LOAD_CONTEXT *DmgLoadContext
|
||
|
);
|
||
|
|
||
|
CHAR16 *
|
||
|
InternalGetAppleDiskLabel (
|
||
|
IN EFI_SIMPLE_FILE_SYSTEM_PROTOCOL *FileSystem,
|
||
|
IN CONST CHAR16 *BootDirectoryName,
|
||
|
IN CONST CHAR16 *LabelFilename
|
||
|
);
|
||
|
|
||
|
EFI_STATUS
|
||
|
InternalGetAppleImage (
|
||
|
IN EFI_SIMPLE_FILE_SYSTEM_PROTOCOL *FileSystem,
|
||
|
IN CONST CHAR16 *DirectoryName,
|
||
|
IN CONST CHAR16 *LabelFilename,
|
||
|
OUT VOID **ImageData,
|
||
|
OUT UINT32 *DataSize
|
||
|
);
|
||
|
|
||
|
CHAR16 *
|
||
|
InternalGetAppleRecoveryName (
|
||
|
IN EFI_SIMPLE_FILE_SYSTEM_PROTOCOL *FileSystem,
|
||
|
IN CONST CHAR16 *BootDirectoryName
|
||
|
);
|
||
|
|
||
|
EFI_STATUS
|
||
|
InternalGetRecoveryOsBooter (
|
||
|
IN EFI_HANDLE Device,
|
||
|
OUT EFI_DEVICE_PATH_PROTOCOL **FilePath,
|
||
|
IN BOOLEAN Basic
|
||
|
);
|
||
|
|
||
|
EFI_STATUS
|
||
|
InternalLoadBootEntry (
|
||
|
IN OC_PICKER_CONTEXT *Context,
|
||
|
IN OC_BOOT_ENTRY *BootEntry,
|
||
|
IN EFI_HANDLE ParentHandle,
|
||
|
OUT EFI_HANDLE *EntryHandle,
|
||
|
OUT INTERNAL_DMG_LOAD_CONTEXT *DmgLoadContext
|
||
|
);
|
||
|
|
||
|
UINT16 *
|
||
|
InternalGetBootOrderForBooting (
|
||
|
IN EFI_GUID *BootVariableGuid,
|
||
|
OUT UINTN *BootOrderCount
|
||
|
);
|
||
|
|
||
|
VOID
|
||
|
InternalDebugBootEnvironment (
|
||
|
IN CONST UINT16 *BootOrder,
|
||
|
IN EFI_GUID *BootGuid,
|
||
|
IN UINTN BootOrderCount
|
||
|
);
|
||
|
|
||
|
/**
|
||
|
Retrieves booting relevant data from an UEFI Boot#### option.
|
||
|
If BootName is NULL, a BDS-style process is assumed and inactive as well as
|
||
|
non-Boot type applications are ignored.
|
||
|
|
||
|
@param[in] BootOption The boot option's index.
|
||
|
@param[out] BootName On output, the boot option's description.
|
||
|
@param[out] OptionalDataSize On output, the optional data size.
|
||
|
@param[out] OptionalData On output, a pointer to the optional data.
|
||
|
|
||
|
**/
|
||
|
EFI_DEVICE_PATH_PROTOCOL *
|
||
|
InternalGetBootOptionData (
|
||
|
IN UINT16 BootOption,
|
||
|
IN EFI_GUID *BootGuid,
|
||
|
OUT CHAR16 **BootName OPTIONAL,
|
||
|
OUT UINT32 *OptionalDataSize OPTIONAL,
|
||
|
OUT VOID **OptionalData OPTIONAL
|
||
|
);
|
||
|
|
||
|
/**
|
||
|
Describe boot entry contents by setting fields other than DevicePath.
|
||
|
|
||
|
@param[in] BootEntry Located boot entry.
|
||
|
|
||
|
@retval EFI_SUCCESS The entry point is described successfully.
|
||
|
**/
|
||
|
EFI_STATUS
|
||
|
InternalDescribeBootEntry (
|
||
|
IN OUT OC_BOOT_ENTRY *BootEntry
|
||
|
);
|
||
|
|
||
|
BOOLEAN
|
||
|
InternalIsAppleLegacyLoadApp (
|
||
|
IN CONST EFI_DEVICE_PATH_PROTOCOL *DevicePath
|
||
|
);
|
||
|
|
||
|
/**
|
||
|
Finds filesystem for discovered filesystem handle.
|
||
|
This solves the problem of checking scan policy multiple times
|
||
|
as well as the problem of finding the filesystem to add entries too.
|
||
|
|
||
|
@param[in] BootContext Context of filesystems.
|
||
|
@param[in] FileSystemHandle Partition handle.
|
||
|
@param[in] LazyScan Lazy filesystem scanning.
|
||
|
|
||
|
@retval discovered filesystem (legit).
|
||
|
@retcal NULL when booting is not allowed from this filesystem.
|
||
|
**/
|
||
|
OC_BOOT_FILESYSTEM *
|
||
|
InternalFileSystemForHandle (
|
||
|
IN OC_BOOT_CONTEXT *BootContext,
|
||
|
IN EFI_HANDLE FileSystemHandle,
|
||
|
IN BOOLEAN LazyScan
|
||
|
);
|
||
|
|
||
|
/**
|
||
|
Resets selected NVRAM variables and reboots the system.
|
||
|
**/
|
||
|
EFI_STATUS
|
||
|
InternalSystemActionResetNvram (
|
||
|
VOID
|
||
|
);
|
||
|
|
||
|
#endif // BOOT_MANAGEMENET_INTERNAL_H
|