Richard W.M. Jones
2016-Jun-13 09:34 UTC
[Libguestfs] [PATCH] v2v: Fix get_firmware_bootable_device.
I'm going to push this because it's a test blocker, but FYI. Rich.
Richard W.M. Jones
2016-Jun-13 09:34 UTC
[Libguestfs] [PATCH] v2v: Fix get_firmware_bootable_device.
Commit 82df76851478f52e02ed6beef0f1576772d066cd breaks the regression test for RHBZ#1232192 because g#part_list can return an error when called on a completely blank disk. By rewriting and simplifying the code using higher-order functions we can avoid the need for the double-nested imperative loop and calling g#part_list at all. Fixes commit 82df76851478f52e02ed6beef0f1576772d066cd. --- v2v/inspect_source.ml | 26 +++++++++----------------- v2v/v2v.ml | 2 +- 2 files changed, 10 insertions(+), 18 deletions(-) diff --git a/v2v/inspect_source.ml b/v2v/inspect_source.ml index 86d7892..cf8c98f 100644 --- a/v2v/inspect_source.ml +++ b/v2v/inspect_source.ml @@ -158,10 +158,9 @@ and reject_if_not_installed_image g root *) and get_firmware_bootable_device g let rec uefi_ESP_guid = "C12A7328-F81F-11D2-BA4B-00A0C93EC93B" - and is_uefi_ESP dev { G.part_num = partnum } - g#part_get_gpt_type dev (Int32.to_int partnum) = uefi_ESP_guid - and part_dev_name dev { G.part_num = partnum } - sprintf "%s%d" dev (Int32.to_int partnum) + and is_uefi_ESP dev part + let partnum = g#part_to_partnum part in + g#part_get_gpt_type dev partnum = uefi_ESP_guid and parttype_is_gpt dev try g#part_get_parttype dev = "gpt" with G.Error msg as exn -> @@ -169,24 +168,17 @@ and get_firmware_bootable_device g if g#last_errno () <> G.Errno.errno_EINVAL then raise exn; debug "%s (ignored)" msg; false - and is_uefi_bootable_part dev part + and is_uefi_bootable_part part + let dev = g#part_to_dev part in parttype_is_gpt dev && is_uefi_ESP dev part in - let devices = Array.to_list (g#list_devices ()) in - let uefi_list = ref [] in - List.iter ( - fun dev -> - Array.iter ( - fun part -> - if is_uefi_bootable_part dev part then - uefi_list := part_dev_name dev part :: !uefi_list - ) (g#part_list dev) - ) devices; + let partitions = Array.to_list (g#list_partitions ()) in + let partitions = List.filter is_uefi_bootable_part partitions in - match !uefi_list with + match partitions with | [] -> I_BIOS - | devices -> I_UEFI devices + | partitions -> I_UEFI partitions (* If some inspection fields are "unknown", then that indicates a * failure in inspection, and we shouldn't continue. For an example diff --git a/v2v/v2v.ml b/v2v/v2v.ml index 2545bda..5483ed6 100644 --- a/v2v/v2v.ml +++ b/v2v/v2v.ml @@ -558,7 +558,7 @@ and get_target_firmware inspect guestcaps source output | UnknownFirmware -> match inspect.i_firmware with | I_BIOS -> TargetBIOS - | I_UEFI devs -> TargetUEFI + | I_UEFI _ -> TargetUEFI in let supported_firmware = output#supported_firmware in if not (List.mem target_firmware supported_firmware) then -- 2.7.4
Possibly Parallel Threads
- Re: [PATCH 1/2] v2v: fill the list of the EFI system partitions
- [PATCH v2 0/3] daemon: parted: Always use -s option even with -m.
- [PATCH FOR DISCUSSION ONLY 0/2] v2v: Copy static IP address information over for Windows guests (RHBZ#1626503).
- [PATCH v2 2/2] v2v: Copy static IP address information over for Windows guests (RHBZ#1626503).
- Re: [PATCH 2/2] v2v: remove the 'graphicsmodedisabled' entry in ESP BCD