|
|
9ae3a8 |
From df682d833654f2f42595d6156341439644a8848d Mon Sep 17 00:00:00 2001
|
|
|
9ae3a8 |
From: John Snow <jsnow@redhat.com>
|
|
|
9ae3a8 |
Date: Mon, 23 Nov 2015 17:38:30 +0100
|
|
|
9ae3a8 |
Subject: [PATCH 11/27] qemu-io: Move functions for registering and running
|
|
|
9ae3a8 |
commands
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
RH-Author: John Snow <jsnow@redhat.com>
|
|
|
9ae3a8 |
Message-id: <1448300320-7772-12-git-send-email-jsnow@redhat.com>
|
|
|
9ae3a8 |
Patchwork-id: 68439
|
|
|
9ae3a8 |
O-Subject: [RHEL-7.3 qemu-kvm PATCH v2 11/21] qemu-io: Move functions for registering and running commands
|
|
|
9ae3a8 |
Bugzilla: 1272523
|
|
|
9ae3a8 |
RH-Acked-by: Thomas Huth <thuth@redhat.com>
|
|
|
9ae3a8 |
RH-Acked-by: Laszlo Ersek <lersek@redhat.com>
|
|
|
9ae3a8 |
RH-Acked-by: Max Reitz <mreitz@redhat.com>
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
From: Kevin Wolf <kwolf@redhat.com>
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
Signed-off-by: Kevin Wolf <kwolf@redhat.com>
|
|
|
9ae3a8 |
Reviewed-by: Eric Blake <eblake@redhat.com>
|
|
|
9ae3a8 |
Signed-off-by: Stefan Hajnoczi <stefanha@redhat.com>
|
|
|
9ae3a8 |
(cherry picked from commit c2cdf5c5892165cbe7d3567bff5930521bc52669)
|
|
|
9ae3a8 |
Signed-off-by: John Snow <jsnow@redhat.com>
|
|
|
9ae3a8 |
Signed-off-by: Miroslav Rezanina <mrezanin@redhat.com>
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
Conflicts:
|
|
|
9ae3a8 |
qemu-io-cmds.c: Conflicts over sleep_f, again.
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
Signed-off-by: John Snow <jsnow@redhat.com>
|
|
|
9ae3a8 |
---
|
|
|
9ae3a8 |
cmd.c | 113 ---------------------------------
|
|
|
9ae3a8 |
cmd.h | 11 +---
|
|
|
9ae3a8 |
qemu-io-cmds.c | 194 +++++++++++++++++++++++++++++++++++++++++----------------
|
|
|
9ae3a8 |
qemu-io.c | 10 +--
|
|
|
9ae3a8 |
4 files changed, 149 insertions(+), 179 deletions(-)
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
diff --git a/cmd.c b/cmd.c
|
|
|
9ae3a8 |
index f6bf2c5..6616d61 100644
|
|
|
9ae3a8 |
--- a/cmd.c
|
|
|
9ae3a8 |
+++ b/cmd.c
|
|
|
9ae3a8 |
@@ -31,94 +31,9 @@
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
/* from libxcmd/command.c */
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
-cmdinfo_t *cmdtab;
|
|
|
9ae3a8 |
-int ncmds;
|
|
|
9ae3a8 |
-
|
|
|
9ae3a8 |
-static checkfunc_t check_func;
|
|
|
9ae3a8 |
static int ncmdline;
|
|
|
9ae3a8 |
static char **cmdline;
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
-static int
|
|
|
9ae3a8 |
-compare(const void *a, const void *b)
|
|
|
9ae3a8 |
-{
|
|
|
9ae3a8 |
- return strcmp(((const cmdinfo_t *)a)->name,
|
|
|
9ae3a8 |
- ((const cmdinfo_t *)b)->name);
|
|
|
9ae3a8 |
-}
|
|
|
9ae3a8 |
-
|
|
|
9ae3a8 |
-void add_command(const cmdinfo_t *ci)
|
|
|
9ae3a8 |
-{
|
|
|
9ae3a8 |
- cmdtab = g_realloc((void *)cmdtab, ++ncmds * sizeof(*cmdtab));
|
|
|
9ae3a8 |
- cmdtab[ncmds - 1] = *ci;
|
|
|
9ae3a8 |
- qsort(cmdtab, ncmds, sizeof(*cmdtab), compare);
|
|
|
9ae3a8 |
-}
|
|
|
9ae3a8 |
-
|
|
|
9ae3a8 |
-static int
|
|
|
9ae3a8 |
-check_command(
|
|
|
9ae3a8 |
- const cmdinfo_t *ci)
|
|
|
9ae3a8 |
-{
|
|
|
9ae3a8 |
- if (check_func)
|
|
|
9ae3a8 |
- return check_func(qemuio_bs, ci);
|
|
|
9ae3a8 |
- return 1;
|
|
|
9ae3a8 |
-}
|
|
|
9ae3a8 |
-
|
|
|
9ae3a8 |
-void
|
|
|
9ae3a8 |
-add_check_command(
|
|
|
9ae3a8 |
- checkfunc_t cf)
|
|
|
9ae3a8 |
-{
|
|
|
9ae3a8 |
- check_func = cf;
|
|
|
9ae3a8 |
-}
|
|
|
9ae3a8 |
-
|
|
|
9ae3a8 |
-int
|
|
|
9ae3a8 |
-command_usage(
|
|
|
9ae3a8 |
- const cmdinfo_t *ci)
|
|
|
9ae3a8 |
-{
|
|
|
9ae3a8 |
- printf("%s %s -- %s\n", ci->name, ci->args, ci->oneline);
|
|
|
9ae3a8 |
- return 0;
|
|
|
9ae3a8 |
-}
|
|
|
9ae3a8 |
-
|
|
|
9ae3a8 |
-int
|
|
|
9ae3a8 |
-command(
|
|
|
9ae3a8 |
- const cmdinfo_t *ct,
|
|
|
9ae3a8 |
- int argc,
|
|
|
9ae3a8 |
- char **argv)
|
|
|
9ae3a8 |
-{
|
|
|
9ae3a8 |
- char *cmd = argv[0];
|
|
|
9ae3a8 |
-
|
|
|
9ae3a8 |
- if (!check_command(ct))
|
|
|
9ae3a8 |
- return 0;
|
|
|
9ae3a8 |
-
|
|
|
9ae3a8 |
- if (argc-1 < ct->argmin || (ct->argmax != -1 && argc-1 > ct->argmax)) {
|
|
|
9ae3a8 |
- if (ct->argmax == -1)
|
|
|
9ae3a8 |
- fprintf(stderr,
|
|
|
9ae3a8 |
- _("bad argument count %d to %s, expected at least %d arguments\n"),
|
|
|
9ae3a8 |
- argc-1, cmd, ct->argmin);
|
|
|
9ae3a8 |
- else if (ct->argmin == ct->argmax)
|
|
|
9ae3a8 |
- fprintf(stderr,
|
|
|
9ae3a8 |
- _("bad argument count %d to %s, expected %d arguments\n"),
|
|
|
9ae3a8 |
- argc-1, cmd, ct->argmin);
|
|
|
9ae3a8 |
- else
|
|
|
9ae3a8 |
- fprintf(stderr,
|
|
|
9ae3a8 |
- _("bad argument count %d to %s, expected between %d and %d arguments\n"),
|
|
|
9ae3a8 |
- argc-1, cmd, ct->argmin, ct->argmax);
|
|
|
9ae3a8 |
- return 0;
|
|
|
9ae3a8 |
- }
|
|
|
9ae3a8 |
- optind = 0;
|
|
|
9ae3a8 |
- return ct->cfunc(qemuio_bs, argc, argv);
|
|
|
9ae3a8 |
-}
|
|
|
9ae3a8 |
-
|
|
|
9ae3a8 |
-const cmdinfo_t *
|
|
|
9ae3a8 |
-find_command(
|
|
|
9ae3a8 |
- const char *cmd)
|
|
|
9ae3a8 |
-{
|
|
|
9ae3a8 |
- cmdinfo_t *ct;
|
|
|
9ae3a8 |
-
|
|
|
9ae3a8 |
- for (ct = cmdtab; ct < &cmdtab[ncmds]; ct++) {
|
|
|
9ae3a8 |
- if (strcmp(ct->name, cmd) == 0 ||
|
|
|
9ae3a8 |
- (ct->altname && strcmp(ct->altname, cmd) == 0))
|
|
|
9ae3a8 |
- return (const cmdinfo_t *)ct;
|
|
|
9ae3a8 |
- }
|
|
|
9ae3a8 |
- return NULL;
|
|
|
9ae3a8 |
-}
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
void add_user_command(char *optarg)
|
|
|
9ae3a8 |
{
|
|
|
9ae3a8 |
@@ -255,34 +170,6 @@ fetchline(void)
|
|
|
9ae3a8 |
}
|
|
|
9ae3a8 |
#endif
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
-char **breakline(char *input, int *count)
|
|
|
9ae3a8 |
-{
|
|
|
9ae3a8 |
- int c = 0;
|
|
|
9ae3a8 |
- char *p;
|
|
|
9ae3a8 |
- char **rval = calloc(sizeof(char *), 1);
|
|
|
9ae3a8 |
- char **tmp;
|
|
|
9ae3a8 |
-
|
|
|
9ae3a8 |
- while (rval && (p = qemu_strsep(&input, " ")) != NULL) {
|
|
|
9ae3a8 |
- if (!*p) {
|
|
|
9ae3a8 |
- continue;
|
|
|
9ae3a8 |
- }
|
|
|
9ae3a8 |
- c++;
|
|
|
9ae3a8 |
- tmp = realloc(rval, sizeof(*rval) * (c + 1));
|
|
|
9ae3a8 |
- if (!tmp) {
|
|
|
9ae3a8 |
- free(rval);
|
|
|
9ae3a8 |
- rval = NULL;
|
|
|
9ae3a8 |
- c = 0;
|
|
|
9ae3a8 |
- break;
|
|
|
9ae3a8 |
- } else {
|
|
|
9ae3a8 |
- rval = tmp;
|
|
|
9ae3a8 |
- }
|
|
|
9ae3a8 |
- rval[c - 1] = p;
|
|
|
9ae3a8 |
- rval[c] = NULL;
|
|
|
9ae3a8 |
- }
|
|
|
9ae3a8 |
- *count = c;
|
|
|
9ae3a8 |
- return rval;
|
|
|
9ae3a8 |
-}
|
|
|
9ae3a8 |
-
|
|
|
9ae3a8 |
#define EXABYTES(x) ((long long)(x) << 60)
|
|
|
9ae3a8 |
#define PETABYTES(x) ((long long)(x) << 50)
|
|
|
9ae3a8 |
#define TERABYTES(x) ((long long)(x) << 40)
|
|
|
9ae3a8 |
diff --git a/cmd.h b/cmd.h
|
|
|
9ae3a8 |
index 5b6f61b..0d01a33 100644
|
|
|
9ae3a8 |
--- a/cmd.h
|
|
|
9ae3a8 |
+++ b/cmd.h
|
|
|
9ae3a8 |
@@ -39,23 +39,16 @@ typedef struct cmdinfo {
|
|
|
9ae3a8 |
helpfunc_t help;
|
|
|
9ae3a8 |
} cmdinfo_t;
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
-extern cmdinfo_t *cmdtab;
|
|
|
9ae3a8 |
-extern int ncmds;
|
|
|
9ae3a8 |
-
|
|
|
9ae3a8 |
typedef int (*checkfunc_t)(BlockDriverState *bs, const cmdinfo_t *ci);
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
-void add_command(const cmdinfo_t *ci);
|
|
|
9ae3a8 |
+void qemuio_add_command(const cmdinfo_t *ci);
|
|
|
9ae3a8 |
void add_user_command(char *optarg);
|
|
|
9ae3a8 |
void add_check_command(checkfunc_t cf);
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
-const cmdinfo_t *find_command(const char *cmd);
|
|
|
9ae3a8 |
-
|
|
|
9ae3a8 |
void command_loop(void);
|
|
|
9ae3a8 |
-int command_usage(const cmdinfo_t *ci);
|
|
|
9ae3a8 |
-int command(const cmdinfo_t *ci, int argc, char **argv);
|
|
|
9ae3a8 |
+int qemuio_command_usage(const cmdinfo_t *ci);
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
/* from input.h */
|
|
|
9ae3a8 |
-char **breakline(char *input, int *count);
|
|
|
9ae3a8 |
char *fetchline(void);
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
void cvtstr(double value, char *str, size_t sz);
|
|
|
9ae3a8 |
diff --git a/qemu-io-cmds.c b/qemu-io-cmds.c
|
|
|
9ae3a8 |
index a8e891a..27a903f 100644
|
|
|
9ae3a8 |
--- a/qemu-io-cmds.c
|
|
|
9ae3a8 |
+++ b/qemu-io-cmds.c
|
|
|
9ae3a8 |
@@ -17,6 +17,110 @@
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
int qemuio_misalign;
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
+static cmdinfo_t *cmdtab;
|
|
|
9ae3a8 |
+static int ncmds;
|
|
|
9ae3a8 |
+
|
|
|
9ae3a8 |
+static int compare_cmdname(const void *a, const void *b)
|
|
|
9ae3a8 |
+{
|
|
|
9ae3a8 |
+ return strcmp(((const cmdinfo_t *)a)->name,
|
|
|
9ae3a8 |
+ ((const cmdinfo_t *)b)->name);
|
|
|
9ae3a8 |
+}
|
|
|
9ae3a8 |
+
|
|
|
9ae3a8 |
+void qemuio_add_command(const cmdinfo_t *ci)
|
|
|
9ae3a8 |
+{
|
|
|
9ae3a8 |
+ cmdtab = g_realloc(cmdtab, ++ncmds * sizeof(*cmdtab));
|
|
|
9ae3a8 |
+ cmdtab[ncmds - 1] = *ci;
|
|
|
9ae3a8 |
+ qsort(cmdtab, ncmds, sizeof(*cmdtab), compare_cmdname);
|
|
|
9ae3a8 |
+}
|
|
|
9ae3a8 |
+
|
|
|
9ae3a8 |
+int qemuio_command_usage(const cmdinfo_t *ci)
|
|
|
9ae3a8 |
+{
|
|
|
9ae3a8 |
+ printf("%s %s -- %s\n", ci->name, ci->args, ci->oneline);
|
|
|
9ae3a8 |
+ return 0;
|
|
|
9ae3a8 |
+}
|
|
|
9ae3a8 |
+
|
|
|
9ae3a8 |
+static int init_check_command(BlockDriverState *bs, const cmdinfo_t *ct)
|
|
|
9ae3a8 |
+{
|
|
|
9ae3a8 |
+ if (ct->flags & CMD_FLAG_GLOBAL) {
|
|
|
9ae3a8 |
+ return 1;
|
|
|
9ae3a8 |
+ }
|
|
|
9ae3a8 |
+ if (!(ct->flags & CMD_NOFILE_OK) && !bs) {
|
|
|
9ae3a8 |
+ fprintf(stderr, "no file open, try 'help open'\n");
|
|
|
9ae3a8 |
+ return 0;
|
|
|
9ae3a8 |
+ }
|
|
|
9ae3a8 |
+ return 1;
|
|
|
9ae3a8 |
+}
|
|
|
9ae3a8 |
+
|
|
|
9ae3a8 |
+static int command(const cmdinfo_t *ct, int argc, char **argv)
|
|
|
9ae3a8 |
+{
|
|
|
9ae3a8 |
+ char *cmd = argv[0];
|
|
|
9ae3a8 |
+
|
|
|
9ae3a8 |
+ if (!init_check_command(qemuio_bs, ct)) {
|
|
|
9ae3a8 |
+ return 0;
|
|
|
9ae3a8 |
+ }
|
|
|
9ae3a8 |
+
|
|
|
9ae3a8 |
+ if (argc - 1 < ct->argmin || (ct->argmax != -1 && argc - 1 > ct->argmax)) {
|
|
|
9ae3a8 |
+ if (ct->argmax == -1) {
|
|
|
9ae3a8 |
+ fprintf(stderr,
|
|
|
9ae3a8 |
+ "bad argument count %d to %s, expected at least %d arguments\n",
|
|
|
9ae3a8 |
+ argc-1, cmd, ct->argmin);
|
|
|
9ae3a8 |
+ } else if (ct->argmin == ct->argmax) {
|
|
|
9ae3a8 |
+ fprintf(stderr,
|
|
|
9ae3a8 |
+ "bad argument count %d to %s, expected %d arguments\n",
|
|
|
9ae3a8 |
+ argc-1, cmd, ct->argmin);
|
|
|
9ae3a8 |
+ } else {
|
|
|
9ae3a8 |
+ fprintf(stderr,
|
|
|
9ae3a8 |
+ "bad argument count %d to %s, expected between %d and %d arguments\n",
|
|
|
9ae3a8 |
+ argc-1, cmd, ct->argmin, ct->argmax);
|
|
|
9ae3a8 |
+ }
|
|
|
9ae3a8 |
+ return 0;
|
|
|
9ae3a8 |
+ }
|
|
|
9ae3a8 |
+ optind = 0;
|
|
|
9ae3a8 |
+ return ct->cfunc(qemuio_bs, argc, argv);
|
|
|
9ae3a8 |
+}
|
|
|
9ae3a8 |
+
|
|
|
9ae3a8 |
+static const cmdinfo_t *find_command(const char *cmd)
|
|
|
9ae3a8 |
+{
|
|
|
9ae3a8 |
+ cmdinfo_t *ct;
|
|
|
9ae3a8 |
+
|
|
|
9ae3a8 |
+ for (ct = cmdtab; ct < &cmdtab[ncmds]; ct++) {
|
|
|
9ae3a8 |
+ if (strcmp(ct->name, cmd) == 0 ||
|
|
|
9ae3a8 |
+ (ct->altname && strcmp(ct->altname, cmd) == 0))
|
|
|
9ae3a8 |
+ {
|
|
|
9ae3a8 |
+ return (const cmdinfo_t *)ct;
|
|
|
9ae3a8 |
+ }
|
|
|
9ae3a8 |
+ }
|
|
|
9ae3a8 |
+ return NULL;
|
|
|
9ae3a8 |
+}
|
|
|
9ae3a8 |
+
|
|
|
9ae3a8 |
+static char **breakline(char *input, int *count)
|
|
|
9ae3a8 |
+{
|
|
|
9ae3a8 |
+ int c = 0;
|
|
|
9ae3a8 |
+ char *p;
|
|
|
9ae3a8 |
+ char **rval = g_malloc0(sizeof(char *));
|
|
|
9ae3a8 |
+ char **tmp;
|
|
|
9ae3a8 |
+
|
|
|
9ae3a8 |
+ while (rval && (p = qemu_strsep(&input, " ")) != NULL) {
|
|
|
9ae3a8 |
+ if (!*p) {
|
|
|
9ae3a8 |
+ continue;
|
|
|
9ae3a8 |
+ }
|
|
|
9ae3a8 |
+ c++;
|
|
|
9ae3a8 |
+ tmp = g_realloc(rval, sizeof(*rval) * (c + 1));
|
|
|
9ae3a8 |
+ if (!tmp) {
|
|
|
9ae3a8 |
+ g_free(rval);
|
|
|
9ae3a8 |
+ rval = NULL;
|
|
|
9ae3a8 |
+ c = 0;
|
|
|
9ae3a8 |
+ break;
|
|
|
9ae3a8 |
+ } else {
|
|
|
9ae3a8 |
+ rval = tmp;
|
|
|
9ae3a8 |
+ }
|
|
|
9ae3a8 |
+ rval[c - 1] = p;
|
|
|
9ae3a8 |
+ rval[c] = NULL;
|
|
|
9ae3a8 |
+ }
|
|
|
9ae3a8 |
+ *count = c;
|
|
|
9ae3a8 |
+ return rval;
|
|
|
9ae3a8 |
+}
|
|
|
9ae3a8 |
+
|
|
|
9ae3a8 |
static int64_t cvtnum(const char *s)
|
|
|
9ae3a8 |
{
|
|
|
9ae3a8 |
char *end;
|
|
|
9ae3a8 |
@@ -468,12 +572,12 @@ static int read_f(BlockDriverState *bs, int argc, char **argv)
|
|
|
9ae3a8 |
vflag = 1;
|
|
|
9ae3a8 |
break;
|
|
|
9ae3a8 |
default:
|
|
|
9ae3a8 |
- return command_usage(&read_cmd);
|
|
|
9ae3a8 |
+ return qemuio_command_usage(&read_cmd);
|
|
|
9ae3a8 |
}
|
|
|
9ae3a8 |
}
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
if (optind != argc - 2) {
|
|
|
9ae3a8 |
- return command_usage(&read_cmd);
|
|
|
9ae3a8 |
+ return qemuio_command_usage(&read_cmd);
|
|
|
9ae3a8 |
}
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
if (bflag && pflag) {
|
|
|
9ae3a8 |
@@ -495,7 +599,7 @@ static int read_f(BlockDriverState *bs, int argc, char **argv)
|
|
|
9ae3a8 |
}
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
if (!Pflag && (lflag || sflag)) {
|
|
|
9ae3a8 |
- return command_usage(&read_cmd);
|
|
|
9ae3a8 |
+ return qemuio_command_usage(&read_cmd);
|
|
|
9ae3a8 |
}
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
if (!lflag) {
|
|
|
9ae3a8 |
@@ -630,12 +734,12 @@ static int readv_f(BlockDriverState *bs, int argc, char **argv)
|
|
|
9ae3a8 |
vflag = 1;
|
|
|
9ae3a8 |
break;
|
|
|
9ae3a8 |
default:
|
|
|
9ae3a8 |
- return command_usage(&readv_cmd);
|
|
|
9ae3a8 |
+ return qemuio_command_usage(&readv_cmd);
|
|
|
9ae3a8 |
}
|
|
|
9ae3a8 |
}
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
if (optind > argc - 2) {
|
|
|
9ae3a8 |
- return command_usage(&readv_cmd);
|
|
|
9ae3a8 |
+ return qemuio_command_usage(&readv_cmd);
|
|
|
9ae3a8 |
}
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
@@ -770,12 +874,12 @@ static int write_f(BlockDriverState *bs, int argc, char **argv)
|
|
|
9ae3a8 |
zflag = 1;
|
|
|
9ae3a8 |
break;
|
|
|
9ae3a8 |
default:
|
|
|
9ae3a8 |
- return command_usage(&write_cmd);
|
|
|
9ae3a8 |
+ return qemuio_command_usage(&write_cmd);
|
|
|
9ae3a8 |
}
|
|
|
9ae3a8 |
}
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
if (optind != argc - 2) {
|
|
|
9ae3a8 |
- return command_usage(&write_cmd);
|
|
|
9ae3a8 |
+ return qemuio_command_usage(&write_cmd);
|
|
|
9ae3a8 |
}
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
if (bflag + pflag + zflag > 1) {
|
|
|
9ae3a8 |
@@ -912,12 +1016,12 @@ static int writev_f(BlockDriverState *bs, int argc, char **argv)
|
|
|
9ae3a8 |
}
|
|
|
9ae3a8 |
break;
|
|
|
9ae3a8 |
default:
|
|
|
9ae3a8 |
- return command_usage(&writev_cmd);
|
|
|
9ae3a8 |
+ return qemuio_command_usage(&writev_cmd);
|
|
|
9ae3a8 |
}
|
|
|
9ae3a8 |
}
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
if (optind > argc - 2) {
|
|
|
9ae3a8 |
- return command_usage(&writev_cmd);
|
|
|
9ae3a8 |
+ return qemuio_command_usage(&writev_cmd);
|
|
|
9ae3a8 |
}
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
offset = cvtnum(argv[optind]);
|
|
|
9ae3a8 |
@@ -1024,12 +1128,12 @@ static int multiwrite_f(BlockDriverState *bs, int argc, char **argv)
|
|
|
9ae3a8 |
}
|
|
|
9ae3a8 |
break;
|
|
|
9ae3a8 |
default:
|
|
|
9ae3a8 |
- return command_usage(&writev_cmd);
|
|
|
9ae3a8 |
+ return qemuio_command_usage(&writev_cmd);
|
|
|
9ae3a8 |
}
|
|
|
9ae3a8 |
}
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
if (optind > argc - 2) {
|
|
|
9ae3a8 |
- return command_usage(&writev_cmd);
|
|
|
9ae3a8 |
+ return qemuio_command_usage(&writev_cmd);
|
|
|
9ae3a8 |
}
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
nr_reqs = 1;
|
|
|
9ae3a8 |
@@ -1258,13 +1362,13 @@ static int aio_read_f(BlockDriverState *bs, int argc, char **argv)
|
|
|
9ae3a8 |
break;
|
|
|
9ae3a8 |
default:
|
|
|
9ae3a8 |
g_free(ctx);
|
|
|
9ae3a8 |
- return command_usage(&aio_read_cmd);
|
|
|
9ae3a8 |
+ return qemuio_command_usage(&aio_read_cmd);
|
|
|
9ae3a8 |
}
|
|
|
9ae3a8 |
}
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
if (optind > argc - 2) {
|
|
|
9ae3a8 |
g_free(ctx);
|
|
|
9ae3a8 |
- return command_usage(&aio_read_cmd);
|
|
|
9ae3a8 |
+ return qemuio_command_usage(&aio_read_cmd);
|
|
|
9ae3a8 |
}
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
ctx->offset = cvtnum(argv[optind]);
|
|
|
9ae3a8 |
@@ -1350,13 +1454,13 @@ static int aio_write_f(BlockDriverState *bs, int argc, char **argv)
|
|
|
9ae3a8 |
break;
|
|
|
9ae3a8 |
default:
|
|
|
9ae3a8 |
g_free(ctx);
|
|
|
9ae3a8 |
- return command_usage(&aio_write_cmd);
|
|
|
9ae3a8 |
+ return qemuio_command_usage(&aio_write_cmd);
|
|
|
9ae3a8 |
}
|
|
|
9ae3a8 |
}
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
if (optind > argc - 2) {
|
|
|
9ae3a8 |
g_free(ctx);
|
|
|
9ae3a8 |
- return command_usage(&aio_write_cmd);
|
|
|
9ae3a8 |
+ return qemuio_command_usage(&aio_write_cmd);
|
|
|
9ae3a8 |
}
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
ctx->offset = cvtnum(argv[optind]);
|
|
|
9ae3a8 |
@@ -1556,12 +1660,12 @@ static int discard_f(BlockDriverState *bs, int argc, char **argv)
|
|
|
9ae3a8 |
qflag = 1;
|
|
|
9ae3a8 |
break;
|
|
|
9ae3a8 |
default:
|
|
|
9ae3a8 |
- return command_usage(&discard_cmd);
|
|
|
9ae3a8 |
+ return qemuio_command_usage(&discard_cmd);
|
|
|
9ae3a8 |
}
|
|
|
9ae3a8 |
}
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
if (optind != argc - 2) {
|
|
|
9ae3a8 |
- return command_usage(&discard_cmd);
|
|
|
9ae3a8 |
+ return qemuio_command_usage(&discard_cmd);
|
|
|
9ae3a8 |
}
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
offset = cvtnum(argv[optind]);
|
|
|
9ae3a8 |
@@ -1876,18 +1980,6 @@ static const cmdinfo_t help_cmd = {
|
|
|
9ae3a8 |
.oneline = "help for one or all commands",
|
|
|
9ae3a8 |
};
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
-static int init_check_command(BlockDriverState *bs, const cmdinfo_t *ct)
|
|
|
9ae3a8 |
-{
|
|
|
9ae3a8 |
- if (ct->flags & CMD_FLAG_GLOBAL) {
|
|
|
9ae3a8 |
- return 1;
|
|
|
9ae3a8 |
- }
|
|
|
9ae3a8 |
- if (!(ct->flags & CMD_NOFILE_OK) && !bs) {
|
|
|
9ae3a8 |
- fprintf(stderr, "no file open, try 'help open'\n");
|
|
|
9ae3a8 |
- return 0;
|
|
|
9ae3a8 |
- }
|
|
|
9ae3a8 |
- return 1;
|
|
|
9ae3a8 |
-}
|
|
|
9ae3a8 |
-
|
|
|
9ae3a8 |
bool qemuio_command(const char *cmd)
|
|
|
9ae3a8 |
{
|
|
|
9ae3a8 |
char *input;
|
|
|
9ae3a8 |
@@ -1915,27 +2007,25 @@ bool qemuio_command(const char *cmd)
|
|
|
9ae3a8 |
static void __attribute((constructor)) init_qemuio_commands(void)
|
|
|
9ae3a8 |
{
|
|
|
9ae3a8 |
/* initialize commands */
|
|
|
9ae3a8 |
- add_command(&help_cmd);
|
|
|
9ae3a8 |
- add_command(&read_cmd);
|
|
|
9ae3a8 |
- add_command(&readv_cmd);
|
|
|
9ae3a8 |
- add_command(&write_cmd);
|
|
|
9ae3a8 |
- add_command(&writev_cmd);
|
|
|
9ae3a8 |
- add_command(&multiwrite_cmd);
|
|
|
9ae3a8 |
- add_command(&aio_read_cmd);
|
|
|
9ae3a8 |
- add_command(&aio_write_cmd);
|
|
|
9ae3a8 |
- add_command(&aio_flush_cmd);
|
|
|
9ae3a8 |
- add_command(&flush_cmd);
|
|
|
9ae3a8 |
- add_command(&truncate_cmd);
|
|
|
9ae3a8 |
- add_command(&length_cmd);
|
|
|
9ae3a8 |
- add_command(&info_cmd);
|
|
|
9ae3a8 |
- add_command(&discard_cmd);
|
|
|
9ae3a8 |
- add_command(&alloc_cmd);
|
|
|
9ae3a8 |
- add_command(&map_cmd);
|
|
|
9ae3a8 |
- add_command(&break_cmd);
|
|
|
9ae3a8 |
- add_command(&resume_cmd);
|
|
|
9ae3a8 |
- add_command(&wait_break_cmd);
|
|
|
9ae3a8 |
- add_command(&abort_cmd);
|
|
|
9ae3a8 |
- add_command(&sleep_cmd);
|
|
|
9ae3a8 |
-
|
|
|
9ae3a8 |
- add_check_command(init_check_command);
|
|
|
9ae3a8 |
+ qemuio_add_command(&help_cmd);
|
|
|
9ae3a8 |
+ qemuio_add_command(&read_cmd);
|
|
|
9ae3a8 |
+ qemuio_add_command(&readv_cmd);
|
|
|
9ae3a8 |
+ qemuio_add_command(&write_cmd);
|
|
|
9ae3a8 |
+ qemuio_add_command(&writev_cmd);
|
|
|
9ae3a8 |
+ qemuio_add_command(&multiwrite_cmd);
|
|
|
9ae3a8 |
+ qemuio_add_command(&aio_read_cmd);
|
|
|
9ae3a8 |
+ qemuio_add_command(&aio_write_cmd);
|
|
|
9ae3a8 |
+ qemuio_add_command(&aio_flush_cmd);
|
|
|
9ae3a8 |
+ qemuio_add_command(&flush_cmd);
|
|
|
9ae3a8 |
+ qemuio_add_command(&truncate_cmd);
|
|
|
9ae3a8 |
+ qemuio_add_command(&length_cmd);
|
|
|
9ae3a8 |
+ qemuio_add_command(&info_cmd);
|
|
|
9ae3a8 |
+ qemuio_add_command(&discard_cmd);
|
|
|
9ae3a8 |
+ qemuio_add_command(&alloc_cmd);
|
|
|
9ae3a8 |
+ qemuio_add_command(&map_cmd);
|
|
|
9ae3a8 |
+ qemuio_add_command(&break_cmd);
|
|
|
9ae3a8 |
+ qemuio_add_command(&resume_cmd);
|
|
|
9ae3a8 |
+ qemuio_add_command(&wait_break_cmd);
|
|
|
9ae3a8 |
+ qemuio_add_command(&abort_cmd);
|
|
|
9ae3a8 |
+ qemuio_add_command(&sleep_cmd);
|
|
|
9ae3a8 |
}
|
|
|
9ae3a8 |
diff --git a/qemu-io.c b/qemu-io.c
|
|
|
9ae3a8 |
index b86bfbf..97af39e 100644
|
|
|
9ae3a8 |
--- a/qemu-io.c
|
|
|
9ae3a8 |
+++ b/qemu-io.c
|
|
|
9ae3a8 |
@@ -155,7 +155,7 @@ static int open_f(BlockDriverState *bs, int argc, char **argv)
|
|
|
9ae3a8 |
qemu_opts_del(qopts);
|
|
|
9ae3a8 |
break;
|
|
|
9ae3a8 |
default:
|
|
|
9ae3a8 |
- return command_usage(&open_cmd);
|
|
|
9ae3a8 |
+ return qemuio_command_usage(&open_cmd);
|
|
|
9ae3a8 |
}
|
|
|
9ae3a8 |
}
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
@@ -164,7 +164,7 @@ static int open_f(BlockDriverState *bs, int argc, char **argv)
|
|
|
9ae3a8 |
}
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
if (optind != argc - 1) {
|
|
|
9ae3a8 |
- return command_usage(&open_cmd);
|
|
|
9ae3a8 |
+ return qemuio_command_usage(&open_cmd);
|
|
|
9ae3a8 |
}
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
return openfile(argv[optind], flags, growable, opts);
|
|
|
9ae3a8 |
@@ -300,9 +300,9 @@ int main(int argc, char **argv)
|
|
|
9ae3a8 |
bdrv_init();
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
/* initialize commands */
|
|
|
9ae3a8 |
- add_command(&quit_cmd);
|
|
|
9ae3a8 |
- add_command(&open_cmd);
|
|
|
9ae3a8 |
- add_command(&close_cmd);
|
|
|
9ae3a8 |
+ qemuio_add_command(&quit_cmd);
|
|
|
9ae3a8 |
+ qemuio_add_command(&open_cmd);
|
|
|
9ae3a8 |
+ qemuio_add_command(&close_cmd);
|
|
|
9ae3a8 |
|
|
|
9ae3a8 |
/* open the device */
|
|
|
9ae3a8 |
if (!readonly) {
|
|
|
9ae3a8 |
--
|
|
|
9ae3a8 |
1.8.3.1
|
|
|
9ae3a8 |
|