mirror of
https://github.com/pbatard/rufus.git
synced 2025-05-25 12:14:33 -04:00
[ui] add option to set internal drives offline for Windows 11 To Go
* This is enabled by default for Windows 11 images and is done to prevent the annoying behaviour of Windows 11 *automatically* upgrading all ReFS drives it sees to latest version, thereby instantly preventing you from accessing these drives ever again with Windows 10. * See: https://gist.github.com/0xbadfca11/da0598e47dd643d933dc#Mountability.
This commit is contained in:
parent
a25af06b3c
commit
e043a49fa7
5 changed files with 47 additions and 10 deletions
|
@ -6,6 +6,8 @@ https://github.com/pbatard/rufus/wiki/Localization#Editing_an_existing_translati
|
||||||
Or simply download https://rufus-web.akeo.ie/locale/pollock.exe and follow its directions.
|
Or simply download https://rufus-web.akeo.ie/locale/pollock.exe and follow its directions.
|
||||||
|
|
||||||
o v3.20 (2022.??.??)
|
o v3.20 (2022.??.??)
|
||||||
|
IMPORTANT: The translation changes below are *NOT* finalized and may evolve further...
|
||||||
|
Please avoid sending a translation update before I send a request for it, thank you!
|
||||||
- *NEW* MSG_323 "Unable to open or read '%s'"
|
- *NEW* MSG_323 "Unable to open or read '%s'"
|
||||||
- *NEW* MSG_325 "Applying Windows customization: %s"
|
- *NEW* MSG_325 "Applying Windows customization: %s"
|
||||||
- *NEW* MSG_326 "Windows User Experience"
|
- *NEW* MSG_326 "Windows User Experience"
|
||||||
|
@ -14,6 +16,7 @@ o v3.20 (2022.??.??)
|
||||||
- *NEW* MSG_329 "Remove requirement for 4GB+ RAM and 64GB+ disk"
|
- *NEW* MSG_329 "Remove requirement for 4GB+ RAM and 64GB+ disk"
|
||||||
- *NEW* MSG_330 "Remove requirement for an online Microsoft account"
|
- *NEW* MSG_330 "Remove requirement for an online Microsoft account"
|
||||||
- *NEW* MSG_331 "Disable data collection (Skip privacy questions)"
|
- *NEW* MSG_331 "Disable data collection (Skip privacy questions)"
|
||||||
|
- *NEW* MSG_332 "Prevent Windows To Go from accessing internal disks"
|
||||||
|
|
||||||
o v3.14 (2021.03.31)
|
o v3.14 (2021.03.31)
|
||||||
- *UPDATED* MSG_068 "Error while partitioning drive." -> "Could not partition drive."
|
- *UPDATED* MSG_068 "Error while partitioning drive." -> "Could not partition drive."
|
||||||
|
|
|
@ -589,6 +589,7 @@ t MSG_328 "Remove requirement for Secure Boot and TPM 2.0"
|
||||||
t MSG_329 "Remove requirement for 4GB+ RAM and 64GB+ disk"
|
t MSG_329 "Remove requirement for 4GB+ RAM and 64GB+ disk"
|
||||||
t MSG_330 "Remove requirement for an online Microsoft account"
|
t MSG_330 "Remove requirement for an online Microsoft account"
|
||||||
t MSG_331 "Disable data collection (Skip privacy questions)"
|
t MSG_331 "Disable data collection (Skip privacy questions)"
|
||||||
|
t MSG_332 "Prevent Windows To Go from accessing internal disks"
|
||||||
|
|
||||||
#########################################################################
|
#########################################################################
|
||||||
l "ar-SA" "Arabic (العربية)" 0x0401, 0x0801, 0x0c01, 0x1001, 0x1401, 0x1801, 0x1c01, 0x2001, 0x2401, 0x2801, 0x2c01, 0x3001, 0x3401, 0x3801, 0x3c01, 0x4001
|
l "ar-SA" "Arabic (العربية)" 0x0401, 0x0801, 0x0c01, 0x1001, 0x1401, 0x1801, 0x1c01, 0x2001, 0x2401, 0x2801, 0x2c01, 0x3001, 0x3401, 0x3801, 0x3c01, 0x4001
|
||||||
|
|
15
src/format.c
15
src/format.c
|
@ -72,7 +72,7 @@ extern uint32_t dur_mins, dur_secs;
|
||||||
extern uint32_t wim_nb_files, wim_proc_files, wim_extra_files;
|
extern uint32_t wim_nb_files, wim_proc_files, wim_extra_files;
|
||||||
static int actual_fs_type, wintogo_index = -1, wininst_index = 0;
|
static int actual_fs_type, wintogo_index = -1, wininst_index = 0;
|
||||||
extern BOOL force_large_fat32, enable_ntfs_compression, lock_drive, zero_drive, fast_zeroing, enable_file_indexing;
|
extern BOOL force_large_fat32, enable_ntfs_compression, lock_drive, zero_drive, fast_zeroing, enable_file_indexing;
|
||||||
extern BOOL write_as_image, use_vds, write_as_esp, is_vds_available, enable_inplace;
|
extern BOOL write_as_image, use_vds, write_as_esp, is_vds_available, enable_inplace, set_drives_offline;
|
||||||
extern const grub_patch_t grub_patch[2];
|
extern const grub_patch_t grub_patch[2];
|
||||||
extern char* unattend_xml_path;
|
extern char* unattend_xml_path;
|
||||||
uint8_t *grub2_buf = NULL, *sec_buf = NULL;
|
uint8_t *grub2_buf = NULL, *sec_buf = NULL;
|
||||||
|
@ -1465,6 +1465,19 @@ static BOOL SetupWinToGo(DWORD DriveIndex, const char* drive_name, BOOL use_esp)
|
||||||
|
|
||||||
UpdateProgressWithInfo(OP_FILE_COPY, MSG_267, wim_proc_files + 2 * wim_extra_files, wim_nb_files);
|
UpdateProgressWithInfo(OP_FILE_COPY, MSG_267, wim_proc_files + 2 * wim_extra_files, wim_nb_files);
|
||||||
|
|
||||||
|
// Setting internal drives offline for Windows To Go is crucial if, for instance, you are using ReFS
|
||||||
|
// on Windows 10 (therefore ReFS v3.4) and don't want a Windows 11 To Go boot to automatically
|
||||||
|
// "upgrade" the ReFS version on all drives to v3.7, thereby preventing you from being able to mount
|
||||||
|
// those volumes back on Windows 10 ever again. Yes, I have been stung by this Microsoft bullshit!
|
||||||
|
// See: https://gist.github.com/0xbadfca11/da0598e47dd643d933dc#Mountability
|
||||||
|
if (set_drives_offline) {
|
||||||
|
uprintf("Setting the target's internal drives offline using command:");
|
||||||
|
// This applies the "offlineServicing" section of the unattend.xml (while ignoring the other sections)
|
||||||
|
static_sprintf(cmd, "dism /Image:%s\\ /Apply-Unattend:%s", drive_name, unattend_xml_path);
|
||||||
|
uprintf(cmd);
|
||||||
|
RunCommand(cmd, NULL, usb_debug);
|
||||||
|
}
|
||||||
|
|
||||||
uprintf("Disabling use of the Windows Recovery Environment using command:");
|
uprintf("Disabling use of the Windows Recovery Environment using command:");
|
||||||
static_sprintf(cmd, "%s\\bcdedit.exe /store %s\\EFI\\Microsoft\\Boot\\BCD /set {default} recoveryenabled no",
|
static_sprintf(cmd, "%s\\bcdedit.exe /store %s\\EFI\\Microsoft\\Boot\\BCD /set {default} recoveryenabled no",
|
||||||
sysnative_dir, (use_esp) ? ms_efi : drive_name);
|
sysnative_dir, (use_esp) ? ms_efi : drive_name);
|
||||||
|
|
28
src/rufus.c
28
src/rufus.c
|
@ -64,10 +64,12 @@ enum bootcheck_return {
|
||||||
#define UNATTEND_MINRAM_MINDISK_MASK 0x02
|
#define UNATTEND_MINRAM_MINDISK_MASK 0x02
|
||||||
#define UNATTEND_NO_ONLINE_ACCOUNT_MASK 0x04
|
#define UNATTEND_NO_ONLINE_ACCOUNT_MASK 0x04
|
||||||
#define UNATTEND_NO_DATA_COLLECTION_MASK 0x08
|
#define UNATTEND_NO_DATA_COLLECTION_MASK 0x08
|
||||||
|
#define UNATTEND_OFFLINE_INTERNAL_DRIVES 0x10
|
||||||
|
|
||||||
#define UNATTEND_WINPE_SETUP_MASK (UNATTEND_SECUREBOOT_TPM_MASK | UNATTEND_MINRAM_MINDISK_MASK)
|
#define UNATTEND_WINPE_SETUP_MASK (UNATTEND_SECUREBOOT_TPM_MASK | UNATTEND_MINRAM_MINDISK_MASK)
|
||||||
#define UNATTEND_SPECIALIZE_DEPLOYMENT_MASK (UNATTEND_NO_ONLINE_ACCOUNT_MASK)
|
#define UNATTEND_SPECIALIZE_DEPLOYMENT_MASK (UNATTEND_NO_ONLINE_ACCOUNT_MASK)
|
||||||
#define UNATTEND_OOBE_SHELL_SETUP (UNATTEND_NO_DATA_COLLECTION_MASK)
|
#define UNATTEND_OOBE_SHELL_SETUP (UNATTEND_NO_DATA_COLLECTION_MASK)
|
||||||
|
#define UNATTEND_OFFLINE_SERVICING (UNATTEND_OFFLINE_INTERNAL_DRIVES)
|
||||||
|
|
||||||
static const char* cmdline_hogger = "rufus.com";
|
static const char* cmdline_hogger = "rufus.com";
|
||||||
static const char* ep_reg = "Software\\Microsoft\\Windows\\CurrentVersion\\Policies\\Explorer";
|
static const char* ep_reg = "Software\\Microsoft\\Windows\\CurrentVersion\\Policies\\Explorer";
|
||||||
|
@ -88,7 +90,8 @@ static BOOL allowed_filesystem[FS_MAX] = { 0 };
|
||||||
static int64_t last_iso_blocking_status;
|
static int64_t last_iso_blocking_status;
|
||||||
static int selected_pt = -1, selected_fs = FS_UNKNOWN, preselected_fs = FS_UNKNOWN;
|
static int selected_pt = -1, selected_fs = FS_UNKNOWN, preselected_fs = FS_UNKNOWN;
|
||||||
static int image_index = 0, select_index = 0;
|
static int image_index = 0, select_index = 0;
|
||||||
static int unattend_xml_mask = (UNATTEND_SECUREBOOT_TPM_MASK | UNATTEND_NO_ONLINE_ACCOUNT_MASK);
|
static int unattend_xml_mask = (UNATTEND_SECUREBOOT_TPM_MASK | UNATTEND_NO_ONLINE_ACCOUNT_MASK |
|
||||||
|
UNATTEND_OFFLINE_INTERNAL_DRIVES);
|
||||||
static RECT relaunch_rc = { -65536, -65536, 0, 0};
|
static RECT relaunch_rc = { -65536, -65536, 0, 0};
|
||||||
static UINT uMBRChecked = BST_UNCHECKED;
|
static UINT uMBRChecked = BST_UNCHECKED;
|
||||||
static HANDLE format_thread = NULL;
|
static HANDLE format_thread = NULL;
|
||||||
|
@ -126,13 +129,13 @@ HWND hDeviceList, hPartitionScheme, hTargetSystem, hFileSystem, hClusterSize, hL
|
||||||
HWND hImageOption, hLogDialog = NULL, hProgress = NULL, hDiskID;
|
HWND hImageOption, hLogDialog = NULL, hProgress = NULL, hDiskID;
|
||||||
HANDLE dialog_handle = NULL;
|
HANDLE dialog_handle = NULL;
|
||||||
BOOL is_x86_32, use_own_c32[NB_OLD_C32] = { FALSE, FALSE }, mbr_selected_by_user = FALSE;
|
BOOL is_x86_32, use_own_c32[NB_OLD_C32] = { FALSE, FALSE }, mbr_selected_by_user = FALSE;
|
||||||
BOOL op_in_progress = TRUE, right_to_left_mode = FALSE, has_uefi_csm = FALSE, its_a_me_mario = FALSE, enable_inplace;
|
BOOL op_in_progress = TRUE, right_to_left_mode = FALSE, has_uefi_csm = FALSE, its_a_me_mario = FALSE, enable_inplace = FALSE;
|
||||||
BOOL enable_HDDs = FALSE, enable_VHDs = TRUE, enable_ntfs_compression = FALSE, no_confirmation_on_cancel = FALSE, lock_drive = TRUE;
|
BOOL enable_HDDs = FALSE, enable_VHDs = TRUE, enable_ntfs_compression = FALSE, no_confirmation_on_cancel = FALSE, lock_drive = TRUE;
|
||||||
BOOL advanced_mode_device, advanced_mode_format, allow_dual_uefi_bios, detect_fakes, enable_vmdk, force_large_fat32, usb_debug;
|
BOOL advanced_mode_device, advanced_mode_format, allow_dual_uefi_bios, detect_fakes, enable_vmdk, force_large_fat32, usb_debug;
|
||||||
BOOL use_fake_units, preserve_timestamps = FALSE, fast_zeroing = FALSE, app_changed_size = FALSE;
|
BOOL use_fake_units, preserve_timestamps = FALSE, fast_zeroing = FALSE, app_changed_size = FALSE;
|
||||||
BOOL zero_drive = FALSE, list_non_usb_removable_drives = FALSE, enable_file_indexing, large_drive = FALSE;
|
BOOL zero_drive = FALSE, list_non_usb_removable_drives = FALSE, enable_file_indexing, large_drive = FALSE;
|
||||||
BOOL write_as_image = FALSE, write_as_esp = FALSE, use_vds = FALSE, ignore_boot_marker = FALSE;
|
BOOL write_as_image = FALSE, write_as_esp = FALSE, use_vds = FALSE, ignore_boot_marker = FALSE;
|
||||||
BOOL appstore_version = FALSE, is_vds_available = TRUE;
|
BOOL appstore_version = FALSE, is_vds_available = TRUE, set_drives_offline = FALSE;
|
||||||
float fScale = 1.0f;
|
float fScale = 1.0f;
|
||||||
int dialog_showing = 0, selection_default = BT_IMAGE, persistence_unit_selection = -1, imop_win_sel = 0;
|
int dialog_showing = 0, selection_default = BT_IMAGE, persistence_unit_selection = -1, imop_win_sel = 0;
|
||||||
int default_fs, fs_type, boot_type, partition_type, target_type;
|
int default_fs, fs_type, boot_type, partition_type, target_type;
|
||||||
|
@ -1275,7 +1278,6 @@ static char* CreateUnattendXml(int arch, int mask)
|
||||||
fd = fopen(path, "w");
|
fd = fopen(path, "w");
|
||||||
if (fd == NULL)
|
if (fd == NULL)
|
||||||
return NULL;
|
return NULL;
|
||||||
enable_inplace = mask & UNATTEND_WINPE_SETUP_MASK;
|
|
||||||
|
|
||||||
fprintf(fd, "<?xml version=\"1.0\" encoding=\"utf-8\"?>\n");
|
fprintf(fd, "<?xml version=\"1.0\" encoding=\"utf-8\"?>\n");
|
||||||
fprintf(fd, "<unattend xmlns=\"urn:schemas-microsoft-com:unattend\">\n");
|
fprintf(fd, "<unattend xmlns=\"urn:schemas-microsoft-com:unattend\">\n");
|
||||||
|
@ -1283,6 +1285,7 @@ static char* CreateUnattendXml(int arch, int mask)
|
||||||
// This part produces the unbecoming display of a command prompt window during initial setup, which
|
// This part produces the unbecoming display of a command prompt window during initial setup, which
|
||||||
// may scare users... But the Windows Store version doesn't allow us to edit an offline registry...
|
// may scare users... But the Windows Store version doesn't allow us to edit an offline registry...
|
||||||
if (mask & UNATTEND_WINPE_SETUP_MASK) {
|
if (mask & UNATTEND_WINPE_SETUP_MASK) {
|
||||||
|
enable_inplace = TRUE;
|
||||||
order = 1;
|
order = 1;
|
||||||
fprintf(fd, " <settings pass=\"windowsPE\">\n");
|
fprintf(fd, " <settings pass=\"windowsPE\">\n");
|
||||||
fprintf(fd, " <component name=\"Microsoft-Windows-Setup\" processorArchitecture=\"%s\" language=\"neutral\" "
|
fprintf(fd, " <component name=\"Microsoft-Windows-Setup\" processorArchitecture=\"%s\" language=\"neutral\" "
|
||||||
|
@ -1345,6 +1348,19 @@ static char* CreateUnattendXml(int arch, int mask)
|
||||||
fprintf(fd, " </settings>\n");
|
fprintf(fd, " </settings>\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (mask & UNATTEND_OFFLINE_SERVICING) {
|
||||||
|
fprintf(fd, " <settings pass=\"offlineServicing\">\n");
|
||||||
|
if (mask & UNATTEND_OFFLINE_INTERNAL_DRIVES) {
|
||||||
|
set_drives_offline = TRUE;
|
||||||
|
fprintf(fd, " <component name=\"Microsoft-Windows-PartitionManager\" processorArchitecture=\"%s\" language=\"neutral\" "
|
||||||
|
"xmlns:wcm=\"http://schemas.microsoft.com/WMIConfig/2002/State\" xmlns:xsi=\"http://www.w3.org/2001/XMLSchema-instance\" "
|
||||||
|
"publicKeyToken=\"31bf3856ad364e35\" versionScope=\"nonSxS\">\n", xml_arch_names[arch]);
|
||||||
|
fprintf(fd, " <SanPolicy>4</SanPolicy>\n");
|
||||||
|
fprintf(fd, " </component>\n");
|
||||||
|
}
|
||||||
|
fprintf(fd, " </settings>\n");
|
||||||
|
}
|
||||||
|
|
||||||
fprintf(fd, "</unattend>\n");
|
fprintf(fd, "</unattend>\n");
|
||||||
fclose(fd);
|
fclose(fd);
|
||||||
return path;
|
return path;
|
||||||
|
@ -1609,6 +1625,8 @@ static DWORD WINAPI BootCheckThread(LPVOID param)
|
||||||
}
|
}
|
||||||
StrArrayAdd(&options, lmprintf(MSG_331), TRUE);
|
StrArrayAdd(&options, lmprintf(MSG_331), TRUE);
|
||||||
MAP_BIT(UNATTEND_NO_DATA_COLLECTION_MASK);
|
MAP_BIT(UNATTEND_NO_DATA_COLLECTION_MASK);
|
||||||
|
StrArrayAdd(&options, lmprintf(MSG_332), TRUE);
|
||||||
|
MAP_BIT(UNATTEND_OFFLINE_INTERNAL_DRIVES);
|
||||||
i = SelectionDialog(BS_AUTOCHECKBOX, lmprintf(MSG_326), lmprintf(MSG_327),
|
i = SelectionDialog(BS_AUTOCHECKBOX, lmprintf(MSG_326), lmprintf(MSG_327),
|
||||||
options.String, options.Index, remap8(unattend_xml_mask, map, FALSE));
|
options.String, options.Index, remap8(unattend_xml_mask, map, FALSE));
|
||||||
StrArrayDestroy(&options);
|
StrArrayDestroy(&options);
|
||||||
|
@ -2747,6 +2765,8 @@ static INT_PTR CALLBACK MainCallback(HWND hDlg, UINT message, WPARAM wParam, LPA
|
||||||
fs_type = (int)ComboBox_GetCurItemData(hFileSystem);
|
fs_type = (int)ComboBox_GetCurItemData(hFileSystem);
|
||||||
write_as_image = FALSE;
|
write_as_image = FALSE;
|
||||||
write_as_esp = FALSE;
|
write_as_esp = FALSE;
|
||||||
|
enable_inplace = FALSE;
|
||||||
|
set_drives_offline = FALSE;
|
||||||
// Disable all controls except Cancel
|
// Disable all controls except Cancel
|
||||||
EnableControls(FALSE, FALSE);
|
EnableControls(FALSE, FALSE);
|
||||||
FormatStatus = 0;
|
FormatStatus = 0;
|
||||||
|
|
10
src/rufus.rc
10
src/rufus.rc
|
@ -33,7 +33,7 @@ LANGUAGE LANG_NEUTRAL, SUBLANG_NEUTRAL
|
||||||
IDD_DIALOG DIALOGEX 12, 12, 232, 326
|
IDD_DIALOG DIALOGEX 12, 12, 232, 326
|
||||||
STYLE DS_SETFONT | DS_MODALFRAME | DS_CENTER | WS_MINIMIZEBOX | WS_POPUP | WS_CAPTION | WS_SYSMENU
|
STYLE DS_SETFONT | DS_MODALFRAME | DS_CENTER | WS_MINIMIZEBOX | WS_POPUP | WS_CAPTION | WS_SYSMENU
|
||||||
EXSTYLE WS_EX_ACCEPTFILES
|
EXSTYLE WS_EX_ACCEPTFILES
|
||||||
CAPTION "Rufus 3.19.1904"
|
CAPTION "Rufus 3.19.1905"
|
||||||
FONT 9, "Segoe UI Symbol", 400, 0, 0x0
|
FONT 9, "Segoe UI Symbol", 400, 0, 0x0
|
||||||
BEGIN
|
BEGIN
|
||||||
LTEXT "Drive Properties",IDS_DRIVE_PROPERTIES_TXT,8,6,53,12,NOT WS_GROUP
|
LTEXT "Drive Properties",IDS_DRIVE_PROPERTIES_TXT,8,6,53,12,NOT WS_GROUP
|
||||||
|
@ -395,8 +395,8 @@ END
|
||||||
//
|
//
|
||||||
|
|
||||||
VS_VERSION_INFO VERSIONINFO
|
VS_VERSION_INFO VERSIONINFO
|
||||||
FILEVERSION 3,19,1904,0
|
FILEVERSION 3,19,1905,0
|
||||||
PRODUCTVERSION 3,19,1904,0
|
PRODUCTVERSION 3,19,1905,0
|
||||||
FILEFLAGSMASK 0x3fL
|
FILEFLAGSMASK 0x3fL
|
||||||
#ifdef _DEBUG
|
#ifdef _DEBUG
|
||||||
FILEFLAGS 0x1L
|
FILEFLAGS 0x1L
|
||||||
|
@ -414,13 +414,13 @@ BEGIN
|
||||||
VALUE "Comments", "https://rufus.ie"
|
VALUE "Comments", "https://rufus.ie"
|
||||||
VALUE "CompanyName", "Akeo Consulting"
|
VALUE "CompanyName", "Akeo Consulting"
|
||||||
VALUE "FileDescription", "Rufus"
|
VALUE "FileDescription", "Rufus"
|
||||||
VALUE "FileVersion", "3.19.1904"
|
VALUE "FileVersion", "3.19.1905"
|
||||||
VALUE "InternalName", "Rufus"
|
VALUE "InternalName", "Rufus"
|
||||||
VALUE "LegalCopyright", "© 2011-2022 Pete Batard (GPL v3)"
|
VALUE "LegalCopyright", "© 2011-2022 Pete Batard (GPL v3)"
|
||||||
VALUE "LegalTrademarks", "https://www.gnu.org/licenses/gpl-3.0.html"
|
VALUE "LegalTrademarks", "https://www.gnu.org/licenses/gpl-3.0.html"
|
||||||
VALUE "OriginalFilename", "rufus-3.19.exe"
|
VALUE "OriginalFilename", "rufus-3.19.exe"
|
||||||
VALUE "ProductName", "Rufus"
|
VALUE "ProductName", "Rufus"
|
||||||
VALUE "ProductVersion", "3.19.1904"
|
VALUE "ProductVersion", "3.19.1905"
|
||||||
END
|
END
|
||||||
END
|
END
|
||||||
BLOCK "VarFileInfo"
|
BLOCK "VarFileInfo"
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue