 
	
| [Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [Xen-changelog] [xen-unstable] xl: Add subcommand "xl debug-keys"
 # HG changeset patch
# User Keir Fraser <keir.fraser@xxxxxxxxxx>
# Date 1274269876 -3600
# Node ID f981d865c8270acef9eba0909df1b30048dbaf53
# Parent  5cf04d1c393384d6b73be4cd6eeb5e3ce67a61d5
xl: Add subcommand "xl debug-keys"
Can be used to send debug keys to Xen.
Signed-off-by: Yu Zhiguo <yuzg@xxxxxxxxxxxxxx>
---
 tools/libxl/libxl.c       |    5 +++++
 tools/libxl/libxl.h       |    1 +
 tools/libxl/xl_cmdimpl.c  |   30 ++++++++++++++++++++++++++++++
 tools/libxl/xl_cmdimpl.h  |    1 +
 tools/libxl/xl_cmdtable.c |    5 +++++
 5 files changed, 42 insertions(+)
diff -r 5cf04d1c3933 -r f981d865c827 tools/libxl/libxl.c
--- a/tools/libxl/libxl.c       Wed May 19 12:48:32 2010 +0100
+++ b/tools/libxl/libxl.c       Wed May 19 12:51:16 2010 +0100
@@ -2822,6 +2822,11 @@ int libxl_send_sysrq(struct libxl_ctx *c
     return 0;
 }
 
+int libxl_send_debug_keys(struct libxl_ctx *ctx, char *keys)
+{
+    return xc_send_debug_keys(ctx->xch, keys);
+}
+
 uint32_t libxl_vm_get_start_time(struct libxl_ctx *ctx, uint32_t domid)
 {
     char *dompath = libxl_xs_get_dompath(ctx, domid);
diff -r 5cf04d1c3933 -r f981d865c827 tools/libxl/libxl.h
--- a/tools/libxl/libxl.h       Wed May 19 12:48:32 2010 +0100
+++ b/tools/libxl/libxl.h       Wed May 19 12:51:16 2010 +0100
@@ -511,6 +511,7 @@ int libxl_send_trigger(struct libxl_ctx 
 int libxl_send_trigger(struct libxl_ctx *ctx, uint32_t domid,
                        char *trigger_name, uint32_t vcpuid);
 int libxl_send_sysrq(struct libxl_ctx *ctx, uint32_t domid, char sysrq);
+int libxl_send_debug_keys(struct libxl_ctx *ctx, char *keys);
 uint32_t libxl_vm_get_start_time(struct libxl_ctx *ctx, uint32_t domid);
 
 char *libxl_tmem_list(struct libxl_ctx *ctx, uint32_t domid, int use_long);
diff -r 5cf04d1c3933 -r f981d865c827 tools/libxl/xl_cmdimpl.c
--- a/tools/libxl/xl_cmdimpl.c  Wed May 19 12:48:32 2010 +0100
+++ b/tools/libxl/xl_cmdimpl.c  Wed May 19 12:51:16 2010 +0100
@@ -3212,6 +3212,36 @@ int main_sysrq(int argc, char **argv)
     exit(0);
 }
 
+int main_debug_keys(int argc, char **argv)
+{
+    int opt;
+    char *keys;
+
+    while ((opt = getopt(argc, argv, "h")) != -1) {
+        switch (opt) {
+        case 'h':
+            help("debug-keys");
+            exit(0);
+        default:
+            fprintf(stderr, "option not supported\n");
+            break;
+        }
+    }
+    if (optind >= argc) {
+        help("debug-keys");
+        exit(2);
+    }
+
+    keys = argv[optind];
+
+    if (libxl_send_debug_keys(&ctx, keys)) {
+        fprintf(stderr, "cannot send debug keys: %s\n", keys);
+        exit(1);
+    }
+
+    exit(0);
+}
+
 int main_top(int argc, char **argv)
 {
     int opt;
diff -r 5cf04d1c3933 -r f981d865c827 tools/libxl/xl_cmdimpl.h
--- a/tools/libxl/xl_cmdimpl.h  Wed May 19 12:48:32 2010 +0100
+++ b/tools/libxl/xl_cmdimpl.h  Wed May 19 12:51:16 2010 +0100
@@ -44,6 +44,7 @@ int main_rename(int argc, char **argv);
 int main_rename(int argc, char **argv);
 int main_trigger(int argc, char **argv);
 int main_sysrq(int argc, char **argv);
+int main_debug_keys(int argc, char **argv);
 int main_top(int argc, char **argv);
 int main_networkattach(int argc, char **argv);
 int main_networklist(int argc, char **argv);
diff -r 5cf04d1c3933 -r f981d865c827 tools/libxl/xl_cmdtable.c
--- a/tools/libxl/xl_cmdtable.c Wed May 19 12:48:32 2010 +0100
+++ b/tools/libxl/xl_cmdtable.c Wed May 19 12:51:16 2010 +0100
@@ -186,6 +186,11 @@ struct cmd_spec cmd_table[] = {
       "Send a sysrq to a domain",
       "<Domain> <letter>",
     },
+    { "debug-keys",
+      &main_debug_keys,
+      "Send debug keys to Xen",
+      "<Keys>",
+    },
     { "top",
       &main_top,
       "Monitor a host and the domains in real time",
_______________________________________________
Xen-changelog mailing list
Xen-changelog@xxxxxxxxxxxxxxxxxxx
http://lists.xensource.com/xen-changelog
 | 
|  | Lists.xenproject.org is hosted with RackSpace, monitoring our |