Commit 0aff8f51 authored by longpanda's avatar longpanda
Browse files

update vtoytool

parent 2750f0c5
...@@ -435,6 +435,33 @@ static int vtoy_printf_iso_path(ventoy_os_param *param) ...@@ -435,6 +435,33 @@ static int vtoy_printf_iso_path(ventoy_os_param *param)
return 0; return 0;
} }
static int vtoy_check_device(ventoy_os_param *param, const char *device)
{
unsigned long long size;
uint8_t vtguid[16] = {0};
uint8_t vtsig[4] = {0};
debug("vtoy_check_device for <%s>\n", device);
size = vtoy_get_disk_size_in_byte(device);
vtoy_get_disk_guid(device, vtguid, vtsig);
debug("param->vtoy_disk_size=%llu size=%llu\n",
(unsigned long long)param->vtoy_disk_size, (unsigned long long)size);
if (memcmp(vtguid, param->vtoy_disk_guid, 16) == 0 &&
memcmp(vtsig, param->vtoy_disk_signature, 4) == 0)
{
debug("<%s> is right ventoy disk\n", device);
return 0;
}
else
{
debug("<%s> is NOT right ventoy disk\n", device);
return 1;
}
}
static int vtoy_print_os_param(ventoy_os_param *param, char *diskname) static int vtoy_print_os_param(ventoy_os_param *param, char *diskname)
{ {
int cnt = 0; int cnt = 0;
...@@ -442,16 +469,20 @@ static int vtoy_print_os_param(ventoy_os_param *param, char *diskname) ...@@ -442,16 +469,20 @@ static int vtoy_print_os_param(ventoy_os_param *param, char *diskname)
const char *fs; const char *fs;
cnt = vtoy_find_disk_by_size(param->vtoy_disk_size, diskname); cnt = vtoy_find_disk_by_size(param->vtoy_disk_size, diskname);
if (cnt > 1) debug("find disk by size %llu, cnt=%d...\n", (unsigned long long)param->vtoy_disk_size, cnt);
if (1 == cnt)
{ {
cnt = vtoy_find_disk_by_guid(param, diskname); if (vtoy_check_device(param, diskname) != 0)
{
cnt = 0;
}
} }
else if (cnt == 0) else
{ {
cnt = vtoy_find_disk_by_guid(param, diskname); cnt = vtoy_find_disk_by_guid(param, diskname);
debug("find 0 disk by size, try with guid cnt=%d...\n", cnt); debug("find disk by guid cnt=%d...\n", cnt);
} }
if (param->vtoy_disk_part_type < ventoy_fs_max) if (param->vtoy_disk_part_type < ventoy_fs_max)
{ {
fs = g_ventoy_fs[param->vtoy_disk_part_type]; fs = g_ventoy_fs[param->vtoy_disk_part_type];
...@@ -472,33 +503,6 @@ static int vtoy_print_os_param(ventoy_os_param *param, char *diskname) ...@@ -472,33 +503,6 @@ static int vtoy_print_os_param(ventoy_os_param *param, char *diskname)
} }
} }
static int vtoy_check_device(ventoy_os_param *param, const char *device)
{
unsigned long long size;
uint8_t vtguid[16] = {0};
uint8_t vtsig[4] = {0};
debug("vtoy_check_device for <%s>\n", device);
size = vtoy_get_disk_size_in_byte(device);
vtoy_get_disk_guid(device, vtguid, vtsig);
debug("param->vtoy_disk_size=%llu size=%llu\n",
(unsigned long long)param->vtoy_disk_size, (unsigned long long)size);
if (memcmp(vtguid, param->vtoy_disk_guid, 16) == 0 &&
memcmp(vtsig, param->vtoy_disk_signature, 4) == 0)
{
debug("<%s> is right ventoy disk\n", device);
return 0;
}
else
{
debug("<%s> is NOT right ventoy disk\n", device);
return 1;
}
}
/* /*
* Find disk and image path from ventoy runtime data. * Find disk and image path from ventoy runtime data.
* By default data is read from phymem(legacy bios) or efivar(UEFI), if -f is input, data is read from file. * By default data is read from phymem(legacy bios) or efivar(UEFI), if -f is input, data is read from file.
......
Markdown is supported
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment