function uefi_windows_menu_func {
vt_windows_reset
- if [ "$ventoy_compatible" = "NO" ]; then
-
+ unset vt_cur_wimboot_mode
+ if vt_check_mode 4 "$vt_chosen_name"; then
+ set vt_cur_wimboot_mode=1
+ fi
+
+ if [ "$ventoy_compatible" = "NO" -o "$vt_cur_wimboot_mode" = "1" ]; then
if [ "$ventoy_fs_probe" = "iso9660" ]; then
loopback -d loop
vt_iso9660_nojoliet 1
ventoy_debug_pause
locate_wim "${chosen_path}"
fi
-
+
vt_windows_chain_data "${1}${chosen_path}"
ventoy_debug_pause
-
- if vt_check_mode 4 "$vt_chosen_name"; then
- vtoy_windows_wimboot_func
+
+ if [ "$vt_cur_wimboot_mode" = "1" ]; then
+ vtoy_wimboot_func
fi
-
+
if [ -n "$vtoy_chain_mem_addr" ]; then
ventoy_acpi_param ${vtoy_chain_mem_addr} 2048
ventoy_cli_console
unset vtGrub2Mode
if vt_check_mode 3 "$vt_chosen_name"; then
set vtGrub2Mode=1
+ elif vt_str_begin "$vt_volume_id" "HOLO_"; then
+ if [ -d (loop)/loader/entries ]; then
+ set vtGrub2Mode=1
+ fi
elif vt_str_begin "$vt_volume_id" "KRD"; then
if [ -f (loop)/boot/grub/grub.cfg.sig ]; then
set vtGrub2Mode=1
break
fi
done
+ if [ $vtback_cfg_find -eq 0 ]; then
+ if [ -f (loop)/loader/loader.conf -a -d (loop)/loader/entries ]; then
+ if vt_str_begin "$vt_volume_id" "HOLO_"; then
+ set root=(loop,2)
+ vt_systemd_menu (loop,2) vt_sys_menu_mem
+ else
+ vt_systemd_menu (loop) vt_sys_menu_mem
+ fi
+ set vtback_cfg_find=1
+ configfile "mem:${vt_sys_menu_mem_addr}:size:${vt_sys_menu_mem_size}"
+ fi
+ fi
if [ "$vtback_cfg_find" = "0" ]; then
echo " "
vt_check_compatible (loop)
fi
+ if vt_need_secondary_menu "$vt_chosen_name"; then
+ vt_show_secondary_menu "$vt_chosen_path" "$vtoy_os" $vt_chosen_size
+ if vt_check_mode 0 "$vt_chosen_name"; then
+ uefi_iso_memdisk $vtoy_iso_part "$vt_chosen_path"
+ vt_secondary_recover_mode
+ return
+ fi
+ fi
+
vt_img_sector "${1}${chosen_path}"
if [ "$ventoy_fs_probe" = "iso9660" ]; then
fi
ventoy_gui_console
+ vt_secondary_recover_mode
}
function uefi_iso_memdisk {
ventoy_gui_console
}
-
-function vtoy_windows_wimboot_func {
+function vtoy_windows_wimboot {
if [ -f (loop)/x86/sources/boot.wim -a -f (loop)/x64/sources/boot.wim ]; then
vt_sel_wimboot vtoy_wimboot_bit
if [ "$vtoy_wimboot_bit" = "32" ]; then
fi
if [ -n "${vtdebug_flag}" ]; then
- echo vtoy_wimboot_prefix=$vtoy_wimboot_prefix vtoy_wimboot_bit=$vtoy_wimboot_bit
+ echo vtoy_wimboot_prefix=$vtoy_wimboot_prefix vtoy_wimboot_bit=$vtoy_wimboot_bit vt_wimkernel=$vt_wimkernel
fi
- for wmfile in sources/boot.wim boot/bcd boot/boot.sdi; do
- if [ ! -f $vtoy_wimboot_prefix/$wmfile ]; then
- return
- fi
- done
-
- if [ -f $vtoy_wimboot_prefix/sources/install.wim -o -f $vtoy_wimboot_prefix/sources/install.esd ]; then
- vt_windows_wimboot_data
- else
- return
- fi
+ vt_windows_wimboot_data "$vtoy_wimboot_prefix/sources/boot.wim" vtoy_init_exe vtoy_wim_bit
if [ "$grub_platform" = "pc" ]; then
- set vt_wimkernel=wimboot.x86_64.xz
-
linux16 "$vtoy_path/$vt_wimkernel" quiet
ventoy_debug_pause
vt_set_wim_load_prompt 1 "Loading files......"
- initrd16 newc:vtoyjump.exe:$vtoy_path/vtoyjump${vtoy_wimboot_bit}.exe \
- newc:wimboot.data:mem:${vtoy_wimboot_mem_addr}:size:${vtoy_wimboot_mem_size} \
- newc:winpeshl.ini:mem:${vtoy_winpeshl_ini_addr}:size:${vtoy_winpeshl_ini_size} \
+ initrd16 newc:winpeshl.exe:mem:${vtoy_wimboot_mem_addr}:size:${vtoy_wimboot_mem_size} \
+ newc:vtoy_wimboot:$vtoy_wimboot_prefix/boot/bcd \
newc:bcd:$vtoy_wimboot_prefix/boot/bcd \
newc:boot.sdi:$vtoy_wimboot_prefix/boot/boot.sdi \
newc:boot.wim:$vtoy_wimboot_prefix/sources/boot.wim
vt_set_wim_load_prompt 0
boot
else
- if [ "$grub_cpu" = "i386" ]; then
- set vt_wimkernel=wimboot.i386.efi.xz
- else
- set vt_wimkernel=wimboot.x86_64.xz
- fi
-
vt_set_wim_load_prompt 1 "Loading files......"
vt_load_file_to_mem "nodecompress" $vtoy_wimboot_prefix/sources/boot.wim vtoy_wimfile_mem
vt_set_wim_load_prompt 0
ventoy_cli_console
chainloader "$vtoy_path/$vt_wimkernel" quiet \
- "vf=wimboot.data:mem:${vtoy_wimboot_mem_addr}:size:${vtoy_wimboot_mem_size}" \
- "vf=winpeshl.ini:mem:${vtoy_winpeshl_ini_addr}:size:${vtoy_winpeshl_ini_size}" \
- "vf=vtoyjump.exe:$vtoy_path/vtoyjump${vtoy_wimboot_bit}.exe" \
+ "vf=winpeshl.exe:mem:${vtoy_wimboot_mem_addr}:size:${vtoy_wimboot_mem_size}" \
+ "vf=vtoy_wimboot:$vtoy_wimboot_prefix/boot/bcd" \
"vf=bcd:$vtoy_wimboot_prefix/boot/bcd" \
"vf=boot.sdi:$vtoy_wimboot_prefix/boot/boot.sdi" \
"vf=boot.wim:$vtoy_wimfile_path" \
fi
}
+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
+}
+
function legacy_windows_menu_func {
vt_windows_reset
- if [ "$ventoy_compatible" = "NO" ]; then
-
+ unset vt_cur_wimboot_mode
+ if vt_check_mode 4 "$vt_chosen_name"; then
+ set vt_cur_wimboot_mode=1
+ fi
+
+ if [ "$ventoy_compatible" = "NO" -o "$vt_cur_wimboot_mode" = "1" ]; then
if [ "$ventoy_fs_probe" = "iso9660" ]; then
loopback -d loop
vt_iso9660_nojoliet 1
distro_specify_wim_patch_phase2
fi
- ventoy_debug_pause
- locate_wim "${chosen_path}"
+ ventoy_debug_pause
+ if [ -z "$vt_cur_wimboot_mode" ]; then
+ locate_wim "${chosen_path}"
+ fi
fi
-
+
vt_windows_chain_data "${1}${chosen_path}"
- ventoy_debug_pause
-
- if vt_check_mode 4 "$vt_chosen_name"; then
- vtoy_windows_wimboot_func
+ ventoy_debug_pause
+
+ if [ "$vt_cur_wimboot_mode" = "1" ]; then
+ vtoy_wimboot_func
fi
if [ -n "$vtoy_chain_mem_addr" ]; then
ventoy_debug_pause
if [ -n "$vtoy_chain_mem_addr" ]; then
+ unset vtGrub2Mode
if vt_check_mode 3 "$vt_chosen_name"; then
+ set vtGrub2Mode=1
+ elif vt_str_begin "$vt_volume_id" "HOLO_"; then
+ if [ -d (loop)/loader/entries ]; then
+ set vtGrub2Mode=1
+ fi
+ fi
+
+ if [ -n "$vtGrub2Mode" ]; then
ventoy_acpi_param ${vtoy_chain_mem_addr} 2048
ventoy_cli_console
-
+
# fallback
set vtback_root=$root
vt_push_last_entry
break
fi
done
+ if [ $vtback_cfg_find -eq 0 ]; then
+ if [ -f (loop)/loader/loader.conf -a -d (loop)/loader/entries ]; then
+ if vt_str_begin "$vt_volume_id" "HOLO_"; then
+ set root=(loop,2)
+ vt_systemd_menu (loop,2) vt_sys_menu_mem
+ else
+ vt_systemd_menu (loop) vt_sys_menu_mem
+ fi
+ set vtback_cfg_find=1
+ configfile "mem:${vt_sys_menu_mem_addr}:size:${vt_sys_menu_mem_size}"
+ fi
+ fi
vt_unset_boot_opt
set root=$vtback_root
vt_check_compatible (loop)
fi
+ if vt_need_secondary_menu "$vt_chosen_name"; then
+ vt_show_secondary_menu "$vt_chosen_path" "$vtoy_os" $vt_chosen_size
+ if vt_check_mode 0 "$vt_chosen_name"; then
+ legacy_iso_memdisk $vtoy_iso_part "$vt_chosen_path"
+ vt_secondary_recover_mode
+ return
+ fi
+ fi
+
vt_img_sector "${1}${chosen_path}"
if [ "$ventoy_fs_probe" = "iso9660" ]; then
vt_check_compatible_linux (loop)
legacy_linux_menu_func "$1" "${chosen_path}"
fi
+ vt_secondary_recover_mode
}
function legacy_iso_memdisk {
loopback -d easysfs
}
+function ventoy_img_easyos2 {
+ vt_load_cpio $vtoy_path "${vt_chosen_path}" ${vtoy_iso_part} "busybox=$ventoy_busybox_ver"
+ vt_trailer_cpio ${vtoy_iso_part} "${vt_chosen_path}" noinit
+
+ if [ -e (vtimghd,2)/easyos/easy.sfs ]; then
+ loopback easysfs (vtimghd,2)/easyos/easy.sfs
+ elif [ -d (vtimghd,2)/easyos/releases ]; then
+ vt_fs_enum_1st_dir (vtimghd,2) /easyos/releases/ vt_dir_name
+ loopback easysfs (vtimghd,2)/easyos/releases/$vt_dir_name/easy.sfs
+ fi
+
+ vt_get_lib_module_ver (easysfs) /lib/modules/ vt_module_ver
+
+ if [ -n "$vt_module_ver" ]; then
+ for mod in "kernel/drivers/md/dm-mod.ko" "kernel/drivers/dax/dax.ko"; do
+ if [ -e (easysfs)/lib/modules/$vt_module_ver/$mod ]; then
+ vt_img_extra_initrd_append (easysfs)/lib/modules/$vt_module_ver/$mod
+ fi
+ done
+ fi
+
+ ventoy_debug_pause
+
+ #boot image file
+ vt_set_boot_opt rdinit=/vtoy/vtoy
+ vt_img_hook_root
+
+ vt_limine_menu (vtimghd,1)/limine.cfg vt_sys_menu_mem
+ configfile "mem:${vt_sys_menu_mem_addr}:size:${vt_sys_menu_mem_size}"
+
+ vt_img_unhook_root
+ vt_unset_boot_opt
+ loopback -d easysfs
+}
+
function ventoy_img_volumio {
vt_load_cpio $vtoy_path "${vt_chosen_path}" ${vtoy_iso_part} "busybox=$ventoy_busybox_ver"
vt_trailer_cpio ${vtoy_iso_part} "${vt_chosen_path}" noinit
ventoy_img_esysrescue
elif [ -e (vtimghd,1)/easy.sfs ]; then
ventoy_img_easyos
+ elif [ -d (vtimghd,2)/easyos ]; then
+ ventoy_img_easyos2
elif [ -e (vtimghd,1)/volumio.initrd ]; then
ventoy_img_volumio
elif [ -f (vtimghd,2)/loader/entries/ubos.conf ]; then
#############################################################
#############################################################
-set VENTOY_VERSION="1.0.79"
+set VENTOY_VERSION="1.0.81"
#ACPI not compatible with Window7/8, so disable by default
set VTOY_PARAM_NO_ACPI=1
done
loadfont ascii
+ if [ -n "$vtoy_efi_part" ]; then
+ vt_load_file_to_mem "auto" $vtoy_efi_part/grub/fonts/unicode.pf2 vtoy_font_mem
+ loadfont mem:${vtoy_font_mem_addr}:size:${vtoy_font_mem_size}
+ fi
+
if [ -f $vtoy_iso_part/ventoy/ventoy.json ]; then
set vt_plugin_path=$vtoy_iso_part
else
export VTOY_CHKSUM_CMD
export VTOY_HELP_TXT_LANGUAGE
export VTOY_CHKSUM_FILE_PATH
+export VTOY_HOTKEY_TIP
#colect all image files (iso files)