[SETUPLIB][USETUP] Introduce a 'SetupLib' library. CORE-13544
- Create the beginnings of a "setuplib" library, whose aim is to be shared between the (currently existing) 1st-stage text-mode installer, and the (future) 1st-stage GUI installer.
- Finish to split the GenList and PartList codes into their UI part, which remain in usetup, and their algorithmic part, which go into setuplib.
- Move SetMountedDeviceValue into the PartList module.
- Split the FileSystem list code into its UI and the algorithmic part (which goes into setuplib under the name fsutil.c).
* The algo part is meant to be able to manage the filesystems available on the running system, similarly to what is mostly done (in scattered form) in fmifs, format, chkdsk / autochk codes...
It also manages the partition filesystem recognition, using OS routines.
* The UI part manages the FS list as it appears on screen, showing only the possible FSes that can be used to format the selected partition (a bit similar to what we do in the shell32's drive.c, etc...).
- Adapt the calling code to these changes.
- Remove some "host" code that was dating back from the dark old times.
svn path=/branches/setup_improvements/; revision=74570
svn path=/branches/setup_improvements/; revision=74659
2017-05-17 23:37:41 +00:00
|
|
|
/*
|
|
|
|
* PROJECT: ReactOS Setup Library
|
2020-11-23 03:38:51 +00:00
|
|
|
* LICENSE: GPL-2.0-or-later (https://spdx.org/licenses/GPL-2.0-or-later)
|
|
|
|
* PURPOSE: Filesystem Format and ChkDsk support functions
|
|
|
|
* COPYRIGHT: Copyright 2003-2019 Casper S. Hornstrup <chorns@users.sourceforge.net>
|
|
|
|
* Copyright 2017-2024 Hermès Bélusca-Maïto <hermes.belusca-maito@reactos.org>
|
[SETUPLIB][USETUP] Introduce a 'SetupLib' library. CORE-13544
- Create the beginnings of a "setuplib" library, whose aim is to be shared between the (currently existing) 1st-stage text-mode installer, and the (future) 1st-stage GUI installer.
- Finish to split the GenList and PartList codes into their UI part, which remain in usetup, and their algorithmic part, which go into setuplib.
- Move SetMountedDeviceValue into the PartList module.
- Split the FileSystem list code into its UI and the algorithmic part (which goes into setuplib under the name fsutil.c).
* The algo part is meant to be able to manage the filesystems available on the running system, similarly to what is mostly done (in scattered form) in fmifs, format, chkdsk / autochk codes...
It also manages the partition filesystem recognition, using OS routines.
* The UI part manages the FS list as it appears on screen, showing only the possible FSes that can be used to format the selected partition (a bit similar to what we do in the shell32's drive.c, etc...).
- Adapt the calling code to these changes.
- Remove some "host" code that was dating back from the dark old times.
svn path=/branches/setup_improvements/; revision=74570
svn path=/branches/setup_improvements/; revision=74659
2017-05-17 23:37:41 +00:00
|
|
|
*/
|
|
|
|
|
2017-08-26 11:42:32 +00:00
|
|
|
#pragma once
|
|
|
|
|
[SETUPLIB][USETUP] Introduce a 'SetupLib' library. CORE-13544
- Create the beginnings of a "setuplib" library, whose aim is to be shared between the (currently existing) 1st-stage text-mode installer, and the (future) 1st-stage GUI installer.
- Finish to split the GenList and PartList codes into their UI part, which remain in usetup, and their algorithmic part, which go into setuplib.
- Move SetMountedDeviceValue into the PartList module.
- Split the FileSystem list code into its UI and the algorithmic part (which goes into setuplib under the name fsutil.c).
* The algo part is meant to be able to manage the filesystems available on the running system, similarly to what is mostly done (in scattered form) in fmifs, format, chkdsk / autochk codes...
It also manages the partition filesystem recognition, using OS routines.
* The UI part manages the FS list as it appears on screen, showing only the possible FSes that can be used to format the selected partition (a bit similar to what we do in the shell32's drive.c, etc...).
- Adapt the calling code to these changes.
- Remove some "host" code that was dating back from the dark old times.
svn path=/branches/setup_improvements/; revision=74570
svn path=/branches/setup_improvements/; revision=74659
2017-05-17 23:37:41 +00:00
|
|
|
#include <fmifs/fmifs.h>
|
|
|
|
|
2019-02-24 16:52:33 +00:00
|
|
|
/** QueryAvailableFileSystemFormat() **/
|
|
|
|
BOOLEAN
|
|
|
|
GetRegisteredFileSystems(
|
|
|
|
IN ULONG Index,
|
|
|
|
OUT PCWSTR* FileSystemName);
|
[SETUPLIB][USETUP] Introduce a 'SetupLib' library. CORE-13544
- Create the beginnings of a "setuplib" library, whose aim is to be shared between the (currently existing) 1st-stage text-mode installer, and the (future) 1st-stage GUI installer.
- Finish to split the GenList and PartList codes into their UI part, which remain in usetup, and their algorithmic part, which go into setuplib.
- Move SetMountedDeviceValue into the PartList module.
- Split the FileSystem list code into its UI and the algorithmic part (which goes into setuplib under the name fsutil.c).
* The algo part is meant to be able to manage the filesystems available on the running system, similarly to what is mostly done (in scattered form) in fmifs, format, chkdsk / autochk codes...
It also manages the partition filesystem recognition, using OS routines.
* The UI part manages the FS list as it appears on screen, showing only the possible FSes that can be used to format the selected partition (a bit similar to what we do in the shell32's drive.c, etc...).
- Adapt the calling code to these changes.
- Remove some "host" code that was dating back from the dark old times.
svn path=/branches/setup_improvements/; revision=74570
svn path=/branches/setup_improvements/; revision=74659
2017-05-17 23:37:41 +00:00
|
|
|
|
2019-02-24 16:52:33 +00:00
|
|
|
|
|
|
|
/** ChkdskEx() **/
|
|
|
|
NTSTATUS
|
|
|
|
ChkdskFileSystem_UStr(
|
2020-11-23 03:38:51 +00:00
|
|
|
_In_ PUNICODE_STRING DriveRoot,
|
|
|
|
_In_ PCWSTR FileSystemName,
|
|
|
|
_In_ BOOLEAN FixErrors,
|
|
|
|
_In_ BOOLEAN Verbose,
|
|
|
|
_In_ BOOLEAN CheckOnlyIfDirty,
|
|
|
|
_In_ BOOLEAN ScanDrive,
|
|
|
|
_In_opt_ PFMIFSCALLBACK Callback);
|
2019-02-24 16:52:33 +00:00
|
|
|
|
|
|
|
NTSTATUS
|
|
|
|
ChkdskFileSystem(
|
2020-11-23 03:38:51 +00:00
|
|
|
_In_ PCWSTR DriveRoot,
|
|
|
|
_In_ PCWSTR FileSystemName,
|
|
|
|
_In_ BOOLEAN FixErrors,
|
|
|
|
_In_ BOOLEAN Verbose,
|
|
|
|
_In_ BOOLEAN CheckOnlyIfDirty,
|
|
|
|
_In_ BOOLEAN ScanDrive,
|
|
|
|
_In_opt_ PFMIFSCALLBACK Callback);
|
[SETUPLIB][USETUP] Introduce a 'SetupLib' library. CORE-13544
- Create the beginnings of a "setuplib" library, whose aim is to be shared between the (currently existing) 1st-stage text-mode installer, and the (future) 1st-stage GUI installer.
- Finish to split the GenList and PartList codes into their UI part, which remain in usetup, and their algorithmic part, which go into setuplib.
- Move SetMountedDeviceValue into the PartList module.
- Split the FileSystem list code into its UI and the algorithmic part (which goes into setuplib under the name fsutil.c).
* The algo part is meant to be able to manage the filesystems available on the running system, similarly to what is mostly done (in scattered form) in fmifs, format, chkdsk / autochk codes...
It also manages the partition filesystem recognition, using OS routines.
* The UI part manages the FS list as it appears on screen, showing only the possible FSes that can be used to format the selected partition (a bit similar to what we do in the shell32's drive.c, etc...).
- Adapt the calling code to these changes.
- Remove some "host" code that was dating back from the dark old times.
svn path=/branches/setup_improvements/; revision=74570
svn path=/branches/setup_improvements/; revision=74659
2017-05-17 23:37:41 +00:00
|
|
|
|
|
|
|
|
2019-02-24 16:52:33 +00:00
|
|
|
/** FormatEx() **/
|
|
|
|
NTSTATUS
|
|
|
|
FormatFileSystem_UStr(
|
2020-11-23 03:38:51 +00:00
|
|
|
_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);
|
2019-02-24 16:52:33 +00:00
|
|
|
|
|
|
|
NTSTATUS
|
|
|
|
FormatFileSystem(
|
2020-11-23 03:38:51 +00:00
|
|
|
_In_ PCWSTR DriveRoot,
|
|
|
|
_In_ PCWSTR FileSystemName,
|
|
|
|
_In_ FMIFS_MEDIA_FLAG MediaFlag,
|
|
|
|
_In_opt_ PCWSTR Label,
|
|
|
|
_In_ BOOLEAN QuickFormat,
|
|
|
|
_In_ ULONG ClusterSize,
|
|
|
|
_In_opt_ PFMIFSCALLBACK Callback);
|
2019-02-24 16:52:33 +00:00
|
|
|
|
|
|
|
|
2020-10-17 18:29:47 +00:00
|
|
|
//
|
|
|
|
// Bootsector routines
|
|
|
|
//
|
|
|
|
|
|
|
|
#define FAT_BOOTSECTOR_SIZE (1 * SECTORSIZE)
|
|
|
|
#define FAT32_BOOTSECTOR_SIZE (1 * SECTORSIZE) // Counts only the primary sector.
|
|
|
|
#define BTRFS_BOOTSECTOR_SIZE (3 * SECTORSIZE)
|
2022-10-19 00:02:24 +00:00
|
|
|
#define NTFS_BOOTSECTOR_SIZE (16 * SECTORSIZE)
|
2020-10-17 18:29:47 +00:00
|
|
|
|
|
|
|
typedef NTSTATUS
|
|
|
|
(/*NTAPI*/ *PFS_INSTALL_BOOTCODE)(
|
|
|
|
IN PCWSTR SrcPath, // Bootsector source file (on the installation medium)
|
|
|
|
IN HANDLE DstPath, // Where to save the bootsector built from the source + partition information
|
|
|
|
IN HANDLE RootPartition); // Partition holding the (old) bootsector data information
|
|
|
|
|
|
|
|
NTSTATUS
|
2020-10-19 21:49:26 +00:00
|
|
|
InstallFatBootCode(
|
2020-10-17 18:29:47 +00:00
|
|
|
IN PCWSTR SrcPath,
|
|
|
|
IN HANDLE DstPath,
|
|
|
|
IN HANDLE RootPartition);
|
|
|
|
|
2020-10-19 21:49:26 +00:00
|
|
|
#define InstallFat12BootCode InstallFatBootCode
|
|
|
|
#define InstallFat16BootCode InstallFatBootCode
|
2020-10-17 18:29:47 +00:00
|
|
|
|
|
|
|
NTSTATUS
|
|
|
|
InstallFat32BootCode(
|
|
|
|
IN PCWSTR SrcPath,
|
|
|
|
IN HANDLE DstPath,
|
|
|
|
IN HANDLE RootPartition);
|
|
|
|
|
|
|
|
NTSTATUS
|
|
|
|
InstallBtrfsBootCode(
|
|
|
|
IN PCWSTR SrcPath,
|
|
|
|
IN HANDLE DstPath,
|
|
|
|
IN HANDLE RootPartition);
|
|
|
|
|
2022-10-19 00:02:24 +00:00
|
|
|
NTSTATUS
|
|
|
|
InstallNtfsBootCode(
|
|
|
|
IN PCWSTR SrcPath,
|
|
|
|
IN HANDLE DstPath,
|
|
|
|
IN HANDLE RootPartition);
|
|
|
|
|
2020-10-17 18:29:47 +00:00
|
|
|
|
2019-02-24 16:52:33 +00:00
|
|
|
//
|
|
|
|
// Formatting routines
|
|
|
|
//
|
|
|
|
|
2020-11-24 01:26:52 +00:00
|
|
|
NTSTATUS
|
|
|
|
ChkdskPartition(
|
2020-11-23 03:38:51 +00:00
|
|
|
_In_ PPARTENTRY PartEntry,
|
|
|
|
_In_ BOOLEAN FixErrors,
|
|
|
|
_In_ BOOLEAN Verbose,
|
|
|
|
_In_ BOOLEAN CheckOnlyIfDirty,
|
|
|
|
_In_ BOOLEAN ScanDrive,
|
|
|
|
_In_opt_ PFMIFSCALLBACK Callback);
|
2017-05-17 23:31:52 +00:00
|
|
|
|
2020-11-24 01:26:52 +00:00
|
|
|
NTSTATUS
|
|
|
|
FormatPartition(
|
2020-11-23 03:38:51 +00:00
|
|
|
_In_ PPARTENTRY PartEntry,
|
|
|
|
_In_ PCWSTR FileSystemName,
|
|
|
|
_In_ FMIFS_MEDIA_FLAG MediaFlag,
|
|
|
|
_In_opt_ PCWSTR Label,
|
|
|
|
_In_ BOOLEAN QuickFormat,
|
|
|
|
_In_ ULONG ClusterSize,
|
|
|
|
_In_opt_ PFMIFSCALLBACK Callback);
|
|
|
|
|
|
|
|
|
|
|
|
//
|
|
|
|
// FileSystem Volume Operations Queue
|
|
|
|
//
|
|
|
|
|
|
|
|
typedef enum _FSVOLNOTIFY
|
|
|
|
{
|
|
|
|
FSVOLNOTIFY_STARTQUEUE = 0,
|
|
|
|
FSVOLNOTIFY_ENDQUEUE,
|
|
|
|
FSVOLNOTIFY_STARTSUBQUEUE,
|
|
|
|
FSVOLNOTIFY_ENDSUBQUEUE,
|
|
|
|
// FSVOLNOTIFY_STARTPARTITION, FSVOLNOTIFY_ENDPARTITION,
|
|
|
|
FSVOLNOTIFY_PARTITIONERROR,
|
|
|
|
FSVOLNOTIFY_STARTFORMAT,
|
|
|
|
FSVOLNOTIFY_ENDFORMAT,
|
|
|
|
FSVOLNOTIFY_FORMATERROR,
|
|
|
|
FSVOLNOTIFY_STARTCHECK,
|
|
|
|
FSVOLNOTIFY_ENDCHECK,
|
|
|
|
FSVOLNOTIFY_CHECKERROR,
|
|
|
|
/**/ChangeSystemPartition/**/ // FIXME: Deprecate!
|
|
|
|
} FSVOLNOTIFY;
|
|
|
|
|
|
|
|
typedef enum _FSVOL_OP
|
|
|
|
{
|
|
|
|
/* Operations ****/
|
|
|
|
FSVOL_FORMAT = 0,
|
|
|
|
FSVOL_CHECK,
|
|
|
|
/* Response actions ****/
|
|
|
|
FSVOL_ABORT = 0,
|
|
|
|
FSVOL_DOIT,
|
|
|
|
FSVOL_RETRY = FSVOL_DOIT,
|
|
|
|
FSVOL_SKIP,
|
|
|
|
} FSVOL_OP;
|
|
|
|
|
|
|
|
typedef struct _FORMAT_VOLUME_INFO
|
|
|
|
{
|
|
|
|
PPARTENTRY PartEntry;
|
|
|
|
// PCWSTR NtPathPartition;
|
|
|
|
NTSTATUS ErrorStatus;
|
|
|
|
|
|
|
|
/* Input information given by the 'FSVOLNOTIFY_STARTFORMAT' step ****/
|
|
|
|
PCWSTR FileSystemName;
|
|
|
|
FMIFS_MEDIA_FLAG MediaFlag;
|
|
|
|
PCWSTR Label;
|
|
|
|
BOOLEAN QuickFormat;
|
|
|
|
ULONG ClusterSize;
|
|
|
|
PFMIFSCALLBACK Callback;
|
|
|
|
|
|
|
|
} FORMAT_VOLUME_INFO, *PFORMAT_VOLUME_INFO;
|
|
|
|
|
|
|
|
typedef struct _CHECK_VOLUME_INFO
|
|
|
|
{
|
|
|
|
PPARTENTRY PartEntry;
|
|
|
|
// PCWSTR NtPathPartition;
|
|
|
|
NTSTATUS ErrorStatus;
|
|
|
|
|
|
|
|
/* Input information given by the 'FSVOLNOTIFY_STARTCHECK' step ****/
|
|
|
|
BOOLEAN FixErrors;
|
|
|
|
BOOLEAN Verbose;
|
|
|
|
BOOLEAN CheckOnlyIfDirty;
|
|
|
|
BOOLEAN ScanDrive;
|
|
|
|
PFMIFSCALLBACK Callback;
|
|
|
|
|
|
|
|
} CHECK_VOLUME_INFO, *PCHECK_VOLUME_INFO;
|
|
|
|
|
|
|
|
typedef FSVOL_OP
|
|
|
|
(CALLBACK *PFSVOL_CALLBACK)(
|
|
|
|
_In_opt_ PVOID Context,
|
|
|
|
_In_ FSVOLNOTIFY FormatStatus,
|
|
|
|
_In_ ULONG_PTR Param1,
|
|
|
|
_In_ ULONG_PTR Param2);
|
|
|
|
|
|
|
|
BOOLEAN
|
|
|
|
FsVolCommitOpsQueue(
|
|
|
|
_In_ PPARTLIST PartitionList,
|
|
|
|
_In_ PPARTENTRY SystemPartition,
|
|
|
|
_In_ PPARTENTRY InstallPartition,
|
|
|
|
_In_opt_ PFSVOL_CALLBACK FsVolCallback,
|
|
|
|
_In_opt_ PVOID Context);
|
2017-05-17 23:31:52 +00:00
|
|
|
|
[SETUPLIB][USETUP] Introduce a 'SetupLib' library. CORE-13544
- Create the beginnings of a "setuplib" library, whose aim is to be shared between the (currently existing) 1st-stage text-mode installer, and the (future) 1st-stage GUI installer.
- Finish to split the GenList and PartList codes into their UI part, which remain in usetup, and their algorithmic part, which go into setuplib.
- Move SetMountedDeviceValue into the PartList module.
- Split the FileSystem list code into its UI and the algorithmic part (which goes into setuplib under the name fsutil.c).
* The algo part is meant to be able to manage the filesystems available on the running system, similarly to what is mostly done (in scattered form) in fmifs, format, chkdsk / autochk codes...
It also manages the partition filesystem recognition, using OS routines.
* The UI part manages the FS list as it appears on screen, showing only the possible FSes that can be used to format the selected partition (a bit similar to what we do in the shell32's drive.c, etc...).
- Adapt the calling code to these changes.
- Remove some "host" code that was dating back from the dark old times.
svn path=/branches/setup_improvements/; revision=74570
svn path=/branches/setup_improvements/; revision=74659
2017-05-17 23:37:41 +00:00
|
|
|
/* EOF */
|