+function vtoy_winpe_wimboot {
+ unset vtoy_boot_sdi_legacy
+ unset vtoy_boot_sdi_efi
+
+ set vtoy_wimboot_prefix=(loop)
+ set vtoy_wim_path="$1"
+
+ if [ -n "${vtdebug_flag}" ]; then
+ echo "winpe_wimboot $1 $2 $3"
+ fi
+
+ if [ "$2" != "0" ]; then
+ set vtoy_boot_sdi_legacy="newc:boot.sdi:$vtoy_wimboot_prefix/$2"
+ set vtoy_boot_sdi_efi="vf=boot.sdi:$vtoy_wimboot_prefix/$2"
+ fi
+
+ vt_windows_wimboot_data $vtoy_wimboot_prefix/$vtoy_wim_path vtoy_init_exe vtoy_wim_bit
+
+ if [ "$grub_platform" = "pc" ]; then
+ linux16 "$vtoy_path/$vt_wimkernel" quiet
+ ventoy_debug_pause
+
+ vt_set_wim_load_prompt 1 "Loading files......"
+ initrd16 newc:$vtoy_init_exe:mem:${vtoy_wimboot_mem_addr}:size:${vtoy_wimboot_mem_size} \
+ newc:vtoy_wimboot:$vtoy_path/$vt_wimkernel \
+ newc:bootmgr.exe:mem:${vtoy_pe_bootmgr_mem_addr}:size:${vtoy_pe_bootmgr_mem_size} \
+ newc:bcd:mem:${vtoy_pe_bcd_mem_addr}:size:${vtoy_pe_bcd_mem_size} \
+ $vtoy_boot_sdi_legacy \
+ newc:boot.wim:$vtoy_wimboot_prefix/$vtoy_wim_path
+ vt_set_wim_load_prompt 0
+ boot
+ else
+ if [ "$VTOY_EFI_ARCH" = "x64" -a "$vtoy_wim_bit" = "32" ]; then
+ echo -e "\nThis is 32bit Windows and does NOT support x86_64 UEFI firmware.\n"
+ echo -e "这是32位的 Windows 系统,不支持当前的64位 UEFI 环境。\n"
+ fi
+
+ vt_set_wim_load_prompt 1 "Loading files......"
+ vt_load_file_to_mem "nodecompress" $vtoy_wimboot_prefix/$vtoy_wim_path vtoy_wimfile_mem
+ vt_set_wim_load_prompt 0
+
+ if [ $? -eq 0 ]; then
+ set vtoy_wimfile_path=mem:${vtoy_wimfile_mem_addr}:size:${vtoy_wimfile_mem_size}
+ else
+ set vtoy_wimfile_path=$vtoy_wimboot_prefix/$vtoy_wim_path
+ fi
+
+ unset vtoy_boot_efi_path
+ if [ -F (loop)/efi/boot/boot${VTOY_EFI_ARCH}.efi ]; then
+ set vtoy_boot_efi_path="vf=bootx64.efi:(loop)/efi/boot/boot${VTOY_EFI_ARCH}.efi"
+ fi
+
+ ventoy_cli_console
+ chainloader "$vtoy_path/$vt_wimkernel" quiet \
+ "vf=$vtoy_init_exe:mem:${vtoy_wimboot_mem_addr}:size:${vtoy_wimboot_mem_size}" \
+ "vf=vtoy_wimboot:$vtoy_path/$vt_wimkernel" \
+ "vf=bcd:mem:${vtoy_pe_bcd_mem_addr}:size:${vtoy_pe_bcd_mem_size}" \
+ "$vtoy_boot_sdi_efi" \
+ "$vtoy_boot_efi_path" \
+ "vf=boot.wim:$vtoy_wimfile_path" \
+ pfsize=$vtoy_chain_file_size \
+ pfread=$vtoy_chain_file_read
+ boot
+ ventoy_gui_console
+ fi
+}
+
+function vtoy_wimboot_func {
+ if [ "$grub_platform" = "pc" ]; then
+ set vt_wimkernel=wimboot.x86_64.xz
+ else
+ if [ "$grub_cpu" = "i386" ]; then
+ set vt_wimkernel=wimboot.i386.efi.xz
+ else
+ set vt_wimkernel=wimboot.x86_64.xz
+ fi
+ fi
+
+ if vt_is_standard_winiso (loop); then
+ echo -e "\n==================== VENTOY WIMBOOT ==================\n"
+ vtoy_windows_wimboot
+ else
+ vt_sel_winpe_wim (loop)
+ if [ -n "$vtoy_pe_wim_path" ]; then
+ echo -e "\n==================== VENTOY WIMBOOT ==================\n"
+
+ vt_fs_ignore_case 1
+ vt_load_file_to_mem "auto" $vtoy_path/common_bcd.xz vtoy_pe_bcd_mem
+
+ set vt_sdi_path=0
+ for vsdi in "boot/boot.sdi" "2K10/FONTS/boot.sdi" "SSTR/boot.sdi" "ISPE/BOOT.SDI" \
+ "boot/uqi.sdi" "ISYL/boot.sdi" "WEPE/WEPE.SDI" ; do
+ if [ -F "(loop)/$vsdi" ]; then
+ set vt_sdi_path=$vsdi
+ break
+ fi
+ done
+
+ if [ "$grub_platform" = "pc" ]; then
+ vt_load_file_to_mem "auto" $vtoy_path/common_bootmgr.xz vtoy_pe_bootmgr_mem
+ vtoy_winpe_wimboot "$vtoy_pe_wim_path" "$vt_sdi_path" 1
+ else
+ vtoy_winpe_wimboot "$vtoy_pe_wim_path" "$vt_sdi_path" 0
+ fi
+
+ vt_fs_ignore_case 0
+ fi
+ fi
+}
+