X-Git-Url: http://git.annexia.org/?p=virt-mem.git;a=blobdiff_plain;f=ps%2Fvirt_ps.ml;h=fe538a9f15b17e3230cce4bce64abe01e4726865;hp=065b4c36ec59a69e5bdba1709a9999cf85ce433e;hb=f6bb3caa719a564615e7fd2f21a3ad5bca010a88;hpb=97131d94f5513b732f8f8d310984e71d8201cadf diff --git a/ps/virt_ps.ml b/ps/virt_ps.ml index 065b4c3..fe538a9 100644 --- a/ps/virt_ps.ml +++ b/ps/virt_ps.ml @@ -21,13 +21,28 @@ open Printf open Virt_mem_gettext.Gettext open Virt_mem_utils -open Virt_mem_mmap +open Virt_mem_types -let run debug images = () +open Kernel_task_struct + +let run debug { domname = domname; mem = mem } { tasks = tasks } = + let tasks = Option.get tasks in + + (* Sort tasks by PID. *) + let cmp { task_pid = p1 } { task_pid = p2 } = compare p1 p2 in + let tasks = List.sort cmp tasks in + + printf " PID STAT COMMAND\n"; + + List.iter ( + fun task -> + printf "%5Ld %s\n" task.task_pid task.task_comm + ) tasks let summary = s_"list processes in virtual machine" let description = s_"\ virt-ps prints a process listing for virtual machines running under libvirt." -let () = Virt_mem.register "ps" summary description ~run +let () = + Virt_mem.register "ps" summary description ~needs_tasks:true ~run