提交 e14ea479 编写于 作者: S Stefan Hajnoczi 提交者: Venkateswararao Jujjuri

vl.c: Replace -virtfs string manipulation with QemuOpts

The -virtfs option creates an fsdev representing the pass-through file
system and a guest-visible virtio-9p-pci device that can access this
file system.  This patch replaces the string manipulation used to build
and reparse option lists with direct QemuOpts calls.  Removing the
string manipulation code makes it easier to maintain and less error
prone.

An error message is also updated to use "mount_tag" instead of
"mnt_tag".
Signed-off-by: NStefan Hajnoczi <stefanha@linux.vnet.ibm.com>
Signed-off-by: NVenkateswararao Jujjuri <jvrao@linux.vnet.ibm.com>
上级 4f8dee2d
...@@ -2447,9 +2447,8 @@ int main(int argc, char **argv, char **envp) ...@@ -2447,9 +2447,8 @@ int main(int argc, char **argv, char **envp)
} }
break; break;
case QEMU_OPTION_virtfs: { case QEMU_OPTION_virtfs: {
char *arg_fsdev = NULL; QemuOpts *fsdev;
char *arg_9p = NULL; QemuOpts *device;
int len = 0;
olist = qemu_find_opts("virtfs"); olist = qemu_find_opts("virtfs");
if (!olist) { if (!olist) {
...@@ -2468,45 +2467,28 @@ int main(int argc, char **argv, char **envp) ...@@ -2468,45 +2467,28 @@ int main(int argc, char **argv, char **envp)
qemu_opt_get(opts, "security_model") == NULL) { qemu_opt_get(opts, "security_model") == NULL) {
fprintf(stderr, "Usage: -virtfs fstype,path=/share_path/," fprintf(stderr, "Usage: -virtfs fstype,path=/share_path/,"
"security_model=[mapped|passthrough|none]," "security_model=[mapped|passthrough|none],"
"mnt_tag=tag.\n"); "mount_tag=tag.\n");
exit(1); exit(1);
} }
len = strlen(",id=,path=,security_model="); fsdev = qemu_opts_create(qemu_find_opts("fsdev"),
len += strlen(qemu_opt_get(opts, "fstype")); qemu_opt_get(opts, "mount_tag"), 1);
len += strlen(qemu_opt_get(opts, "mount_tag")); if (!fsdev) {
len += strlen(qemu_opt_get(opts, "path")); fprintf(stderr, "duplicate fsdev id: %s\n",
len += strlen(qemu_opt_get(opts, "security_model")); qemu_opt_get(opts, "mount_tag"));
arg_fsdev = qemu_malloc((len + 1) * sizeof(*arg_fsdev));
snprintf(arg_fsdev, (len + 1) * sizeof(*arg_fsdev),
"%s,id=%s,path=%s,security_model=%s",
qemu_opt_get(opts, "fstype"),
qemu_opt_get(opts, "mount_tag"),
qemu_opt_get(opts, "path"),
qemu_opt_get(opts, "security_model"));
len = strlen("virtio-9p,fsdev=,mount_tag=");
len += 2*strlen(qemu_opt_get(opts, "mount_tag"));
arg_9p = qemu_malloc((len + 1) * sizeof(*arg_9p));
snprintf(arg_9p, (len + 1) * sizeof(*arg_9p),
"virtio-9p,fsdev=%s,mount_tag=%s",
qemu_opt_get(opts, "mount_tag"),
qemu_opt_get(opts, "mount_tag"));
if (!qemu_opts_parse(qemu_find_opts("fsdev"), arg_fsdev, 1)) {
fprintf(stderr, "parse error [fsdev]: %s\n", optarg);
exit(1); exit(1);
} }
qemu_opt_set(fsdev, "fstype", qemu_opt_get(opts, "fstype"));
if (!qemu_opts_parse(qemu_find_opts("device"), arg_9p, 1)) { qemu_opt_set(fsdev, "path", qemu_opt_get(opts, "path"));
fprintf(stderr, "parse error [device]: %s\n", optarg); qemu_opt_set(fsdev, "security_model",
exit(1); qemu_opt_get(opts, "security_model"));
}
device = qemu_opts_create(qemu_find_opts("device"), NULL, 0);
qemu_free(arg_fsdev); qemu_opt_set(device, "driver", "virtio-9p-pci");
qemu_free(arg_9p); qemu_opt_set(device, "fsdev",
qemu_opt_get(opts, "mount_tag"));
qemu_opt_set(device, "mount_tag",
qemu_opt_get(opts, "mount_tag"));
break; break;
} }
case QEMU_OPTION_serial: case QEMU_OPTION_serial:
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册