Elementary -- and broken -- implementation of virt-mem capture.
[virt-mem.git] / uname / virt_uname.ml
index dcdf5c8..6004bb8 100644 (file)
@@ -23,20 +23,7 @@ open Virt_mem_gettext.Gettext
 open Virt_mem_utils
 open Virt_mem_mmap
 
-let usage = s_"NAME
-  virt-uname - uname command for virtual machines
-
-SUMMARY
-  virt-uname [-options] [domains]
-
-DESCRIPTION
-  virt-uname prints the uname information such as OS version,
-  architecture and node name for virtual machines running under
-  libvirt."
-
-let verbose, images = Virt_mem.start usage
-
-let () =
+let run debug images =
   (* Print new_utsname structure from bitstring. *)
   let print_new_utsname name bs =
     (* Truncate an OCaml string at the first ASCII NUL character, ie. as
@@ -49,16 +36,20 @@ let () =
       with
        Not_found -> str
     in
+    (* Expect the first (sysname) field to always be "Linux", which is
+     * also a good way to tell if we're synchronized to the right bit of
+     * memory.
+     *)
     bitmatch bs with
-    | { sysname : 65*8 : string;
+    | { "Linux\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000\000" : 65*8 : string;
        nodename : 65*8 : string;
        release : 65*8 : string;
        version : 65*8 : string;
        machine : 65*8 : string;
        domainname : 65*8 : string } ->
-       printf "%s: %s %s %s %s %s %s\n"
+       printf "%s: Linux %s %s %s %s %s\n"
          name
-         (truncate sysname) (truncate nodename) (truncate release)
+         (truncate nodename) (truncate release)
          (truncate version) (truncate machine) (truncate domainname)
     | { _ } ->
        eprintf (f_"%s: unexpected system_utsname in kernel image\n")
@@ -66,15 +57,14 @@ let () =
   in
 
   List.iter (
-    fun (name, arch, mem, lookup_ksym) ->
+    fun (_, name, arch, mem, lookup_ksym) ->
       (* In Linux 2.6.25, the symbol is init_uts_ns.
        * http://lxr.linux.no/linux/init/version.c
        *)
       try
        let addr = lookup_ksym "init_uts_ns" in
-       if verbose then printf "init_uts_ns at %Lx\n" addr;
 
-       let bs = Bitmatch.bitstring_of_string (get_bytes mem addr (65*6+4)) in
+       let bs = Bitstring.bitstring_of_string (get_bytes mem addr (65*6+4)) in
        (bitmatch bs with
         | { _ : 32 : int;              (* the kref, atomic_t, always 32 bits *)
             new_utsname : -1 : bitstring } ->
@@ -89,12 +79,19 @@ let () =
           *)
          try
            let addr = lookup_ksym "system_utsname" in
-           if verbose then printf "system_utsname at %Lx\n" addr;
 
            let bs =
-             Bitmatch.bitstring_of_string (get_bytes mem addr (65*6)) in
+             Bitstring.bitstring_of_string (get_bytes mem addr (65*6)) in
            print_new_utsname name bs
          with
            Not_found ->
              eprintf (f_"%s: could not find utsname in kernel image\n") name
   ) images
+
+let summary = s_"uname command for virtual machines"
+let description = s_"\
+virt-uname prints the uname information such as OS version,
+architecture and node name for virtual machines running under
+libvirt."
+
+let () = Virt_mem.register "uname" summary description ~run