1 /* 2 * PROJECT: ReactOS Setup Library 3 * LICENSE: GPL-2.0+ (https://spdx.org/licenses/GPL-2.0+) 4 * PURPOSE: Boot Stores Management functionality, with support for 5 * NT 5.x family (MS Windows <= 2003, and ReactOS) bootloaders. 6 * COPYRIGHT: Copyright 2017-2018 Hermes Belusca-Maito 7 */ 8 9 // TODO: Add support for NT 6.x family! (detection + BCD manipulation). 10 11 #pragma once 12 13 typedef enum _BOOT_STORE_TYPE 14 { 15 FreeLdr, // ReactOS' FreeLoader 16 NtLdr, // Windows <= 2k3 NT "FlexBoot" OS Loader NTLDR 17 // BootMgr, // Vista+ BCD-oriented BOOTMGR 18 BldrTypeMax 19 } BOOT_STORE_TYPE; 20 21 /* 22 * Some references about EFI boot entries: 23 * https://docs.microsoft.com/en-us/windows-hardware/drivers/devtest/overview-of-boot-options-in-efi 24 * https://docs.microsoft.com/en-us/windows-hardware/drivers/devtest/identifying-backup-files-for-existing-boot-entries 25 */ 26 27 /* 28 * This structure is inspired from the EFI boot entry structure 29 * BOOT_OPTIONS that is defined in ndk/iotypes.h . 30 */ 31 typedef struct _BOOT_STORE_OPTIONS 32 { 33 ULONG Version; // BOOT_STORE_TYPE value 34 // ULONG Length; 35 ULONG Timeout; 36 ULONG_PTR CurrentBootEntryKey; 37 // ULONG_PTR NextBootEntryKey; 38 // WCHAR HeadlessRedirection[1]; 39 } BOOT_STORE_OPTIONS, *PBOOT_STORE_OPTIONS; 40 41 /* 42 * These macros are used to set a value for the BootEntryKey member of a 43 * BOOT_STORE_ENTRY structure, much in the same idea as MAKEINTRESOURCE and 44 * IS_INTRESOURCE macros for Win32 resources. 45 * 46 * A key consists of either a boot ID number, comprised between 0 and 47 * MAX_USHORT == 0xFFFF == 65535, or can be a pointer to a human-readable 48 * string (section name), as in the case of FreeLDR, or to a GUID, as in the 49 * case of BOOTMGR. 50 * 51 * If IS_INTKEY(BootEntryKey) == TRUE, i.e. the key is <= 65535, this means 52 * the key is a boot ID number, otherwise it is typically a pointer to a string. 53 */ 54 #define MAKESTRKEY(i) ((ULONG_PTR)(i)) 55 #define MAKEINTKEY(i) ((ULONG_PTR)((USHORT)(i))) 56 #define IS_INTKEY(i) (((ULONG_PTR)(i) >> 16) == 0) 57 58 /* 59 * This structure is inspired from the EFI boot entry structures 60 * BOOT_ENTRY and FILE_PATH that are defined in ndk/iotypes.h . 61 */ 62 typedef struct _BOOT_STORE_ENTRY 63 { 64 ULONG Version; // BOOT_STORE_TYPE value 65 // ULONG Length; 66 ULONG_PTR BootEntryKey; // Boot entry "key" 67 PCWSTR FriendlyName; // Human-readable boot entry description // LoadIdentifier 68 PCWSTR BootFilePath; // Path to e.g. osloader.exe, or winload.efi // EfiOsLoaderFilePath 69 ULONG OsOptionsLength; // Loader-specific options blob (can be a string, or a binary structure...) 70 UCHAR OsOptions[ANYSIZE_ARRAY]; 71 /* 72 * In packed form, this structure would contain offsets to 'FriendlyName' 73 * and 'BootFilePath' strings and, after the OsOptions blob, there would 74 * be the following data: 75 * 76 * WCHAR FriendlyName[ANYSIZE_ARRAY]; 77 * FILE_PATH BootFilePath; 78 */ 79 } BOOT_STORE_ENTRY, *PBOOT_STORE_ENTRY; 80 81 /* "NTOS" (aka. ReactOS or MS Windows NT) <= 5.x options */ 82 typedef struct _NTOS_OPTIONS 83 { 84 UCHAR Signature[8]; // "NTOS_5\0\0" 85 // ULONG Version; 86 // ULONG Length; 87 PCWSTR OsLoadPath; // The OS SystemRoot path // OsLoaderFilePath // OsFilePath 88 PCWSTR OsLoadOptions; // OsLoadOptions 89 /* 90 * In packed form, this structure would contain an offset to the 'OsLoadPath' 91 * string, and the 'OsLoadOptions' member would be: 92 * WCHAR OsLoadOptions[ANYSIZE_ARRAY]; 93 * followed by: 94 * FILE_PATH OsLoadPath; 95 */ 96 } NTOS_OPTIONS, *PNTOS_OPTIONS; 97 98 #define NTOS_OPTIONS_SIGNATURE "NTOS_5\0\0" 99 100 /* Options for boot-sector boot entries */ 101 typedef struct _BOOT_SECTOR_OPTIONS 102 { 103 UCHAR Signature[8]; // "BootSect" 104 // ULONG Version; 105 // ULONG Length; 106 PCWSTR Drive; 107 PCWSTR Partition; 108 PCWSTR BootSectorFileName; 109 } BOOT_SECTOR_OPTIONS, *PBOOT_SECTOR_OPTIONS; 110 111 #define BOOT_SECTOR_OPTIONS_SIGNATURE "BootSect" 112 113 114 typedef NTSTATUS 115 (NTAPI *PENUM_BOOT_ENTRIES_ROUTINE)( 116 IN BOOT_STORE_TYPE Type, 117 IN PBOOT_STORE_ENTRY BootEntry, 118 IN PVOID Parameter OPTIONAL); 119 120 121 NTSTATUS 122 FindBootStore( // By handle 123 IN HANDLE PartitionDirectoryHandle, // OPTIONAL 124 IN BOOT_STORE_TYPE Type, 125 OUT PULONG VersionNumber OPTIONAL); 126 127 128 NTSTATUS 129 OpenBootStoreByHandle( 130 OUT PVOID* Handle, 131 IN HANDLE PartitionDirectoryHandle, // OPTIONAL 132 IN BOOT_STORE_TYPE Type, 133 IN BOOLEAN CreateNew); 134 135 NTSTATUS 136 OpenBootStore_UStr( 137 OUT PVOID* Handle, 138 IN PUNICODE_STRING SystemPartitionPath, 139 IN BOOT_STORE_TYPE Type, 140 IN BOOLEAN CreateNew); 141 142 NTSTATUS 143 OpenBootStore( 144 OUT PVOID* Handle, 145 IN PCWSTR SystemPartition, 146 IN BOOT_STORE_TYPE Type, 147 IN BOOLEAN CreateNew); 148 149 NTSTATUS 150 CloseBootStore( 151 IN PVOID Handle); 152 153 NTSTATUS 154 AddBootStoreEntry( 155 IN PVOID Handle, 156 IN PBOOT_STORE_ENTRY BootEntry, 157 IN ULONG_PTR BootEntryKey); 158 159 NTSTATUS 160 DeleteBootStoreEntry( 161 IN PVOID Handle, 162 IN ULONG_PTR BootEntryKey); 163 164 NTSTATUS 165 ModifyBootStoreEntry( 166 IN PVOID Handle, 167 IN PBOOT_STORE_ENTRY BootEntry); 168 169 NTSTATUS 170 QueryBootStoreEntry( 171 IN PVOID Handle, 172 IN ULONG_PTR BootEntryKey, 173 OUT PBOOT_STORE_ENTRY BootEntry); // Technically this should be PBOOT_STORE_ENTRY* 174 175 NTSTATUS 176 QueryBootStoreOptions( 177 IN PVOID Handle, 178 IN OUT PBOOT_STORE_OPTIONS BootOptions 179 /* , IN PULONG BootOptionsLength */ ); 180 181 NTSTATUS 182 SetBootStoreOptions( 183 IN PVOID Handle, 184 IN PBOOT_STORE_OPTIONS BootOptions, 185 IN ULONG FieldsToChange); 186 187 NTSTATUS 188 EnumerateBootStoreEntries( 189 IN PVOID Handle, 190 // IN ULONG Flags, // Determine which data to retrieve 191 IN PENUM_BOOT_ENTRIES_ROUTINE EnumBootEntriesRoutine, 192 IN PVOID Parameter OPTIONAL); 193 194 /* EOF */ 195