]>
git.proxmox.com Git - mirror_qemu.git/blob - fsdev/qemu-fsdev.c
4 * Copyright IBM, Corp. 2010
7 * Gautham R Shenoy <ego@in.ibm.com>
9 * This work is licensed under the terms of the GNU GPL, version 2. See
10 * the COPYING file in the top-level directory.
15 #include "qemu-fsdev.h"
16 #include "qemu-queue.h"
18 #include "qemu-common.h"
19 #include "qemu-config.h"
21 static QTAILQ_HEAD(FsDriverEntry_head
, FsDriverListEntry
) fsdriver_entries
=
22 QTAILQ_HEAD_INITIALIZER(fsdriver_entries
);
24 static FsDriverTable FsDrivers
[] = {
25 { .name
= "local", .ops
= &local_ops
},
26 { .name
= "handle", .ops
= &handle_ops
},
29 int qemu_fsdev_add(QemuOpts
*opts
)
31 struct FsDriverListEntry
*fsle
;
33 const char *fsdev_id
= qemu_opts_id(opts
);
34 const char *fsdriver
= qemu_opt_get(opts
, "fsdriver");
35 const char *path
= qemu_opt_get(opts
, "path");
36 const char *sec_model
= qemu_opt_get(opts
, "security_model");
37 const char *writeout
= qemu_opt_get(opts
, "writeout");
38 bool ro
= qemu_opt_get_bool(opts
, "readonly", 0);
41 fprintf(stderr
, "fsdev: No id specified\n");
46 for (i
= 0; i
< ARRAY_SIZE(FsDrivers
); i
++) {
47 if (strcmp(FsDrivers
[i
].name
, fsdriver
) == 0) {
52 if (i
== ARRAY_SIZE(FsDrivers
)) {
53 fprintf(stderr
, "fsdev: fsdriver %s not found\n", fsdriver
);
57 fprintf(stderr
, "fsdev: No fsdriver specified\n");
61 if (!strcmp(fsdriver
, "local") && !sec_model
) {
62 fprintf(stderr
, "security model not specified, "
63 "local fs needs security model\nvalid options are:"
64 "\tsecurity_model=[passthrough|mapped|none]\n");
68 if (strcmp(fsdriver
, "local") && sec_model
) {
69 fprintf(stderr
, "only local fs driver needs security model\n");
74 fprintf(stderr
, "fsdev: No path specified.\n");
78 fsle
= g_malloc(sizeof(*fsle
));
80 fsle
->fse
.fsdev_id
= g_strdup(fsdev_id
);
81 fsle
->fse
.path
= g_strdup(path
);
82 fsle
->fse
.ops
= FsDrivers
[i
].ops
;
83 fsle
->fse
.export_flags
= 0;
85 if (!strcmp(writeout
, "immediate")) {
86 fsle
->fse
.export_flags
|= V9FS_IMMEDIATE_WRITEOUT
;
90 fsle
->fse
.export_flags
|= V9FS_RDONLY
;
92 fsle
->fse
.export_flags
&= ~V9FS_RDONLY
;
95 if (strcmp(fsdriver
, "local")) {
99 if (!strcmp(sec_model
, "passthrough")) {
100 fsle
->fse
.export_flags
|= V9FS_SM_PASSTHROUGH
;
101 } else if (!strcmp(sec_model
, "mapped")) {
102 fsle
->fse
.export_flags
|= V9FS_SM_MAPPED
;
103 } else if (!strcmp(sec_model
, "none")) {
104 fsle
->fse
.export_flags
|= V9FS_SM_NONE
;
106 fprintf(stderr
, "Invalid security model %s specified, valid options are"
107 "\n\t [passthrough|mapped|none]\n", sec_model
);
111 QTAILQ_INSERT_TAIL(&fsdriver_entries
, fsle
, next
);
115 FsDriverEntry
*get_fsdev_fsentry(char *id
)
118 struct FsDriverListEntry
*fsle
;
120 QTAILQ_FOREACH(fsle
, &fsdriver_entries
, next
) {
121 if (strcmp(fsle
->fse
.fsdev_id
, id
) == 0) {
129 static void fsdev_register_config(void)
131 qemu_add_opts(&qemu_fsdev_opts
);
132 qemu_add_opts(&qemu_virtfs_opts
);
134 machine_init(fsdev_register_config
);