mirror of
https://github.com/ventoy/Ventoy.git
synced 2025-01-14 00:05:05 -05:00
1. grub2 mode supports Porteus ISO file.
2. Optimization for Lenovo Recovery Image.
This commit is contained in:
parent
eac1c35f76
commit
7fe4762faa
@ -159,7 +159,7 @@ if $GREP -q SCRE /proc/cmdline; then
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
if $GREP -qw 'SA[.]1' /proc/cmdline; then
|
if $GREP -qw 'SA[.]1' /proc/cmdline; then
|
||||||
if $GREP -qw 'SA[.]2' /proc/cmdline; then
|
if $GREP -qw 'writable.fsimg' /proc/cmdline; then
|
||||||
if $GREP -qw 'rw' /proc/cmdline; then
|
if $GREP -qw 'rw' /proc/cmdline; then
|
||||||
echo 1 > $VTOY_PATH/distmagic/DELL_PER
|
echo 1 > $VTOY_PATH/distmagic/DELL_PER
|
||||||
fi
|
fi
|
||||||
|
@ -860,6 +860,9 @@ function uefi_linux_menu_func {
|
|||||||
if [ -f (loop)/boot/isolinux/syslnx64.cfg ]; then
|
if [ -f (loop)/boot/isolinux/syslnx64.cfg ]; then
|
||||||
syslinux_configfile (loop)/boot/isolinux/syslnx64.cfg
|
syslinux_configfile (loop)/boot/isolinux/syslnx64.cfg
|
||||||
set vtback_cfg_find=1
|
set vtback_cfg_find=1
|
||||||
|
elif [ -f (loop)/boot/syslinux/porteus.cfg ]; then
|
||||||
|
syslinux_configfile (loop)/boot/syslinux/porteus.cfg
|
||||||
|
set vtback_cfg_find=1
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@ -1311,6 +1314,9 @@ function legacy_linux_menu_func {
|
|||||||
if [ -f (loop)/boot/isolinux/syslnx64.cfg ]; then
|
if [ -f (loop)/boot/isolinux/syslnx64.cfg ]; then
|
||||||
syslinux_configfile (loop)/boot/isolinux/syslnx64.cfg
|
syslinux_configfile (loop)/boot/isolinux/syslnx64.cfg
|
||||||
set vtback_cfg_find=1
|
set vtback_cfg_find=1
|
||||||
|
elif [ -f (loop)/boot/syslinux/porteus.cfg ]; then
|
||||||
|
syslinux_configfile (loop)/boot/syslinux/porteus.cfg
|
||||||
|
set vtback_cfg_find=1
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@ -1486,6 +1492,8 @@ function iso_common_menuentry {
|
|||||||
|
|
||||||
get_os_type (loop)
|
get_os_type (loop)
|
||||||
|
|
||||||
|
ventoy_debug_pause
|
||||||
|
|
||||||
if vt_need_secondary_menu "$vt_chosen_name"; then
|
if vt_need_secondary_menu "$vt_chosen_name"; then
|
||||||
vt_show_secondary_menu "$vt_chosen_path" "$vtoy_os" $vt_chosen_size
|
vt_show_secondary_menu "$vt_chosen_path" "$vtoy_os" $vt_chosen_size
|
||||||
if [ "$VTOY_SECOND_EXIT" = "1" ]; then
|
if [ "$VTOY_SECOND_EXIT" = "1" ]; then
|
||||||
|
Binary file not shown.
Binary file not shown.
@ -916,7 +916,7 @@ static BOOL Is2K10PE(void)
|
|||||||
return bRet;
|
return bRet;
|
||||||
}
|
}
|
||||||
|
|
||||||
static CHAR GetIMDiskMountLogicalDrive(void)
|
static CHAR GetIMDiskMountLogicalDrive(const char *suffix)
|
||||||
{
|
{
|
||||||
CHAR Letter = 'Y';
|
CHAR Letter = 'Y';
|
||||||
DWORD Drives;
|
DWORD Drives;
|
||||||
@ -929,6 +929,12 @@ static CHAR GetIMDiskMountLogicalDrive(void)
|
|||||||
return 'M';
|
return 'M';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//fixed use Z as mountpoint for Lenovo Product Recovery
|
||||||
|
if (strcmp(suffix, "VTLRI") == 0)
|
||||||
|
{
|
||||||
|
return 'Z';
|
||||||
|
}
|
||||||
|
|
||||||
Drives = GetLogicalDrives();
|
Drives = GetLogicalDrives();
|
||||||
Log("Drives=0x%x", Drives);
|
Log("Drives=0x%x", Drives);
|
||||||
|
|
||||||
@ -1073,26 +1079,18 @@ End:
|
|||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int VentoyRunImdisk(const char *IsoPath, const char *imdiskexe, const char *opt)
|
static int VentoyRunImdisk(const char *suffix, const char *IsoPath, const char *imdiskexe, const char *opt)
|
||||||
{
|
{
|
||||||
CHAR Letter;
|
CHAR Letter;
|
||||||
CHAR Cmdline[512];
|
CHAR Cmdline[512];
|
||||||
WCHAR CmdlineW[512];
|
WCHAR CmdlineW[512];
|
||||||
PROCESS_INFORMATION Pi;
|
PROCESS_INFORMATION Pi;
|
||||||
|
|
||||||
Log("VentoyRunImdisk <%s> <%s> <%s>", IsoPath, imdiskexe, opt);
|
Log("VentoyRunImdisk <%s> <%s> <%s> <%s>", suffix, IsoPath, imdiskexe, opt);
|
||||||
|
|
||||||
Letter = GetIMDiskMountLogicalDrive();
|
Letter = GetIMDiskMountLogicalDrive(suffix);
|
||||||
|
|
||||||
if (opt)
|
|
||||||
{
|
|
||||||
sprintf_s(Cmdline, sizeof(Cmdline), "%s -a -o %s -f \"%s\" -m %C:", imdiskexe, opt, IsoPath, Letter);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
sprintf_s(Cmdline, sizeof(Cmdline), "%s -a -f \"%s\" -m %C:", imdiskexe, IsoPath, Letter);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
sprintf_s(Cmdline, sizeof(Cmdline), "%s -a -o %s -f \"%s\" -m %C:", imdiskexe, opt, IsoPath, Letter);
|
||||||
Log("mount iso to %C: use imdisk cmd <%s>", Letter, Cmdline);
|
Log("mount iso to %C: use imdisk cmd <%s>", Letter, Cmdline);
|
||||||
|
|
||||||
if (IsUTF8Encode(IsoPath))
|
if (IsUTF8Encode(IsoPath))
|
||||||
@ -1135,7 +1133,7 @@ int VentoyMountISOByImdisk(const char *IsoPath, DWORD PhyDrive)
|
|||||||
|
|
||||||
if (0 == VentoyCopyImdisk(PhyDrive, ImPath))
|
if (0 == VentoyCopyImdisk(PhyDrive, ImPath))
|
||||||
{
|
{
|
||||||
VentoyRunImdisk(IsoPath, ImPath, "ro");
|
VentoyRunImdisk("iso", IsoPath, ImPath, "ro");
|
||||||
rc = 0;
|
rc = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2370,7 +2368,7 @@ static int MountVTLRI(CHAR *ImgPath, DWORD PhyDrive)
|
|||||||
|
|
||||||
VentoyCopyImdisk(PhyDrive, ImDiskPath);
|
VentoyCopyImdisk(PhyDrive, ImDiskPath);
|
||||||
|
|
||||||
VentoyRunImdisk(ImgPath, ImDiskPath, "rem");
|
VentoyRunImdisk("VTLRI", ImgPath, ImDiskPath, "ro,rem");
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user