mirror of
https://github.com/reactos/reactos.git
synced 2024-11-19 13:33:42 +00:00
194 lines
5.6 KiB
C
194 lines
5.6 KiB
C
/*
|
|
* PROJECT: ReactOS Setup Library
|
|
* LICENSE: GPL-2.0+ (https://spdx.org/licenses/GPL-2.0+)
|
|
* PURPOSE: Boot Stores Management functionality, with support for
|
|
* NT 5.x family (MS Windows <= 2003, and ReactOS) bootloaders.
|
|
* COPYRIGHT: Copyright 2017-2018 Hermes Belusca-Maito
|
|
*/
|
|
|
|
// TODO: Add support for NT 6.x family! (detection + BCD manipulation).
|
|
|
|
#pragma once
|
|
|
|
typedef enum _BOOT_STORE_TYPE
|
|
{
|
|
FreeLdr, // ReactOS' FreeLoader
|
|
NtLdr, // Windows <= 2k3 NT "FlexBoot" OS Loader NTLDR
|
|
// BootMgr, // Vista+ BCD-oriented BOOTMGR
|
|
BldrTypeMax
|
|
} BOOT_STORE_TYPE;
|
|
|
|
/*
|
|
* Some references about EFI boot entries:
|
|
* https://docs.microsoft.com/en-us/windows-hardware/drivers/devtest/overview-of-boot-options-in-efi
|
|
* https://docs.microsoft.com/en-us/windows-hardware/drivers/devtest/identifying-backup-files-for-existing-boot-entries
|
|
*/
|
|
|
|
/*
|
|
* This structure is inspired from the EFI boot entry structure
|
|
* BOOT_OPTIONS that is defined in ndk/iotypes.h .
|
|
*/
|
|
typedef struct _BOOT_STORE_OPTIONS
|
|
{
|
|
ULONG Version; // BOOT_STORE_TYPE value
|
|
// ULONG Length;
|
|
ULONG Timeout;
|
|
ULONG_PTR CurrentBootEntryKey;
|
|
// ULONG_PTR NextBootEntryKey;
|
|
// WCHAR HeadlessRedirection[1];
|
|
} BOOT_STORE_OPTIONS, *PBOOT_STORE_OPTIONS;
|
|
|
|
/*
|
|
* These macros are used to set a value for the BootEntryKey member of a
|
|
* BOOT_STORE_ENTRY structure, much in the same idea as MAKEINTRESOURCE and
|
|
* IS_INTRESOURCE macros for Win32 resources.
|
|
*
|
|
* A key consists of either a boot ID number, comprised between 0 and
|
|
* MAXUSHORT == 0xFFFF == 65535, or can be a pointer to a human-readable
|
|
* string (section name), as in the case of FreeLDR, or to a GUID, as in the
|
|
* case of BOOTMGR.
|
|
*
|
|
* If IS_INTKEY(BootEntryKey) == TRUE, i.e. the key is <= 65535, this means
|
|
* the key is a boot ID number, otherwise it is typically a pointer to a string.
|
|
*/
|
|
#define MAKESTRKEY(i) ((ULONG_PTR)(i))
|
|
#define MAKEINTKEY(i) ((ULONG_PTR)((USHORT)(i)))
|
|
#define IS_INTKEY(i) (((ULONG_PTR)(i) >> 16) == 0)
|
|
|
|
/*
|
|
* This structure is inspired from the EFI boot entry structures
|
|
* BOOT_ENTRY and FILE_PATH that are defined in ndk/iotypes.h .
|
|
*/
|
|
typedef struct _BOOT_STORE_ENTRY
|
|
{
|
|
ULONG Version; // BOOT_STORE_TYPE value
|
|
// ULONG Length;
|
|
ULONG_PTR BootEntryKey; // Boot entry "key"
|
|
PCWSTR FriendlyName; // Human-readable boot entry description // LoadIdentifier
|
|
PCWSTR BootFilePath; // Path to e.g. osloader.exe, or winload.efi // EfiOsLoaderFilePath
|
|
ULONG OsOptionsLength; // Loader-specific options blob (can be a string, or a binary structure...)
|
|
UCHAR OsOptions[ANYSIZE_ARRAY];
|
|
/*
|
|
* In packed form, this structure would contain offsets to 'FriendlyName'
|
|
* and 'BootFilePath' strings and, after the OsOptions blob, there would
|
|
* be the following data:
|
|
*
|
|
* WCHAR FriendlyName[ANYSIZE_ARRAY];
|
|
* FILE_PATH BootFilePath;
|
|
*/
|
|
} BOOT_STORE_ENTRY, *PBOOT_STORE_ENTRY;
|
|
|
|
/* "NTOS" (aka. ReactOS or MS Windows NT) <= 5.x options */
|
|
typedef struct _NTOS_OPTIONS
|
|
{
|
|
UCHAR Signature[8]; // "NTOS_5\0\0"
|
|
// ULONG Version;
|
|
// ULONG Length;
|
|
PCWSTR OsLoadPath; // The OS SystemRoot path // OsLoaderFilePath // OsFilePath
|
|
PCWSTR OsLoadOptions; // OsLoadOptions
|
|
/*
|
|
* In packed form, this structure would contain an offset to the 'OsLoadPath'
|
|
* string, and the 'OsLoadOptions' member would be:
|
|
* WCHAR OsLoadOptions[ANYSIZE_ARRAY];
|
|
* followed by:
|
|
* FILE_PATH OsLoadPath;
|
|
*/
|
|
} NTOS_OPTIONS, *PNTOS_OPTIONS;
|
|
|
|
#define NTOS_OPTIONS_SIGNATURE "NTOS_5\0\0"
|
|
|
|
/* Options for boot-sector boot entries */
|
|
typedef struct _BOOT_SECTOR_OPTIONS
|
|
{
|
|
UCHAR Signature[8]; // "BootSect"
|
|
// ULONG Version;
|
|
// ULONG Length;
|
|
PCWSTR Drive;
|
|
PCWSTR Partition;
|
|
PCWSTR BootSectorFileName;
|
|
} BOOT_SECTOR_OPTIONS, *PBOOT_SECTOR_OPTIONS;
|
|
|
|
#define BOOT_SECTOR_OPTIONS_SIGNATURE "BootSect"
|
|
|
|
|
|
typedef NTSTATUS
|
|
(NTAPI *PENUM_BOOT_ENTRIES_ROUTINE)(
|
|
IN BOOT_STORE_TYPE Type,
|
|
IN PBOOT_STORE_ENTRY BootEntry,
|
|
IN PVOID Parameter OPTIONAL);
|
|
|
|
|
|
NTSTATUS
|
|
FindBootStore( // By handle
|
|
IN HANDLE PartitionDirectoryHandle, // OPTIONAL
|
|
IN BOOT_STORE_TYPE Type,
|
|
OUT PULONG VersionNumber OPTIONAL);
|
|
|
|
|
|
NTSTATUS
|
|
OpenBootStoreByHandle(
|
|
OUT PVOID* Handle,
|
|
IN HANDLE PartitionDirectoryHandle, // OPTIONAL
|
|
IN BOOT_STORE_TYPE Type,
|
|
IN BOOLEAN CreateNew);
|
|
|
|
NTSTATUS
|
|
OpenBootStore_UStr(
|
|
OUT PVOID* Handle,
|
|
IN PUNICODE_STRING SystemPartitionPath,
|
|
IN BOOT_STORE_TYPE Type,
|
|
IN BOOLEAN CreateNew);
|
|
|
|
NTSTATUS
|
|
OpenBootStore(
|
|
OUT PVOID* Handle,
|
|
IN PCWSTR SystemPartition,
|
|
IN BOOT_STORE_TYPE Type,
|
|
IN BOOLEAN CreateNew);
|
|
|
|
NTSTATUS
|
|
CloseBootStore(
|
|
IN PVOID Handle);
|
|
|
|
NTSTATUS
|
|
AddBootStoreEntry(
|
|
IN PVOID Handle,
|
|
IN PBOOT_STORE_ENTRY BootEntry,
|
|
IN ULONG_PTR BootEntryKey);
|
|
|
|
NTSTATUS
|
|
DeleteBootStoreEntry(
|
|
IN PVOID Handle,
|
|
IN ULONG_PTR BootEntryKey);
|
|
|
|
NTSTATUS
|
|
ModifyBootStoreEntry(
|
|
IN PVOID Handle,
|
|
IN PBOOT_STORE_ENTRY BootEntry);
|
|
|
|
NTSTATUS
|
|
QueryBootStoreEntry(
|
|
IN PVOID Handle,
|
|
IN ULONG_PTR BootEntryKey,
|
|
OUT PBOOT_STORE_ENTRY BootEntry); // Technically this should be PBOOT_STORE_ENTRY*
|
|
|
|
NTSTATUS
|
|
QueryBootStoreOptions(
|
|
IN PVOID Handle,
|
|
IN OUT PBOOT_STORE_OPTIONS BootOptions
|
|
/* , IN PULONG BootOptionsLength */ );
|
|
|
|
NTSTATUS
|
|
SetBootStoreOptions(
|
|
IN PVOID Handle,
|
|
IN PBOOT_STORE_OPTIONS BootOptions,
|
|
IN ULONG FieldsToChange);
|
|
|
|
NTSTATUS
|
|
EnumerateBootStoreEntries(
|
|
IN PVOID Handle,
|
|
// IN ULONG Flags, // Determine which data to retrieve
|
|
IN PENUM_BOOT_ENTRIES_ROUTINE EnumBootEntriesRoutine,
|
|
IN PVOID Parameter OPTIONAL);
|
|
|
|
/* EOF */
|