X-Git-Url: https://glassweightruler.freedombox.rocks/gitweb/Ventoy.git/blobdiff_plain/cd4a5fcb0685b8a12915d22efc5c1e0cc8b40d9b..d5b829f8e8c8367b032b4bb57a8fc37701d42e17:/INSTALL/grub/grub.cfg diff --git a/INSTALL/grub/grub.cfg b/INSTALL/grub/grub.cfg index 9265704..d9a59fa 100644 --- a/INSTALL/grub/grub.cfg +++ b/INSTALL/grub/grub.cfg @@ -74,6 +74,20 @@ function distro_specify_initrd_file { vt_linux_specify_initrd_file /pmagic/initrd.img elif [ -e (loop)/boot/initrd.xz ]; then vt_linux_specify_initrd_file /boot/initrd.xz + elif [ -f (loop)/boot/initrd ]; then + vt_linux_specify_initrd_file /boot/initrd + elif [ -f (loop)/boot/x86_64/loader/initrd ]; then + vt_linux_specify_initrd_file /boot/x86_64/loader/initrd + elif [ -f (loop)/boot/initramfs-x86_64.img ]; then + vt_linux_specify_initrd_file /boot/initramfs-x86_64.img + + + fi +} + +function distro_specify_initrd_file_phase2 { + if [ -f (loop)/boot/initrd.img ]; then + vt_linux_specify_initrd_file /boot/initrd.img fi } @@ -127,8 +141,24 @@ function uefi_linux_menu_func { vt_linux_parse_initrd_grub dir (loop)/boot/grub/ fi + if [ -e (loop)/syslinux/alt0/full.cz ]; then + set LoadIsoEfiDriver=on + set FirstTryBootFile='@EFI@BOOT@grubx64.efi' + fi + distro_specify_initrd_file + vt_linux_initrd_count vtcount + if [ $vtcount -eq 0 ]; then + distro_specify_initrd_file_phase2 + + if [ "$vt_efi_dir" = "NO" ]; then + if [ -f (loop)/efi.img ]; then + vt_add_replace_file 0 "initrd" + fi + fi + fi + locate_initrd fi @@ -136,7 +166,7 @@ function uefi_linux_menu_func { if [ -n "$vtoy_chain_mem_addr" ]; then terminal_output console - chainloader ${vtoy_path}/ventoy_x64.efi env_param=${env_param} isoefi=${LoadIsoEfiDriver} ${vtdebug_flag} mem:${vtoy_chain_mem_addr}:size:${vtoy_chain_mem_size} + chainloader ${vtoy_path}/ventoy_x64.efi env_param=${env_param} isoefi=${LoadIsoEfiDriver} FirstTry=${FirstTryBootFile} ${vtdebug_flag} mem:${vtoy_chain_mem_addr}:size:${vtoy_chain_mem_size} boot else echo "chain empty failed" @@ -171,6 +201,14 @@ function uefi_iso_menu_func { loopback loop ${1}${chosen_path} get_os_type (loop) + if [ -d (loop)/EFI ]; then + set vt_efi_dir=YES + elif [ -d (loop)/efi ]; then + set vt_efi_dir=YES + else + set vt_efi_dir=NO + fi + if [ -n "$vtcompat" ]; then set ventoy_compatible=YES unset vtcompat @@ -185,6 +223,8 @@ function uefi_iso_menu_func { if [ "$vtoy_os" = "Windows" ]; then if [ "$ventoy_fs_probe" = "iso9660" ]; then set ventoy_compatible=YES + elif [ -f (loop)/HBCD_PE.ini ]; then + set ventoy_compatible=YES fi uefi_windows_menu_func $1 @@ -209,7 +249,6 @@ function uefi_iso_memdisk { - function legacy_windows_menu_func { vt_windows_reset @@ -272,6 +311,11 @@ function legacy_linux_menu_func { distro_specify_initrd_file + vt_linux_initrd_count vtcount + if [ $vtcount -eq 0 ]; then + distro_specify_initrd_file_phase2 + fi + locate_initrd fi @@ -323,7 +367,10 @@ function legacy_iso_menu_func { if [ "$vtoy_os" = "Windows" ]; then if [ "$ventoy_fs_probe" = "iso9660" ]; then set ventoy_compatible=YES + elif [ -f (loop)/HBCD_PE.ini ]; then + set ventoy_compatible=YES fi + legacy_windows_menu_func $1 else legacy_linux_menu_func $1 @@ -348,7 +395,7 @@ function legacy_iso_memdisk { ############################################################# ############################################################# -set VENTOY_VERSION="1.0.05" +set VENTOY_VERSION="1.0.07" #disable timeout unset timeout @@ -378,7 +425,11 @@ if [ -f $iso_path/ventoy/ventoy.json ]; then vt_load_plugin $iso_path fi -terminal_output gfxterm +if [ -n "$vtoy_gfxmode" ]; then + set gfxmode=$vtoy_gfxmode +else + set gfxmode=1920x1080,1366x768,1024x768 +fi if [ -n "$vtoy_theme" ]; then set theme=$vtoy_theme @@ -386,11 +437,7 @@ else set theme=$prefix/themes/ventoy/theme.txt fi -if [ -n "$vtoy_gfxmode" ]; then - set gfxmode=$vtoy_gfxmode -else - set gfxmode=1024x768 -fi +terminal_output gfxterm #colect all image files (iso files) set ventoy_img_count=0