Added dmesg command.
authorRichard W.M. Jones <rjones@redhat.com>
Fri, 1 May 2009 10:27:32 +0000 (11:27 +0100)
committerRichard W.M. Jones <rjones@redhat.com>
Fri, 1 May 2009 10:27:32 +0000 (11:27 +0100)
daemon/Makefile.am
daemon/dmesg.c [new file with mode: 0644]
src/generator.ml

index 569f1ec..20195cb 100644 (file)
@@ -29,6 +29,7 @@ guestfsd_SOURCES = \
        debug.c \
        devsparts.c \
        dir.c \
+       dmesg.c \
        dropcaches.c \
        ext2.c \
        file.c \
diff --git a/daemon/dmesg.c b/daemon/dmesg.c
new file mode 100644 (file)
index 0000000..2e58eb9
--- /dev/null
@@ -0,0 +1,46 @@
+/* libguestfs - the guestfsd daemon
+ * Copyright (C) 2009 Red Hat Inc. 
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with this program; if not, write to the Free Software
+ * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
+ */
+
+#include <config.h>
+
+#include <stdio.h>
+#include <stdlib.h>
+#include <string.h>
+#include <unistd.h>
+#include <fcntl.h>
+
+#include "daemon.h"
+#include "actions.h"
+
+char *
+do_dmesg (void)
+{
+  char *out, *err;
+  int r;
+
+  r = command (&out, &err, "dmesg", NULL);
+  if (r == -1) {
+    reply_with_error ("dmesg: %s", err);
+    free (out);
+    free (err);
+    return NULL;
+  }
+  free (err);
+
+  return out;                  /* caller frees */
+}
index 2ffe19d..92da381 100755 (executable)
@@ -1752,6 +1752,20 @@ Setting C<whattodrop> to 3 should drop everything.
 This automatically calls L<sync(2)> before the operation,
 so that the maximum guest memory is freed.");
 
+  ("dmesg", (RString "kmsgs", []), 91, [],
+   [InitEmpty, TestRun (
+      [["dmesg"]])],
+   "return kernel messages",
+   "\
+This returns the kernel messages (C<dmesg> output) from
+the guest kernel.  This is sometimes useful for extended
+debugging of problems.
+
+Another way to get the same information is to enable
+verbose messages with C<guestfs_set_verbose> or by setting
+the environment variable C<LIBGUESTFS_DEBUG=1> before
+running the program.");
+
 ]
 
 let all_functions = non_daemon_functions @ daemon_functions