67 BootEntry->BootFilePath =
NULL;
78 BootEntry->FriendlyName =
L"\"ReactOS\"";
79 Options->OsLoadOptions =
L"/FASTDETECT";
84 BootEntry->FriendlyName =
L"\"ReactOS (Debug)\"";
85 Options->OsLoadOptions =
L"/DEBUG /DEBUGPORT=COM1 /BAUDRATE=115200 /SOS";
91 BootEntry->FriendlyName =
L"\"ReactOS (VBox Debug)\"";
92 Options->OsLoadOptions =
L"/DEBUG /DEBUGPORT=VBOX /SOS";
99 BootEntry->FriendlyName =
L"\"ReactOS (RosDbg)\"";
100 Options->OsLoadOptions =
L"/DEBUG /DEBUGPORT=COM1 /BAUDRATE=115200 /SOS /KDSERIAL";
106 BootEntry->FriendlyName =
L"\"ReactOS (Screen)\"";
107 Options->OsLoadOptions =
L"/DEBUG /DEBUGPORT=SCREEN /SOS";
112 BootEntry->FriendlyName =
L"\"ReactOS (Log file)\"";
113 Options->OsLoadOptions =
L"/DEBUG /DEBUGPORT=FILE /SOS";
118 BootEntry->FriendlyName =
L"\"ReactOS (RAM Disk)\"";
119 Options->OsLoadPath =
L"ramdisk(0)\\ReactOS";
120 Options->OsLoadOptions =
L"/DEBUG /DEBUGPORT=COM1 /BAUDRATE=115200 /SOS /RDPATH=reactos.img /RDIMAGEOFFSET=32256";
125 BootEntry->FriendlyName =
L"\"ReactOS (Emergency Management Services)\"";
127 Options->OsLoadOptions =
L"/DEBUG /DEBUGPORT=COM1 /BAUDRATE=115200 /SOS /redirect=com2 /redirectbaudrate=115200";
133#if DBG && !defined(_WINKD_)
173 PVOID BootStoreHandle;
199 PVOID BootStoreHandle;
214 DPRINT1(
"BootPath = '%S' points to disk #%d, partition #%d, path '%S'\n",
220 L"multi(0)disk(0)rdisk(%lu)partition(%lu)",
243 L"multi(0)disk(0)fdisk(%lu)", DiskNumber);
266 DPRINT1(
"Unhandled NT path '%S'\n", BootPath);
280 BootEntry->BootFilePath =
NULL;
287 Options->BootPath = BootPathBuffer;
339 DPRINT(
" An installation '%S' of unsupported type %lu\n",
340 BootEntry->FriendlyName, BootEntry->OsOptionsLength);
349 DPRINT1(
" A Win2k3 install '%S' without an ARC path?!\n", BootEntry->FriendlyName);
369 DPRINT(
" Found a candidate Win2k3 install '%S' with ARC path '%S'\n",
370 BootEntry->FriendlyName,
Options->OsLoadPath);
374 DPRINT(
"EnumerateReactOSEntries: OsLoadPath: '%S'\n",
Options->OsLoadPath);
387 L"ReactOS_%lu",
Data->i);
389 L"\"ReactOS %lu\"",
Data->i);
402 PVOID BootStoreHandle;
417 Data.ArcPath = ArcPath;
428 if (!
Data.UseExistingEntry)
434 BootEntry->BootFilePath =
NULL;
444 BootEntry->FriendlyName =
Data.OsName;
462 PVOID BootStoreHandle;
479 Data.ArcPath = EntryName;
490 if (!
Data.UseExistingEntry
493 BootEntry->Version =
NtLdr;
494 BootEntry->BootFilePath =
NULL;
501 Options->OsLoadPath = EntryName;
505 BootEntry->FriendlyName = EntryValue;
626 IN PFS_INSTALL_BOOTCODE InstallBootCode)
661 DPRINT1(
"Unable to lock the volume before installing boot code. Status 0x%08x. Expect problems.\n", LockStatus);
665 Status = InstallBootCode(SrcPath, PartitionHandle, PartitionHandle);
673 DPRINT1(
"Unable to dismount the volume after installing boot code. Status 0x%08x. Expect problems.\n", LockStatus);
679 DPRINT1(
"Unable to unlock the volume after installing boot code. Status 0x%08x. Expect problems.\n", LockStatus);
695 IN PFS_INSTALL_BOOTCODE InstallBootCode)
853 L"\\Device\\Harddisk%d\\Partition0",
858 SourceRootPath->Buffer,
L"\\loader\\dosmbr.bin");
864 SystemRootPath->Buffer,
L"mbr.old");
866 DPRINT1(
"Save MBR: %S ==> %S\n", DestinationDevicePathBuffer,
DstPath);
875 DPRINT1(
"Install MBR bootcode: %S ==> %S\n",
876 SourceMbrPathBuffer, DestinationDevicePathBuffer);
880 DestinationDevicePathBuffer,
902 DPRINT1(
"SetupCopyFile() failed (Status 0x%08lx)\n",
Status);
914 DPRINT1(
"SetupCopyFile() failed (Status 0x%08lx)\n",
Status);
935 DPRINT(
"System path: '%wZ'\n", SystemRootPath);
941 DPRINT1(
"InstallBootloaderFiles() failed (Status %lx)\n",
Status);
947 if (DoesFreeLdrExist)
950 DPRINT1(
"Update existing 'freeldr.ini'\n");
954 DPRINT1(
"UpdateFreeLoaderIni() failed (Status %lx)\n",
Status);
968 DPRINT1(
"Found Microsoft Windows NT/2000/XP boot loader\n");
971 if (DoesFreeLdrExist ==
FALSE)
974 DPRINT1(
"Create new 'freeldr.ini'\n");
978 DPRINT1(
"CreateFreeLoaderIniForReactOS() failed (Status %lx)\n",
Status);
985 if (
_wcsicmp(FileSystemName,
L"FAT32") == 0)
992 SystemRootPath->Buffer,
996 DPRINT1(
"InstallBootCodeToFile(FAT32) failed (Status %lx)\n",
Status);
1005 DPRINT1(
"Install FAT16 bootcode: %S ==> %S\n", SrcPath,
DstPath);
1007 SystemRootPath->Buffer,
1011 DPRINT1(
"InstallBootCodeToFile(FAT16) failed (Status %lx)\n",
Status);
1020 DPRINT1(
"Update 'boot.ini'\n");
1022 L"C:\\bootsect.ros",
1042 DPRINT1(
"Found COMPAQ MS-DOS 1.x (1.11, 1.12) / MS-DOS 1.25 boot loader\n");
1044 Section =
L"CPQDOS";
1054 DPRINT1(
"Found Microsoft DOS or Windows 9x boot loader\n");
1066 DPRINT1(
"Found IBM PC-DOS or DR-DOS 5.x or IBM OS/2 1.0\n");
1068 Section =
L"IBMDOS";
1069 Description =
L"\"IBM PC-DOS or DR-DOS 5.x or IBM OS/2 1.0\"";
1077 DPRINT1(
"Found DR-DOS 3.x\n");
1088 DPRINT1(
"Found Dell Real-Mode Kernel OS\n");
1100 DPRINT1(
"Found MS OS/2 1.x\n");
1112 DPRINT1(
"Found MS/IBM OS/2\n");
1114 Section =
L"IBMOS2";
1122 DPRINT1(
"Found FreeDOS boot loader\n");
1131 DPRINT1(
"No or unknown boot loader found\n");
1133 Section =
L"Unknown";
1139 if (DoesFreeLdrExist ==
FALSE)
1142 DPRINT1(
"Create new 'freeldr.ini'\n");
1147 SystemRootPath->Buffer, DestinationArcPath->Buffer,
1152 DPRINT1(
"CreateFreeLoaderIniForReactOSAndBootSector() failed (Status %lx)\n",
Status);
1159 DPRINT1(
"Save bootsector: %S ==> %S\n", SystemRootPath->Buffer,
DstPath);
1172 DPRINT1(
"CreateFreeLoaderIniForReactOS() failed (Status %lx)\n",
Status);
1178 if (
_wcsicmp(FileSystemName,
L"FAT32") == 0)
1183 DPRINT1(
"Install FAT32 bootcode: %S ==> %S\n", SrcPath, SystemRootPath->Buffer);
1188 DPRINT1(
"InstallBootCodeToDisk(FAT32) failed (Status %lx)\n",
Status);
1197 DPRINT1(
"Install FAT16 bootcode: %S ==> %S\n", SrcPath, SystemRootPath->Buffer);
1201 DPRINT1(
"InstallBootCodeToDisk(FAT16) failed (Status %lx)\n",
Status);
1224 DPRINT(
"System path: '%wZ'\n", SystemRootPath);
1230 DPRINT1(
"InstallBootloaderFiles() failed (Status %lx)\n",
Status);
1235 DoesFreeLdrExist =
DoesFileExist_2(SystemRootPath->Buffer,
L"freeldr.ini");
1236 if (DoesFreeLdrExist)
1239 DPRINT1(
"Update existing 'freeldr.ini'\n");
1243 DPRINT1(
"UpdateFreeLoaderIni() failed (Status %lx)\n",
Status);
1251 if (DoesFreeLdrExist ==
FALSE)
1254 DPRINT1(
"Create new 'freeldr.ini'\n");
1257 DPRINT1(
"*nix or unknown boot loader found\n");
1264 SystemRootPath->Buffer, DestinationArcPath->Buffer,
1265 L"Linux",
L"\"Linux\"",
1269 DPRINT1(
"CreateFreeLoaderIniForReactOSAndBootSector() failed (Status %lx)\n",
Status);
1276 DPRINT1(
"Save bootsector: %S ==> %S\n", SystemRootPath->Buffer,
DstPath);
1289 DPRINT1(
"CreateFreeLoaderIniForReactOS() failed (Status %lx)\n",
Status);
1298 DPRINT1(
"Install BTRFS bootcode: %S ==> %S\n", SrcPath, SystemRootPath->Buffer);
1302 DPRINT1(
"InstallBootCodeToDisk(BTRFS) failed (Status %lx)\n",
Status);
1323 DPRINT(
"System path: '%wZ'\n", SystemRootPath);
1329 DPRINT1(
"InstallBootloaderFiles() failed (Status %lx)\n",
Status);
1334 DoesFreeLdrExist =
DoesFileExist_2(SystemRootPath->Buffer,
L"freeldr.ini");
1335 if (DoesFreeLdrExist)
1338 DPRINT1(
"Update existing 'freeldr.ini'\n");
1342 DPRINT1(
"UpdateFreeLoaderIni() failed (Status %lx)\n",
Status);
1351 DPRINT1(
"Create new 'freeldr.ini'\n");
1354 DPRINT1(
"*nix or unknown boot loader found\n");
1361 SystemRootPath->Buffer, DestinationArcPath->Buffer,
1362 L"Linux",
L"\"Linux\"",
1366 DPRINT1(
"CreateFreeLoaderIniForReactOSAndBootSector() failed (Status %lx)\n",
Status);
1373 DPRINT1(
"Save bootsector: %S ==> %S\n", SystemRootPath->Buffer,
DstPath);
1386 DPRINT1(
"CreateFreeLoaderIniForReactOS() failed (Status %lx)\n",
Status);
1396 DPRINT1(
"Install NTFS bootcode: %S ==> %S\n", SrcPath, SystemRootPath->Buffer);
1400 DPRINT1(
"InstallBootCodeToDisk(NTFS) failed (Status %lx)\n",
Status);
1415 if (
_wcsicmp(FileSystemName,
L"FAT") == 0 ||
1416 _wcsicmp(FileSystemName,
L"FAT32") == 0)
1423 else if (
_wcsicmp(FileSystemName,
L"NTFS") == 0)
1427 DestinationArcPath);
1429 else if (
_wcsicmp(FileSystemName,
L"BTRFS") == 0)
1433 DestinationArcPath);
1446 DPRINT1(
"Unknown file system '%S'\n", FileSystemName);
1504 if (InstallType <= 1)
1513 DPRINT1(
"InstallVBRToPartition() failed (Status 0x%08lx)\n",
Status);
1523 L"\\Device\\Harddisk%d\\Partition0",
1530 DPRINT1(
"InstallMbrBootCodeToDisk() failed (Status 0x%08lx)\n",
Status);
1535 else if (InstallType == 2)
1550 DPRINT1(
"InstallBootloaderFiles() failed (Status 0x%08lx)\n",
Status);
1555 DPRINT(
"Create new 'freeldr.ini'\n");
1559 DPRINT1(
"CreateFreeLoaderIniForReactOS() failed (Status 0x%08lx)\n",
Status);
1566 DPRINT1(
"Install FAT12 bootcode: %S ==> %S\n", SrcPath, SystemRootPath->Buffer);
1570 DPRINT1(
"InstallBootCodeToDisk(FAT12) failed (Status 0x%08lx)\n",
Status);
1600 DPRINT1(
"Cannot open device '%wZ' (Status 0x%08lx)\n",
1613 DPRINT1(
"FileFsDeviceInformation failed (Status 0x%08lx)\n",
Status);
1699 DPRINT1(
"Cannot open %wZ for bootloader installation (Status 0x%08lx)\n",
1709 DPRINT1(
"GetFileSystemName() failed (Status 0x%08lx)\n",
Status);
1717 DPRINT1(
"FileFsDeviceInformation failed (Status 0x%08lx)\n",
Status);
1769 DPRINT1(
"Invalid disk number reported, bail out\n");
1785 DPRINT1(
"IOCTL_DISK_GET_DRIVE_GEOMETRY_EX failed (Status 0x%08lx)\n",
Status);
1807 DPRINT1(
"IOCTL_DISK_GET_PARTITION_INFO failed (Status 0x%08lx)\n",
Status);
1812 PartitionStyle = DiskGeoEx.
Partition.PartitionStyle;
1819 ArchType, SystemRootPath,
1821 SourceRootPath, DestinationArcPath,
Options);
1855 DPRINT1(
"FileFsDeviceInformation failed (Status 0x%08lx)\n",
Status);
1877 DPRINT1(
"Device is NOT removable!\n");
1885 FileSystemName = (
IsFloppy ?
L"FAT" :
L"FAT32");
1898 DPRINT1(
"%s FS non-existent on this system!\n", FileSystemName);
1900 DPRINT1(
"FormatFileSystem(%s) failed (Status 0x%08lx)\n", FileSystemName,
Status);
1911 DPRINT1(
"InstallBootManagerAndBootEntries() failed (Status 0x%08lx)\n",
Status);
PRTL_UNICODE_STRING_BUFFER Path
#define OBJ_NAME_PATH_SEPARATOR
NTSTATUS OpenBootStore(_Out_ PVOID *Handle, _In_ PCWSTR SystemPartition, _In_ BOOT_STORE_TYPE Type, _In_ BOOT_STORE_OPENMODE OpenMode, _In_ BOOT_STORE_ACCESS Access)
NTSTATUS SetBootStoreOptions(IN PVOID Handle, IN PBOOT_STORE_OPTIONS BootOptions, IN ULONG FieldsToChange)
NTSTATUS AddBootStoreEntry(IN PVOID Handle, IN PBOOT_STORE_ENTRY BootEntry, IN ULONG_PTR BootEntryKey)
NTSTATUS CloseBootStore(_In_ PVOID Handle)
NTSTATUS EnumerateBootStoreEntries(IN PVOID Handle, IN PENUM_BOOT_ENTRIES_ROUTINE EnumBootEntriesRoutine, IN PVOID Parameter OPTIONAL)
struct _BOOTSECTOR_OPTIONS BOOTSECTOR_OPTIONS
#define BOOTSECTOR_OPTIONS_SIGNATURE
struct _NTOS_OPTIONS NTOS_OPTIONS
#define BOOT_OPTIONS_NEXT_BOOTENTRY_KEY
#define BOOT_OPTIONS_TIMEOUT
struct _NTOS_OPTIONS * PNTOS_OPTIONS
struct _BOOT_STORE_ENTRY * PBOOT_STORE_ENTRY
#define NTOS_OPTIONS_SIGNATURE
struct _BOOTSECTOR_OPTIONS * PBOOTSECTOR_OPTIONS
enum _BOOT_STORE_TYPE BOOT_STORE_TYPE
VOID FreeBootCode(IN OUT PBOOTCODE BootCodeInfo)
NTSTATUS ReadBootCodeByHandle(IN OUT PBOOTCODE BootCodeInfo, IN HANDLE FileHandle, IN ULONG Length OPTIONAL)
NTSTATUS ReadBootCodeFromFile(IN OUT PBOOTCODE BootCodeInfo, IN PUNICODE_STRING FilePath, IN ULONG Length OPTIONAL)
static NTSTATUS InstallBootloaderFiles(_In_ PCUNICODE_STRING SystemRootPath, _In_ PCUNICODE_STRING SourceRootPath)
static NTSTATUS InstallMbrBootCode(IN PCWSTR SrcPath, IN HANDLE DstPath, IN HANDLE DiskHandle)
static NTSTATUS SaveBootSector(IN PCWSTR RootPath, IN PCWSTR DstPath, IN ULONG Length)
static NTSTATUS InstallFatBootcodeToPartition(_In_ PCUNICODE_STRING SystemRootPath, _In_ PCUNICODE_STRING SourceRootPath, _In_ PCUNICODE_STRING DestinationArcPath, _In_ PCWSTR FileSystemName)
static NTSTATUS UpdateBootIni(IN PCWSTR IniPath, IN PCWSTR EntryName, IN PCWSTR EntryValue)
static NTSTATUS NTAPI EnumerateReactOSEntries(IN BOOT_STORE_TYPE Type, IN PBOOT_STORE_ENTRY BootEntry, IN PVOID Parameter OPTIONAL)
static NTSTATUS InstallBtrfsBootcodeToPartition(_In_ PCUNICODE_STRING SystemRootPath, _In_ PCUNICODE_STRING SourceRootPath, _In_ PCUNICODE_STRING DestinationArcPath)
static NTSTATUS InstallMbrBootCodeToDisk(_In_ PCUNICODE_STRING SystemRootPath, _In_ PCUNICODE_STRING SourceRootPath, _In_ PCWSTR DestinationDevicePathBuffer)
NTSTATUS NTAPI InstallBootcodeToRemovable(_In_ ARCHITECTURE_TYPE ArchType, _In_ PCUNICODE_STRING RemovableRootPath, _In_ PCUNICODE_STRING SourceRootPath, _In_ PCUNICODE_STRING DestinationArcPath)
static NTSTATUS CreateFreeLoaderIniForReactOS(IN PCWSTR IniPath, IN PCWSTR ArcPath)
static NTSTATUS InstallBootCodeToFile(IN PCWSTR SrcPath, IN PCWSTR DstPath, IN PCWSTR RootPath, IN PFS_INSTALL_BOOTCODE InstallBootCode)
static NTSTATUS CreateFreeLoaderIniForReactOSAndBootSector(IN PCWSTR IniPath, IN PCWSTR ArcPath, IN PCWSTR Section, IN PCWSTR Description, IN PCWSTR BootPath, IN PCWSTR BootSector)
static NTSTATUS InstallNtfsBootcodeToPartition(_In_ PCUNICODE_STRING SystemRootPath, _In_ PCUNICODE_STRING SourceRootPath, _In_ PCUNICODE_STRING DestinationArcPath)
static BOOLEAN IsThereAValidBootSector(IN PCWSTR RootPath)
static NTSTATUS InstallBootManagerAndBootEntriesWorker(_In_ ARCHITECTURE_TYPE ArchType, _In_ PCUNICODE_STRING SystemRootPath, _In_ ULONG DiskNumber, _In_ PARTITION_STYLE DiskStyle, _In_ BOOLEAN IsSuperFloppy, _In_ PCWSTR FileSystem, _In_ PCUNICODE_STRING SourceRootPath, _In_ PCUNICODE_STRING DestinationArcPath, _In_ ULONG_PTR Options)
Helper for InstallBootManagerAndBootEntries().
NTSTATUS GetDeviceInfo(_In_opt_ PCWSTR DeviceName, _In_opt_ HANDLE DeviceHandle, _Out_ PFILE_FS_DEVICE_INFORMATION DeviceInfo)
NTSTATUS NTAPI InstallBootManagerAndBootEntries(_In_ ARCHITECTURE_TYPE ArchType, _In_ PCUNICODE_STRING SystemRootPath, _In_ PCUNICODE_STRING SourceRootPath, _In_ PCUNICODE_STRING DestinationArcPath, _In_ ULONG_PTR Options)
Installs FreeLoader on the system and configure the boot entries.
struct _ENUM_REACTOS_ENTRIES_DATA * PENUM_REACTOS_ENTRIES_DATA
static NTSTATUS InstallVBRToPartition(_In_ PCUNICODE_STRING SystemRootPath, _In_ PCUNICODE_STRING SourceRootPath, _In_ PCUNICODE_STRING DestinationArcPath, _In_ PCWSTR FileSystemName)
static VOID TrimTrailingPathSeparators_UStr(IN OUT PUNICODE_STRING UnicodeString)
struct _ENUM_REACTOS_ENTRIES_DATA ENUM_REACTOS_ENTRIES_DATA
BOOLEAN IsUnattendedSetup
static NTSTATUS InstallBootCodeToDisk(IN PCWSTR SrcPath, IN PCWSTR RootPath, IN PFS_INSTALL_BOOTCODE InstallBootCode)
NTSTATUS GetDeviceInfo_UStr(_In_opt_ PCUNICODE_STRING DeviceName, _In_opt_ HANDLE DeviceHandle, _Out_ PFILE_FS_DEVICE_INFORMATION DeviceInfo)
static NTSTATUS UpdateFreeLoaderIni(IN PCWSTR IniPath, IN PCWSTR ArcPath)
static VOID CreateFreeLoaderReactOSEntries(IN PVOID BootStoreHandle, IN PCWSTR ArcPath)
_In_ PFCB _In_ LONGLONG FileOffset
_In_ PCHAR _In_ ULONG DeviceNumber
IN PUNICODE_STRING IN POBJECT_ATTRIBUTES ObjectAttributes
#define STATUS_NOT_SUPPORTED
NTSTATUS pOpenDeviceEx_UStr(_In_ PCUNICODE_STRING DevicePath, _Out_ PHANDLE DeviceHandle, _In_ ACCESS_MASK DesiredAccess, _In_ ULONG ShareAccess)
Open an existing device given by its NT-style path, which is assumed to be for a disk device or a par...
#define NT_SUCCESS(StatCode)
static const WCHAR Description[]
#define FILE_ATTRIBUTE_NORMAL
static const WCHAR Signature[]
static BOOL IsFloppy(PCWSTR pszDrive)
struct _DISK_GEOMETRY_EX_INTERNAL * PDISK_GEOMETRY_EX_INTERNAL
struct _DISK_GEOMETRY_EX_INTERNAL DISK_GEOMETRY_EX_INTERNAL
#define RtlCompareMemory(s1, s2, l)
NTSTATUS CombinePaths(OUT PWSTR PathBuffer, IN SIZE_T cchPathSize, IN ULONG NumberOfPathComponents, IN ...)
BOOLEAN DoesFileExist_2(IN PCWSTR PathName OPTIONAL, IN PCWSTR FileName)
BOOLEAN NtPathToDiskPartComponents(IN PCWSTR NtPath, OUT PULONG pDiskNumber, OUT PULONG pPartNumber, OUT PCWSTR *PathComponent OPTIONAL)
NTSTATUS SetupCopyFile(IN PCWSTR SourceFileName, IN PCWSTR DestinationFileName, IN BOOLEAN FailIfExists)
#define DoesDirExist(RootDirectory, DirName)
#define IOCTL_DISK_GET_DRIVE_GEOMETRY_EX
_Must_inspect_result_ _In_opt_ PFLT_INSTANCE _Out_ PHANDLE FileHandle
#define FILE_SYNCHRONOUS_IO_NONALERT
@ FileFsDeviceInformation
#define FILE_SEQUENTIAL_ONLY
NTSTATUS GetFileSystemName_UStr(IN PUNICODE_STRING PartitionPath OPTIONAL, IN HANDLE PartitionHandle OPTIONAL, IN OUT PWSTR FileSystemName, IN SIZE_T FileSystemNameSize)
_Inout_ PUSB_DEVICE_HANDLE DeviceHandle
_Check_return_ unsigned long __cdecl wcstoul(_In_z_ const wchar_t *_Str, _Out_opt_ _Deref_post_z_ wchar_t **_EndPtr, _In_ int _Radix)
#define OBJ_CASE_INSENSITIVE
#define RTL_FIELD_SIZE(type, field)
UNICODE_STRING DeviceFloppy
enum _PARTITION_STYLE PARTITION_STYLE
static OUT PIO_STATUS_BLOCK IoStatusBlock
#define InitializeObjectAttributes(p, n, a, r, s)
NTSYSAPI NTSTATUS NTAPI NtOpenFile(OUT PHANDLE phFile, IN ACCESS_MASK DesiredAccess, IN POBJECT_ATTRIBUTES ObjectAttributes, OUT PIO_STATUS_BLOCK pIoStatusBlock, IN ULONG ShareMode, IN ULONG OpenMode)
#define FSCTL_LOCK_VOLUME
NTSYSAPI NTSTATUS NTAPI NtWriteFile(IN HANDLE hFile, IN HANDLE hEvent OPTIONAL, IN PIO_APC_ROUTINE IoApcRoutine OPTIONAL, IN PVOID IoApcContext OPTIONAL, OUT PIO_STATUS_BLOCK pIoStatusBlock, IN PVOID WriteBuffer, IN ULONG WriteBufferLength, IN PLARGE_INTEGER FileOffset OPTIONAL, IN PULONG LockOperationKey OPTIONAL)
#define FILE_READ_ATTRIBUTES
NTSYSAPI VOID NTAPI RtlInitUnicodeString(PUNICODE_STRING DestinationString, PCWSTR SourceString)
NTSYSAPI NTSTATUS NTAPI NtDeviceIoControlFile(IN HANDLE hFile, IN HANDLE hEvent OPTIONAL, IN PIO_APC_ROUTINE IoApcRoutine OPTIONAL, IN PVOID IoApcContext OPTIONAL, OUT PIO_STATUS_BLOCK pIoStatusBlock, IN ULONG DeviceIoControlCode, IN PVOID InBuffer OPTIONAL, IN ULONG InBufferLength, OUT PVOID OutBuffer OPTIONAL, IN ULONG OutBufferLength)
#define FSCTL_UNLOCK_VOLUME
NTSTATUS NTAPI NtClose(IN HANDLE Handle)
#define FILE_FLOPPY_DISKETTE
NTSYSAPI BOOLEAN NTAPI RtlPrefixUnicodeString(IN PUNICODE_STRING String1, IN PUNICODE_STRING String2, IN BOOLEAN CaseInSensitive)
#define FSCTL_DISMOUNT_VOLUME
NTSTATUS NTAPI NtCreateFile(OUT PHANDLE FileHandle, IN ACCESS_MASK DesiredAccess, IN POBJECT_ATTRIBUTES ObjectAttributes, OUT PIO_STATUS_BLOCK IoStatusBlock, IN PLARGE_INTEGER AllocationSize OPTIONAL, IN ULONG FileAttributes, IN ULONG ShareAccess, IN ULONG CreateDisposition, IN ULONG CreateOptions, IN PVOID EaBuffer OPTIONAL, IN ULONG EaLength)
NTSYSAPI NTSTATUS NTAPI NtFsControlFile(IN HANDLE hFile, IN HANDLE hEvent OPTIONAL, IN PIO_APC_ROUTINE IoApcRoutine OPTIONAL, IN PVOID IoApcContext OPTIONAL, OUT PIO_STATUS_BLOCK pIoStatusBlock, IN ULONG DeviceIoControlCode, IN PVOID InBuffer OPTIONAL, IN ULONG InBufferLength, OUT PVOID OutBuffer OPTIONAL, IN ULONG OutBufferLength)
#define FILE_REMOVABLE_MEDIA
__GNU_EXTENSION typedef unsigned __int64 * PULONGLONG
#define IOCTL_DISK_GET_PARTITION_INFO
_In_ ULONG _In_ ULONG _In_ ULONG Length
#define IOCTL_STORAGE_GET_DEVICE_NUMBER
#define STATUS_INVALID_PARAMETER_MIX
#define STATUS_NO_MORE_ENTRIES
NTSTRSAFEAPI RtlStringCchCopyW(_Out_writes_(cchDest) _Always_(_Post_z_) NTSTRSAFE_PWSTR pszDest, _In_ size_t cchDest, _In_ NTSTRSAFE_PCWSTR pszSrc)
NTSTRSAFEAPI RtlStringCchCatW(_Inout_updates_(cchDest) _Always_(_Post_z_) NTSTRSAFE_PWSTR pszDest, _In_ size_t cchDest, _In_ NTSTRSAFE_PCWSTR pszSrc)
NTSTRSAFEVAPI RtlStringCchPrintfW(_Out_writes_(cchDest) _Always_(_Post_z_) NTSTRSAFE_PWSTR pszDest, _In_ size_t cchDest, _In_ _Printf_format_string_ NTSTRSAFE_PCWSTR pszFormat,...)
_Check_return_ _CRTIMP int __cdecl _wcsicmp(_In_z_ const wchar_t *_Str1, _In_z_ const wchar_t *_Str2)
_Check_return_ _CRTIMP int __cdecl wcscmp(_In_z_ const wchar_t *_Str1, _In_z_ const wchar_t *_Str2)
_Check_return_ _CRTIMP int __cdecl _wcsnicmp(_In_reads_or_z_(_MaxCount) const wchar_t *_Str1, _In_reads_or_z_(_MaxCount) const wchar_t *_Str2, _In_ size_t _MaxCount)
NTSTATUS InstallFat32BootCode(IN PCWSTR SrcPath, IN HANDLE DstPath, IN HANDLE RootPartition)
NTSTATUS NTAPI FormatFileSystem_UStr(_In_ PUNICODE_STRING DriveRoot, _In_ PCWSTR FileSystemName, _In_ FMIFS_MEDIA_FLAG MediaFlag, _In_opt_ PUNICODE_STRING Label, _In_ BOOLEAN QuickFormat, _In_ ULONG ClusterSize, _In_opt_ PFMIFSCALLBACK Callback)
NTSTATUS InstallBtrfsBootCode(IN PCWSTR SrcPath, IN HANDLE DstPath, IN HANDLE RootPartition)
NTSTATUS InstallNtfsBootCode(IN PCWSTR SrcPath, IN HANDLE DstPath, IN HANDLE RootPartition)
IN HANDLE IN HANDLE RootPartition
#define NTFS_BOOTSECTOR_SIZE
#define InstallFat16BootCode
#define InstallFat12BootCode
#define BTRFS_BOOTSECTOR_SIZE
BOOLEAN IsDiskSuperFloppy2(_In_ const DISK_PARTITION_INFO *DiskInfo, _In_opt_ const ULONGLONG *DiskSize, _In_ const PARTITION_INFORMATION *PartitionInfo)
BOOLEAN IsSuperFloppy(_In_ PDISKENTRY DiskEntry)
enum _ARCHITECTURE_TYPE ARCHITECTURE_TYPE
#define STATUS_DEVICE_NOT_READY
NTSTATUS NTAPI NtQueryVolumeInformationFile(HANDLE FileHandle, PIO_STATUS_BLOCK IoStatusBlock, PVOID FsInformation, ULONG Length, FS_INFORMATION_CLASS FsInformationClass)
PULONG MinorVersion OPTIONAL
DISK_PARTITION_INFO Partition
#define RTL_CONSTANT_STRING(s)
#define FIELD_OFFSET(t, f)
#define RtlCopyMemory(Destination, Source, Length)
#define STATUS_INVALID_DEVICE_REQUEST
_In_ PWDFDEVICE_INIT _In_ PWDF_REMOVE_LOCK_OPTIONS Options
_Must_inspect_result_ _In_ PWDFDEVICE_INIT _In_opt_ PCUNICODE_STRING DeviceName
_In_ ULONG _In_ struct _SET_PARTITION_INFORMATION_EX * PartitionInfo
_In_ ULONG _In_ ULONG PartitionNumber
_Inout_opt_ PVOID Parameter