[Pkg-libvirt-commits] [libguestfs] 47/59: v2v: Warn if a kernel-* package is found containing no files.
Hilko Bengen
bengen at moszumanska.debian.org
Wed Nov 26 22:04:06 UTC 2014
This is an automated email from the git hooks/post-receive script.
bengen pushed a commit to branch master
in repository libguestfs.
commit 174d4dfde39df05fcb0b68522e5b15182084e2f4
Author: Richard W.M. Jones <rjones at redhat.com>
Date: Thu Nov 6 18:49:46 2014 +0000
v2v: Warn if a kernel-* package is found containing no files.
(cherry picked from commit 4a187b7faf119cb2bb4a761bd59618bd2af77ef9)
---
v2v/convert_linux.ml | 200 ++++++++++++++++++++++++++-------------------------
1 file changed, 103 insertions(+), 97 deletions(-)
diff --git a/v2v/convert_linux.ml b/v2v/convert_linux.ml
index 3451f27..c5b13a1 100644
--- a/v2v/convert_linux.ml
+++ b/v2v/convert_linux.ml
@@ -150,105 +150,111 @@ let rec convert ~verbose ~keep_serial_console (g : G.guestfs) inspect source =
(* For each kernel, list the files directly owned by the kernel. *)
let files = Linux.file_list_of_package verbose g inspect app in
- (* Which of these is the kernel itself? *)
- let vmlinuz = List.find (
- fun filename -> string_prefix filename "/boot/vmlinuz-"
- ) files in
- (* Which of these is the modpath? *)
- let modpath = List.find (
- fun filename ->
- String.length filename >= 14 &&
- string_prefix filename "/lib/modules/"
- ) files in
-
- (* Check vmlinuz & modpath exist. *)
- if not (g#is_dir ~followsymlinks:true modpath) then
- raise Not_found;
- let vmlinuz_stat =
- try g#statns vmlinuz with G.Error _ -> raise Not_found in
-
- (* Get/construct the version. XXX Read this from kernel file. *)
- let version =
- sprintf "%s-%s" app.G.app2_version app.G.app2_release in
-
- (* Find the initramfs which corresponds to the kernel.
- * Since the initramfs is built at runtime, and doesn't have
- * to be covered by the RPM file list, this is basically
- * guesswork.
- *)
- let initrd =
- let files = g#ls "/boot" in
- let files = Array.to_list files in
- let files =
- List.filter (fun n -> Str.string_match rex_initrd n 0) files in
- let files =
- List.filter (
- fun n ->
- string_find n app.G.app2_version >= 0 &&
- string_find n app.G.app2_release >= 0
- ) files in
- (* Don't consider kdump initramfs images (RHBZ#1138184). *)
- let files =
- List.filter (fun n -> string_find n "kdump.img" == -1) files in
- (* If several files match, take the shortest match. This
- * handles the case where we have a mix of same-version non-Xen
- * and Xen kernels:
- * initrd-2.6.18-308.el5.img
- * initrd-2.6.18-308.el5xen.img
- * and kernel 2.6.18-308.el5 (non-Xen) will match both
- * (RHBZ#1141145).
+ if files = [] then (
+ warning (f_"package '%s' contains no files") name;
+ None
+ )
+ else (
+ (* Which of these is the kernel itself? *)
+ let vmlinuz = List.find (
+ fun filename -> string_prefix filename "/boot/vmlinuz-"
+ ) files in
+ (* Which of these is the modpath? *)
+ let modpath = List.find (
+ fun filename ->
+ String.length filename >= 14 &&
+ string_prefix filename "/lib/modules/"
+ ) files in
+
+ (* Check vmlinuz & modpath exist. *)
+ if not (g#is_dir ~followsymlinks:true modpath) then
+ raise Not_found;
+ let vmlinuz_stat =
+ try g#statns vmlinuz with G.Error _ -> raise Not_found in
+
+ (* Get/construct the version. XXX Read this from kernel file. *)
+ let version =
+ sprintf "%s-%s" app.G.app2_version app.G.app2_release in
+
+ (* Find the initramfs which corresponds to the kernel.
+ * Since the initramfs is built at runtime, and doesn't have
+ * to be covered by the RPM file list, this is basically
+ * guesswork.
*)
- let cmp a b = compare (String.length a) (String.length b) in
- let files = List.sort cmp files in
- match files with
- | [] ->
- warning (f_"no initrd was found in /boot matching %s %s.")
- name version;
- None
- | x :: _ -> Some ("/boot/" ^ x) in
-
- (* Get all modules, which might include custom-installed
- * modules that don't appear in 'files' list above.
- *)
- let modules = g#find modpath in
- let modules = Array.to_list modules in
- let modules =
- List.filter (fun m -> Str.string_match rex_ko m 0) modules in
- assert (List.length modules > 0);
-
- (* Determine the kernel architecture by looking at the
- * architecture of an arbitrary kernel module.
- *)
- let arch =
- let any_module = modpath ^ List.hd modules in
- g#file_architecture any_module in
-
- (* Just return the module names, without path or extension. *)
- let modules = filter_map (
- fun m ->
- if Str.string_match rex_ko_extract m 0 then
- Some (Str.matched_group 1 m)
- else
+ let initrd =
+ let files = g#ls "/boot" in
+ let files = Array.to_list files in
+ let files =
+ List.filter (fun n -> Str.string_match rex_initrd n 0) files in
+ let files =
+ List.filter (
+ fun n ->
+ string_find n app.G.app2_version >= 0 &&
+ string_find n app.G.app2_release >= 0
+ ) files in
+ (* Don't consider kdump initramfs images (RHBZ#1138184). *)
+ let files =
+ List.filter (fun n -> string_find n "kdump.img" == -1) files in
+ (* If several files match, take the shortest match. This
+ * handles the case where we have a mix of same-version non-Xen
+ * and Xen kernels:
+ * initrd-2.6.18-308.el5.img
+ * initrd-2.6.18-308.el5xen.img
+ * and kernel 2.6.18-308.el5 (non-Xen) will match both
+ * (RHBZ#1141145).
+ *)
+ let cmp a b = compare (String.length a) (String.length b) in
+ let files = List.sort cmp files in
+ match files with
+ | [] ->
+ warning (f_"no initrd was found in /boot matching %s %s.")
+ name version;
None
- ) modules in
- assert (List.length modules > 0);
-
- let supports_virtio = List.mem "virtio_net" modules in
- let is_xen_kernel = List.mem "xennet" modules in
-
- Some {
- ki_app = app;
- ki_name = name;
- ki_version = version;
- ki_arch = arch;
- ki_vmlinuz = vmlinuz;
- ki_vmlinuz_stat = vmlinuz_stat;
- ki_initrd = initrd;
- ki_modpath = modpath;
- ki_modules = modules;
- ki_supports_virtio = supports_virtio;
- ki_is_xen_kernel = is_xen_kernel;
- }
+ | x :: _ -> Some ("/boot/" ^ x) in
+
+ (* Get all modules, which might include custom-installed
+ * modules that don't appear in 'files' list above.
+ *)
+ let modules = g#find modpath in
+ let modules = Array.to_list modules in
+ let modules =
+ List.filter (fun m -> Str.string_match rex_ko m 0) modules in
+ assert (List.length modules > 0);
+
+ (* Determine the kernel architecture by looking at the
+ * architecture of an arbitrary kernel module.
+ *)
+ let arch =
+ let any_module = modpath ^ List.hd modules in
+ g#file_architecture any_module in
+
+ (* Just return the module names, without path or extension. *)
+ let modules = filter_map (
+ fun m ->
+ if Str.string_match rex_ko_extract m 0 then
+ Some (Str.matched_group 1 m)
+ else
+ None
+ ) modules in
+ assert (List.length modules > 0);
+
+ let supports_virtio = List.mem "virtio_net" modules in
+ let is_xen_kernel = List.mem "xennet" modules in
+
+ Some {
+ ki_app = app;
+ ki_name = name;
+ ki_version = version;
+ ki_arch = arch;
+ ki_vmlinuz = vmlinuz;
+ ki_vmlinuz_stat = vmlinuz_stat;
+ ki_initrd = initrd;
+ ki_modpath = modpath;
+ ki_modules = modules;
+ ki_supports_virtio = supports_virtio;
+ ki_is_xen_kernel = is_xen_kernel;
+ }
+ )
with Not_found -> None
)
--
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