Fix a bug when booting Porteus 4.0 i586 20170701.iso

This commit is contained in:
longpanda 2021-10-21 20:23:32 +08:00
parent be8b6e8976
commit ec4b6c2a2c
6 changed files with 53 additions and 10 deletions

View File

@ -22,9 +22,16 @@ porteus_hook() {
$SED "/searching *for *\$CFG *file/i\ $BUSYBOX_PATH/sh $VTOY_PATH/hook/debian/porteus-disk.sh" -i $1 $SED "/searching *for *\$CFG *file/i\ $BUSYBOX_PATH/sh $VTOY_PATH/hook/debian/porteus-disk.sh" -i $1
} }
if $GREP -q exfat /proc/filesystems; then vtPath=$($VTOY_PATH/tool/vtoydump -p $VTOY_PATH/ventoy_os_param)
vtPath=$($VTOY_PATH/tool/vtoydump -p $VTOY_PATH/ventoy_os_param) echo $vtPath | $GREP -q " "
_vtRet1=$?
$GREP -q exfat /proc/filesystems
_vtRet2=$?
echo "_vtRet1=$_vtRet1 _vtRet2=$_vtRet2 ..." >> $VTLOG
if [ $_vtRet1 -ne 0 -a $_vtRet2 -eq 0 ]; then
vtFindFlag=0 vtFindFlag=0
$GREP '`value from`' /usr/* -r | $AWK -F: '{print $1}' | while read vtline; do $GREP '`value from`' /usr/* -r | $AWK -F: '{print $1}' | while read vtline; do
echo "hooking $vtline ..." >> $VTLOG echo "hooking $vtline ..." >> $VTLOG
@ -34,11 +41,19 @@ if $GREP -q exfat /proc/filesystems; then
if [ $vtFindFlag -eq 0 ]; then if [ $vtFindFlag -eq 0 ]; then
if $GREP -q '`value from`' /linuxrc; then if $GREP -q '`value from`' /linuxrc; then
echo "hooking linuxrc ..." >> $VTLOG if $GREP -q "searching *for *\$CFG *file" /linuxrc; then
$SED "/searching *for *\$CFG *file/i$BUSYBOX_PATH/sh $VTOY_PATH/hook/debian/porteus-path.sh" -i /linuxrc echo "hooking linuxrc CFG..." >> $VTLOG
$SED "/searching *for *\$CFG *file/iFROM=\$(cat /porteus-from)" -i /linuxrc $SED "/searching *for *\$CFG *file/i$BUSYBOX_PATH/sh $VTOY_PATH/hook/debian/porteus-path.sh" -i /linuxrc
$SED "/searching *for *\$CFG *file/iISO=\$(cat /porteus-from)" -i /linuxrc $SED "/searching *for *\$CFG *file/iFROM=\$(cat /porteus-from)" -i /linuxrc
vtFindFlag=1 $SED "/searching *for *\$CFG *file/iISO=\$(cat /porteus-from)" -i /linuxrc
vtFindFlag=1
else
echo "hooking linuxrc SGN..." >> $VTLOG
$SED "/searching *for *\$SGN *file/i$BUSYBOX_PATH/sh $VTOY_PATH/hook/debian/porteus-path.sh" -i /linuxrc
$SED "/searching *for *\$SGN *file/iFROM=\$(cat /porteus-from)" -i /linuxrc
$SED "/searching *for *\$SGN *file/iISO=\$(cat /porteus-from)" -i /linuxrc
vtFindFlag=1
fi
fi fi
fi fi
@ -46,7 +61,7 @@ else
for vtfile in '/linuxrc' '/init'; do for vtfile in '/linuxrc' '/init'; do
if [ -e $vtfile ]; then if [ -e $vtfile ]; then
if ! $GREP -q ventoy $vtfile; then if ! $GREP -q ventoy $vtfile; then
echo "hooking $vtfile ..." >> $VTLOG echo "hooking disk $vtfile ..." >> $VTLOG
porteus_hook $vtfile porteus_hook $vtfile
fi fi
fi fi

View File

@ -435,6 +435,24 @@ static int vtoy_printf_iso_path(ventoy_os_param *param)
return 0; return 0;
} }
static int vtoy_printf_fs(ventoy_os_param *param)
{
const char *fs[] =
{
"exfat", "ntfs", "ext", "xfs", "udf", "fat"
};
if (param->vtoy_disk_part_type < 6)
{
printf("%s\n", fs[param->vtoy_disk_part_type]);
}
else
{
printf("unknown\n");
}
return 0;
}
static int vtoy_check_device(ventoy_os_param *param, const char *device) static int vtoy_check_device(ventoy_os_param *param, const char *device)
{ {
unsigned long long size; unsigned long long size;
@ -551,12 +569,13 @@ int vtoydump_main(int argc, char **argv)
int rc; int rc;
int ch; int ch;
int print_path = 0; int print_path = 0;
int print_fs = 0;
char filename[256] = {0}; char filename[256] = {0};
char diskname[256] = {0}; char diskname[256] = {0};
char device[64] = {0}; char device[64] = {0};
ventoy_os_param *param = NULL; ventoy_os_param *param = NULL;
while ((ch = getopt(argc, argv, "c:f:p:v::")) != -1) while ((ch = getopt(argc, argv, "c:f:p:s:v::")) != -1)
{ {
if (ch == 'f') if (ch == 'f')
{ {
@ -575,6 +594,11 @@ int vtoydump_main(int argc, char **argv)
print_path = 1; print_path = 1;
strncpy(filename, optarg, sizeof(filename) - 1); strncpy(filename, optarg, sizeof(filename) - 1);
} }
else if (ch == 's')
{
print_fs = 1;
strncpy(filename, optarg, sizeof(filename) - 1);
}
else else
{ {
fprintf(stderr, "Usage: %s -f datafile [ -v ] \n", argv[0]); fprintf(stderr, "Usage: %s -f datafile [ -v ] \n", argv[0]);
@ -627,6 +651,10 @@ int vtoydump_main(int argc, char **argv)
{ {
rc = vtoy_printf_iso_path(param); rc = vtoy_printf_iso_path(param);
} }
else if (print_fs)
{
rc = vtoy_printf_fs(param);
}
else if (device[0]) else if (device[0])
{ {
rc = vtoy_check_device(param, device); rc = vtoy_check_device(param, device);

Binary file not shown.

Binary file not shown.

Binary file not shown.

Binary file not shown.