From 8c60f5c681b5d7cf90bc798fcaf94cd4e242e27f Mon Sep 17 00:00:00 2001 From: "Richard W.M. Jones" Date: Fri, 1 May 2009 11:27:32 +0100 Subject: [PATCH] Added dmesg command. --- daemon/Makefile.am | 1 + daemon/dmesg.c | 46 ++++++++++++++++++++++++++++++++++++++++++++++ src/generator.ml | 14 ++++++++++++++ 3 files changed, 61 insertions(+) create mode 100644 daemon/dmesg.c diff --git a/daemon/Makefile.am b/daemon/Makefile.am index 569f1ec..20195cb 100644 --- a/daemon/Makefile.am +++ b/daemon/Makefile.am @@ -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 index 0000000..2e58eb9 --- /dev/null +++ b/daemon/dmesg.c @@ -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 + +#include +#include +#include +#include +#include + +#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 */ +} diff --git a/src/generator.ml b/src/generator.ml index 2ffe19d..92da381 100755 --- a/src/generator.ml +++ b/src/generator.ml @@ -1752,6 +1752,20 @@ Setting C to 3 should drop everything. This automatically calls L 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 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 or by setting +the environment variable C before +running the program."); + ] let all_functions = non_daemon_functions @ daemon_functions -- 1.8.3.1