X-Git-Url: https://glassweightruler.freedombox.rocks/gitweb/Ventoy.git/blobdiff_plain/790fa744f85c7dff5fe6f1905cd4268980c60dda..5d0fe69b2592f3c19fd12529ad94cb64ec0ed7d1:/INSTALL/grub/grub.cfg diff --git a/INSTALL/grub/grub.cfg b/INSTALL/grub/grub.cfg index 2a71af3..ab18f8d 100644 --- a/INSTALL/grub/grub.cfg +++ b/INSTALL/grub/grub.cfg @@ -16,9 +16,29 @@ # #************************************************************************************ +function ventoy_power { + echo '<1> Reboot' + echo '<2> Halt' + echo '<0> Return to menu' + echo -e '\nPlease enter your choice:' + + unset vtOpt + read vtOpt + + if [ "$vtOpt" = "1" ]; then + echo -e '\n\nSystem is rebooting ... \n' + sleep 1 + reboot + elif [ "$vtOpt" = "2" ]; then + echo -e '\n\nSystem is halting ... \n' + sleep 1 + halt + fi +} + function get_os_type { set vtoy_os=Linux - for file in "efi/microsoft" "sources/boot.wim" "boot/bcd" "bootmgr.efi" "boot/etfsboot.com"; do + for file in "efi/microsoft" "sources/boot.wim" "boot/bcd" "bootmgr.efi" "boot/etfsboot.com" "BOOT/etfsboot.com"; do if [ -e $1/$file ]; then set vtoy_os=Windows break @@ -30,7 +50,22 @@ function get_os_type { fi } -function locate_initrd { +function vt_check_pe { + unset VT_PE_SUPPORT + + if [ -f $1/HBCD_PE.ini ]; then + set ventoy_compatible=YES + set VT_PE_SUPPORT=YES + elif [ -f $1/easyu.flg ]; then + set VT_PE_SUPPORT=YES + elif [ -f $1/USM.ICO ]; then + set VT_PE_SUPPORT=YES + elif [ -d $1/USM_TOOL ]; then + set VT_PE_SUPPORT=YES + fi +} + +function locate_initrd { vt_linux_locate_initrd if [ -n "${vtdebug_flag}" ]; then @@ -42,7 +77,8 @@ function locate_initrd { function find_wim_file { unset ventoy_wim_file - for file in "sources/boot.wim" "sources/BOOT.WIM" "Sources/Win10PEx64.WIM" "boot/BOOT.WIM" "winpe_x64.wim"; do + for file in "sources/boot.wim" "sources/BOOT.WIM" "Sources/Win10PEx64.WIM" "boot/BOOT.WIM" \ + "winpe_x64.wim" "boot/10pex64.wim" "BOOT/USM1PE6L.WIM" "BOOT/USM1PE6F.WIM"; do if [ -e $1/$file ]; then set ventoy_wim_file=$1/$file break @@ -64,6 +100,39 @@ function distro_specify_initrd_file { if [ -e (loop)/casper/initrd-oem ]; then vt_linux_specify_initrd_file /casper/initrd-oem fi + elif [ -e (loop)/boot/grub/initrd.xz ]; then + vt_linux_specify_initrd_file /boot/grub/initrd.xz + elif [ -e (loop)/initrd.gz ]; then + vt_linux_specify_initrd_file /initrd.gz + elif [ -e (loop)/slax/boot/initrfs.img ]; then + vt_linux_specify_initrd_file /slax/boot/initrfs.img + elif [ -e (loop)/pmagic/initrd.img ]; then + 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 + elif [ -f (loop)/Setup/initrd.gz ]; then + vt_linux_specify_initrd_file /Setup/initrd.gz + elif [ -f (loop)/isolinux/initramfs ]; then + vt_linux_specify_initrd_file /isolinux/initramfs + elif [ -f (loop)/boot/iniramfs.igz ]; then + vt_linux_specify_initrd_file /boot/iniramfs.igz + elif [ -f (loop)/initrd-x86_64 ]; then + vt_linux_specify_initrd_file /initrd-x86_64 + fi } @@ -95,31 +164,44 @@ function uefi_windows_menu_func { function uefi_linux_menu_func { if [ "$ventoy_compatible" = "NO" ]; then - vt_load_cpio ${vtoy_path}/ventoy.cpio + vt_load_cpio ${vtoy_path}/ventoy.cpio $2 $1 vt_linux_clear_initrd - for file in "boot/grub/grub.cfg" "EFI/BOOT/grub.cfg" "EFI/boot/grub.cfg" "efi/boot/grub.cfg" "EFI/BOOT/BOOTX64.conf"; do - if [ -e (loop)/$file ]; then - vt_linux_parse_initrd_grub file (loop)/$file - fi - done - - vt_linux_initrd_count initrd_count + if [ -d (loop)/pmagic ]; then + vt_linux_specify_initrd_file /pmagic/initrd.img + else + for file in "boot/grub/grub.cfg" "EFI/BOOT/grub.cfg" "EFI/boot/grub.cfg" "efi/boot/grub.cfg" "EFI/BOOT/BOOTX64.conf" "/grub/grub.cfg"; do + if [ -e (loop)/$file ]; then + vt_linux_parse_initrd_grub file (loop)/$file + fi + done + fi # special process for special distros - if vt_cmp $initrd_count eq 0; then - if [ -d (loop)/loader/entries ]; then - set LoadIsoEfiDriver=on - vt_linux_parse_initrd_grub dir (loop)/loader/entries/ - elif [ -d (loop)/boot/grub ]; then - vt_linux_parse_initrd_grub dir (loop)/boot/grub/ - fi + if [ -d (loop)/loader/entries ]; then + set LoadIsoEfiDriver=on + vt_linux_parse_initrd_grub dir (loop)/loader/entries/ + elif [ -d (loop)/boot/grub ]; then + vt_linux_parse_initrd_grub dir (loop)/boot/grub/ fi - vt_linux_initrd_count initrd_count - if vt_cmp $initrd_count eq 0; then - distro_specify_initrd_file + 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 @@ -129,7 +211,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" @@ -147,7 +229,7 @@ function uefi_iso_menu_func { if [ -n "$vtisouefi" ]; then set LoadIsoEfiDriver=on unset vtisouefi - elif [ -n "$VTOY_ISO_UEFI_DRV" ]; then + elif vt_check_mode 2; then set LoadIsoEfiDriver=on else unset LoadIsoEfiDriver @@ -164,10 +246,18 @@ 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 - elif [ -n "$VTOY_ISO_RAW" ]; then + elif vt_check_mode 1; then set ventoy_compatible=YES else vt_check_compatible (loop) @@ -176,13 +266,16 @@ function uefi_iso_menu_func { vt_img_sector ${1}${chosen_path} if [ "$vtoy_os" = "Windows" ]; then - if [ "$ventoy_fs_probe" = "iso9660" ]; then - set ventoy_compatible=YES + vt_check_pe (loop) + if [ "$VT_PE_SUPPORT" != "YES" ]; then + if [ "$ventoy_fs_probe" = "iso9660" ]; then + set ventoy_compatible=YES + fi fi - uefi_windows_menu_func $1 + uefi_windows_menu_func $1 ${chosen_path} else - uefi_linux_menu_func $1 + uefi_linux_menu_func $1 ${chosen_path} fi terminal_output gfxterm @@ -200,9 +293,6 @@ function uefi_iso_memdisk { } - - - function legacy_windows_menu_func { vt_windows_reset @@ -222,8 +312,7 @@ function legacy_windows_menu_func { fi if [ -n "$vtoy_chain_mem_addr" ]; then - linux16 $vtoy_path/ipxe.krn ${vtdebug_flag} ibft - initrd16 mem:${vtoy_chain_mem_addr}:size:${vtoy_chain_mem_size} + linux16 $vtoy_path/ipxe.krn ${vtdebug_flag} ibft mem:${vtoy_chain_mem_addr}:size:${vtoy_chain_mem_size} boot else echo "chain empty failed" @@ -233,39 +322,40 @@ function legacy_windows_menu_func { function legacy_linux_menu_func { if [ "$ventoy_compatible" = "NO" ]; then - - vt_load_cpio $vtoy_path/ventoy.cpio + vt_load_cpio $vtoy_path/ventoy.cpio $2 $1 vt_linux_clear_initrd - - for dir in "isolinux" "boot/isolinux" "boot/x86_64/loader" "syslinux" "boot/syslinux"; do - if [ -d (loop)/$dir ]; then - vt_linux_parse_initrd_isolinux (loop)/$dir/ - fi - done - vt_linux_initrd_count initrd_count + if [ -d (loop)/pmagic ]; then + vt_linux_specify_initrd_file /pmagic/initrd.img + else + for dir in "isolinux" "boot/isolinux" "boot/x86_64/loader" "syslinux" "boot/syslinux"; do + if [ -d (loop)/$dir ]; then + vt_linux_parse_initrd_isolinux (loop)/$dir/ + fi + done + fi # special process for special distros - if vt_cmp $initrd_count eq 0; then - #archlinux - if [ -d (loop)/arch/boot/syslinux ]; then - vt_linux_parse_initrd_isolinux (loop)/arch/boot/syslinux/ /arch/ - vt_linux_parse_initrd_isolinux (loop)/arch/boot/syslinux/ /arch/boot/syslinux/ - - #manjaro - elif [ -d (loop)/manjaro ]; then - if [ -e (loop)/boot/grub/kernels.cfg ]; then - vt_linux_parse_initrd_grub file (loop)/boot/grub/kernels.cfg - fi - elif [ -e (loop)/boot/grub/grub.cfg ]; then - vt_linux_parse_initrd_grub file (loop)/boot/grub/grub.cfg + #archlinux + if [ -d (loop)/arch/boot/syslinux ]; then + vt_linux_parse_initrd_isolinux (loop)/arch/boot/syslinux/ /arch/ + vt_linux_parse_initrd_isolinux (loop)/arch/boot/syslinux/ /arch/boot/syslinux/ + + #manjaro + elif [ -d (loop)/manjaro ]; then + if [ -e (loop)/boot/grub/kernels.cfg ]; then + vt_linux_parse_initrd_grub file (loop)/boot/grub/kernels.cfg fi + elif [ -e (loop)/boot/grub/grub.cfg ]; then + vt_linux_parse_initrd_grub file (loop)/boot/grub/grub.cfg fi - vt_linux_initrd_count initrd_count - if vt_cmp $initrd_count eq 0; then - distro_specify_initrd_file + distro_specify_initrd_file + + vt_linux_initrd_count vtcount + if [ $vtcount -eq 0 ]; then + distro_specify_initrd_file_phase2 fi locate_initrd @@ -277,9 +367,8 @@ function legacy_linux_menu_func { sleep 5 fi - if [ -n "$vtoy_chain_mem_addr" ]; then - linux16 $vtoy_path/ipxe.krn ${vtdebug_flag} - initrd16 mem:${vtoy_chain_mem_addr}:size:${vtoy_chain_mem_size} + if [ -n "$vtoy_chain_mem_addr" ]; then + linux16 $vtoy_path/ipxe.krn ${vtdebug_flag} mem:${vtoy_chain_mem_addr}:size:${vtoy_chain_mem_size} boot else echo "chain empty failed" @@ -308,7 +397,7 @@ function legacy_iso_menu_func { if [ -n "$vtcompat" ]; then set ventoy_compatible=YES unset vtcompat - elif [ -n "$VTOY_ISO_RAW" ]; then + elif vt_check_mode 1; then set ventoy_compatible=YES else vt_check_compatible (loop) @@ -317,12 +406,16 @@ function legacy_iso_menu_func { vt_img_sector ${1}${chosen_path} if [ "$vtoy_os" = "Windows" ]; then - if [ "$ventoy_fs_probe" = "iso9660" ]; then - set ventoy_compatible=YES + vt_check_pe (loop) + if [ "$VT_PE_SUPPORT" != "YES" ]; then + if [ "$ventoy_fs_probe" = "iso9660" ]; then + set ventoy_compatible=YES + fi fi - legacy_windows_menu_func $1 + + legacy_windows_menu_func $1 ${chosen_path} else - legacy_linux_menu_func $1 + legacy_linux_menu_func $1 ${chosen_path} fi } @@ -335,6 +428,22 @@ function legacy_iso_memdisk { boot } +function common_menuentry { + if [ "$grub_platform" = "pc" ]; then + if vt_check_mode 0; then + legacy_iso_memdisk $iso_path + else + legacy_iso_menu_func $iso_path + fi + else + if vt_check_mode 0; then + uefi_iso_memdisk $iso_path + else + uefi_iso_menu_func $iso_path + fi + fi +} + ############################################################# ############################################################# @@ -344,7 +453,12 @@ function legacy_iso_memdisk { ############################################################# ############################################################# -set VENTOY_VERSION="1.0.04" +set VENTOY_VERSION="1.0.10" + +# Default menu display mode, you can change it as you want. +# 0: List mode +# 1: TreeView mode +set VTOY_DEFAULT_MENU_MODE=0 #disable timeout unset timeout @@ -353,12 +467,20 @@ set VTOY_MEM_DISK_STR="MEMDISK" set VTOY_ISO_RAW_STR="ISO RAW" set VTOY_ISO_UEFI_DRV_STR="UEFI FS" +set VTOY_F2_CMD="ventoy_power" + +if [ "$grub_platform" = "pc" ]; then + set VTOY_TEXT_MENU_VER="Ventoy $VENTOY_VERSION BIOS www.ventoy.net" +else + set VTOY_TEXT_MENU_VER="Ventoy $VENTOY_VERSION UEFI www.ventoy.net" +fi + vt_device $root vtoy_dev if [ "$vtoy_dev" = "tftp" ]; then set vtoy_path=($root) for vtid in 0 1 2 3; do - if [ -d (hd$vtid,2)/grub ]; then + if [ -d (hd$vtid,2)/ventoy ]; then set iso_path=(hd$vtid,1) break fi @@ -370,55 +492,49 @@ fi loadfont ascii +#Load Plugin if [ -f $iso_path/ventoy/ventoy.json ]; then vt_load_plugin $iso_path fi -terminal_output gfxterm -if [ -n "$vtoy_theme" ]; then - set theme=$vtoy_theme +if [ $VTOY_DEFAULT_MENU_MODE -eq 0 ]; then + set VTOY_F3_CMD="vt_dynamic_menu 1 1" + set VTOY_HOTKEY_TIP="F1:Memdisk F2:Power F3:TreeView" else - set theme=$prefix/themes/ventoy/theme.txt + set VTOY_F3_CMD="vt_dynamic_menu 1 0" + set VTOY_HOTKEY_TIP="F1:Memdisk F2:Power F3:ListView" fi + if [ -n "$vtoy_gfxmode" ]; then set gfxmode=$vtoy_gfxmode else - set gfxmode=1024x768 + set gfxmode=1920x1080,1366x768,1024x768 +fi + +if [ -n "$vtoy_theme" ]; then + set theme=$vtoy_theme +else + set theme=$prefix/themes/ventoy/theme.txt fi +terminal_output gfxterm + #colect all image files (iso files) set ventoy_img_count=0 vt_list_img $iso_path ventoy_img_count -#Dynamic menu for every iso file -if vt_cmp $ventoy_img_count ne 0; then - set imgid=0 - while vt_cmp $imgid lt $ventoy_img_count; do - vt_img_name $imgid img_name - menuentry "$img_name" { - if [ "$grub_platform" = "pc" ]; then - if [ -n "$VTOY_MEM_DISK" ]; then - legacy_iso_memdisk $iso_path - else - legacy_iso_menu_func $iso_path - fi - else - if [ -n "$VTOY_MEM_DISK" ]; then - uefi_iso_memdisk $iso_path - else - uefi_iso_menu_func $iso_path - fi - fi - } - - vt_incr imgid 1 - done +#Main menu +if [ $ventoy_img_count -gt 0 ]; then + if [ $VTOY_DEFAULT_MENU_MODE -eq 0 ]; then + vt_dynamic_menu 0 0 + else + vt_dynamic_menu 0 1 + fi else menuentry "No ISO files found (Press enter to reboot ...)" { echo -e "\n Rebooting ... " reboot } fi -