]> xenbits.xensource.com Git - xen.git/commitdiff
xl: Add "xl sysrq" command, a clone of "xm sysrq".
authorKeir Fraser <keir.fraser@citrix.com>
Wed, 12 May 2010 07:52:07 +0000 (08:52 +0100)
committerKeir Fraser <keir.fraser@citrix.com>
Wed, 12 May 2010 07:52:07 +0000 (08:52 +0100)
Signed-off-by: Yang Hongyang <yanghy@cn.fujitsu.com>
tools/libxl/libxl.c
tools/libxl/libxl.h
tools/libxl/xl_cmdimpl.c
tools/libxl/xl_cmdimpl.h
tools/libxl/xl_cmdtable.c

index 1b09294016a9c1fc7c126c1ef41e81cd0047264f..e031582083b0cc4f76f71ed04ad5d42bd34ebb0b 100644 (file)
@@ -2629,3 +2629,13 @@ int libxl_send_trigger(struct libxl_ctx *ctx, uint32_t domid, char *trigger_name
 
     return rc;
 }
+
+int libxl_send_sysrq(struct libxl_ctx *ctx, uint32_t domid, char sysrq)
+{
+    char *dompath = libxl_xs_get_dompath(ctx, domid);
+
+    libxl_xs_write(ctx, XBT_NULL, libxl_sprintf(ctx, "%s/control/sysrq", dompath), "%c", sysrq);
+
+    return 0;
+}
+
index 198d98daf29ea092128a9d024ddf4409c9cfe5a5..ffed896f454d635eb6a1f88b2f519a287c96dbde 100644 (file)
@@ -481,5 +481,6 @@ int libxl_sched_credit_domain_set(struct libxl_ctx *ctx, uint32_t domid,
                                   struct libxl_sched_credit *scinfo);
 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);
 #endif /* LIBXL_H */
 
index f1e03913fac6626a6fe9e5cf9c3dee6d741bdca8..1e2304756ea8e46afd38f2bd8b3c1474b45b4103 100644 (file)
@@ -3058,3 +3058,43 @@ int main_trigger(int argc, char **argv)
 
     exit(0);
 }
+
+
+int main_sysrq(int argc, char **argv)
+{
+    int opt;
+    char *sysrq = NULL;
+    char *dom = NULL;
+
+    while ((opt = getopt(argc, argv, "h")) != -1) {
+        switch (opt) {
+        case 'h':
+            help("sysrq");
+            exit(0);
+        default:
+            fprintf(stderr, "option `%c' not supported.\n", opt);
+            break;
+        }
+    }
+
+    dom = argv[optind++];
+    if (!dom || !argv[optind]) {
+        fprintf(stderr, "'xl sysrq' requires 2 arguments.\n\n");
+        help("sysrq");
+        exit(1);
+    }
+
+    find_domain(dom);
+
+    sysrq = argv[optind];
+
+    if (sysrq[1] != '\0') {
+        fprintf(stderr, "Invalid sysrq.\n\n");
+        help("sysrq");
+        exit(1);
+    }
+
+    libxl_send_sysrq(&ctx, domid, sysrq[0]);
+
+    exit(0);
+}
index c53ba4e4b8f5c60526fdbfb952fcd8d80eaa223d..c08c5d1593c6e5e227cea06f00694d600bbac950 100644 (file)
@@ -39,5 +39,6 @@ int main_domid(int argc, char **argv);
 int main_domname(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);
 
 void help(char *command);
index 3c43094631e6cf430b0d28fdbbeb551c7706a533..33582a79d93baf131d305ff4809a097c43604dd0 100644 (file)
@@ -172,6 +172,11 @@ struct cmd_spec cmd_table[] = {
       "Send a trigger to a domain",
       "<Domain> <nmi|reset|init|power|sleep> [<VCPU>]",
     },
+    { "sysrq",
+      &main_sysrq,
+      "Send a sysrq to a domain",
+      "<Domain> <letter>",
+    },
 };
 
 int cmdtable_len = sizeof(cmd_table)/sizeof(struct cmd_spec);