[Pkg-libvirt-commits] [libguestfs] 48/59: v2v: efi: Detect if the guest could boot with UEFI.

Hilko Bengen bengen at moszumanska.debian.org
Sun May 3 21:26:41 UTC 2015


This is an automated email from the git hooks/post-receive script.

bengen pushed a commit to branch experimental
in repository libguestfs.

commit 6a76d6d780a8a833c9762195a79515bbc65704a0
Author: Richard W.M. Jones <rjones at redhat.com>
Date:   Thu Apr 30 14:09:46 2015 +0100

    v2v: efi: Detect if the guest could boot with UEFI.
    
    Use a heuristic to detect if the guest could boot with UEFI.
    
    This is only used where we have missing metadata (in the
    source.s_firmware == UnknownFirmware case).  Currently that only
    applies for `-i disk' and `-i libvirt/libvirtxml'.
    
    Eventually we'll be able to get this information from the libvirt
    metadata (RHBZ#1217444), so it'll only be used for `-i disk'.
---
 v2v/types.ml  |  1 +
 v2v/types.mli |  1 +
 v2v/v2v.ml    | 19 ++++++++++++++++++-
 3 files changed, 20 insertions(+), 1 deletion(-)

diff --git a/v2v/types.ml b/v2v/types.ml
index 90591c3..5531f26 100644
--- a/v2v/types.ml
+++ b/v2v/types.ml
@@ -275,6 +275,7 @@ type inspect = {
   i_mountpoints : (string * string) list;
   i_apps : Guestfs.application2 list;
   i_apps_map : Guestfs.application2 list StringMap.t;
+  i_uefi : bool;
 }
 
 type mpstat = {
diff --git a/v2v/types.mli b/v2v/types.mli
index b629283..1ee9013 100644
--- a/v2v/types.mli
+++ b/v2v/types.mli
@@ -164,6 +164,7 @@ type inspect = {
     (** This is a map from the app name to the application object.
         Since RPM allows multiple packages with the same name to be
         installed, the value is a list. *)
+  i_uefi : bool;        (** True if the guest could boot with UEFI. *)
 }
 (** Inspection information. *)
 
diff --git a/v2v/v2v.ml b/v2v/v2v.ml
index 0ae7f7d..dcf0b80 100644
--- a/v2v/v2v.ml
+++ b/v2v/v2v.ml
@@ -530,6 +530,22 @@ and inspect_source g root_choice =
       StringMap.add name (app :: vs) map
   ) StringMap.empty apps in
 
+  (* See if this guest could use UEFI to boot.  It should use GPT and
+   * it should have an EFI System Partition (ESP).
+   *)
+  let uefi =
+    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 is_uefi_bootable_device dev =
+      g#part_get_parttype dev = "gpt" && (
+        let partitions = Array.to_list (g#part_list dev) in
+        List.exists (is_uefi_ESP dev) partitions
+      )
+    in
+    let devices = Array.to_list (g#list_devices ()) in
+    List.exists is_uefi_bootable_device devices in
+
   { i_root = root;
     i_type = g#inspect_get_type root;
     i_distro = g#inspect_get_distro root;
@@ -542,7 +558,8 @@ and inspect_source g root_choice =
     i_product_variant = g#inspect_get_product_variant root;
     i_mountpoints = mps;
     i_apps = apps;
-    i_apps_map = apps_map; }
+    i_apps_map = apps_map;
+    i_uefi = uefi; }
 
 (* Conversion can fail if there is no space on the guest filesystems
  * (RHBZ#1139543).  To avoid this situation, check there is some

-- 
Alioth's /usr/local/bin/git-commit-notice on /srv/git.debian.org/git/pkg-libvirt/libguestfs.git



More information about the Pkg-libvirt-commits mailing list