Command line support for seccomp with -sandbox (v8)
Signed-off-by: Eduardo Otubo <otubo@linux.vnet.ibm.com> Signed-off-by: Anthony Liguori <aliguori@us.ibm.com> --- v7 -> v8 - Parse options correctly (aliguori)
This commit is contained in:
parent
452dfbef60
commit
7d76ad4fa4
@ -362,6 +362,19 @@ static QemuOptsList qemu_global_opts = {
|
|||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
|
QemuOptsList qemu_sandbox_opts = {
|
||||||
|
.name = "sandbox",
|
||||||
|
.implied_opt_name = "enable",
|
||||||
|
.head = QTAILQ_HEAD_INITIALIZER(qemu_sandbox_opts.head),
|
||||||
|
.desc = {
|
||||||
|
{
|
||||||
|
.name = "enable",
|
||||||
|
.type = QEMU_OPT_BOOL,
|
||||||
|
},
|
||||||
|
{ /* end of list */ }
|
||||||
|
},
|
||||||
|
};
|
||||||
|
|
||||||
static QemuOptsList qemu_mon_opts = {
|
static QemuOptsList qemu_mon_opts = {
|
||||||
.name = "mon",
|
.name = "mon",
|
||||||
.implied_opt_name = "chardev",
|
.implied_opt_name = "chardev",
|
||||||
@ -645,6 +658,7 @@ static QemuOptsList *vm_config_groups[32] = {
|
|||||||
&qemu_machine_opts,
|
&qemu_machine_opts,
|
||||||
&qemu_boot_opts,
|
&qemu_boot_opts,
|
||||||
&qemu_iscsi_opts,
|
&qemu_iscsi_opts,
|
||||||
|
&qemu_sandbox_opts,
|
||||||
NULL,
|
NULL,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -6,6 +6,7 @@
|
|||||||
extern QemuOptsList qemu_fsdev_opts;
|
extern QemuOptsList qemu_fsdev_opts;
|
||||||
extern QemuOptsList qemu_virtfs_opts;
|
extern QemuOptsList qemu_virtfs_opts;
|
||||||
extern QemuOptsList qemu_spice_opts;
|
extern QemuOptsList qemu_spice_opts;
|
||||||
|
extern QemuOptsList qemu_sandbox_opts;
|
||||||
|
|
||||||
QemuOptsList *qemu_find_opts(const char *group);
|
QemuOptsList *qemu_find_opts(const char *group);
|
||||||
QemuOptsList *qemu_find_opts_err(const char *group, Error **errp);
|
QemuOptsList *qemu_find_opts_err(const char *group, Error **errp);
|
||||||
|
@ -2723,6 +2723,16 @@ STEXI
|
|||||||
Old param mode (ARM only).
|
Old param mode (ARM only).
|
||||||
ETEXI
|
ETEXI
|
||||||
|
|
||||||
|
DEF("sandbox", HAS_ARG, QEMU_OPTION_sandbox, \
|
||||||
|
"-sandbox <arg> Enable seccomp mode 2 system call filter (default 'off').\n",
|
||||||
|
QEMU_ARCH_ALL)
|
||||||
|
STEXI
|
||||||
|
@item -sandbox
|
||||||
|
@findex -sandbox
|
||||||
|
Enable Seccomp mode 2 system call filter. 'on' will enable syscall filtering and 'off' will
|
||||||
|
disable it. The default is 'off'.
|
||||||
|
ETEXI
|
||||||
|
|
||||||
DEF("readconfig", HAS_ARG, QEMU_OPTION_readconfig,
|
DEF("readconfig", HAS_ARG, QEMU_OPTION_readconfig,
|
||||||
"-readconfig <file>\n", QEMU_ARCH_ALL)
|
"-readconfig <file>\n", QEMU_ARCH_ALL)
|
||||||
STEXI
|
STEXI
|
||||||
|
38
vl.c
38
vl.c
@ -770,6 +770,26 @@ static int bt_parse(const char *opt)
|
|||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static int parse_sandbox(QemuOpts *opts, void *opaque)
|
||||||
|
{
|
||||||
|
/* FIXME: change this to true for 1.3 */
|
||||||
|
if (qemu_opt_get_bool(opts, "enable", false)) {
|
||||||
|
#ifdef CONFIG_SECCOMP
|
||||||
|
if (seccomp_start() < 0) {
|
||||||
|
qerror_report(ERROR_CLASS_GENERIC_ERROR,
|
||||||
|
"failed to install seccomp syscall filter in the kernel");
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
qerror_report(ERROR_CLASS_GENERIC_ERROR,
|
||||||
|
"sandboxing request but seccomp is not compiled into this build");
|
||||||
|
return -1;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
/***********************************************************/
|
/***********************************************************/
|
||||||
/* QEMU Block devices */
|
/* QEMU Block devices */
|
||||||
|
|
||||||
@ -2349,14 +2369,6 @@ int main(int argc, char **argv, char **envp)
|
|||||||
const char *trace_events = NULL;
|
const char *trace_events = NULL;
|
||||||
const char *trace_file = NULL;
|
const char *trace_file = NULL;
|
||||||
|
|
||||||
#ifdef CONFIG_SECCOMP
|
|
||||||
if (seccomp_start() < 0) {
|
|
||||||
fprintf(stderr,
|
|
||||||
"seccomp: failed to install syscall filter in the kernel\n");
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
atexit(qemu_run_exit_notifiers);
|
atexit(qemu_run_exit_notifiers);
|
||||||
error_set_progname(argv[0]);
|
error_set_progname(argv[0]);
|
||||||
|
|
||||||
@ -3260,6 +3272,12 @@ int main(int argc, char **argv, char **envp)
|
|||||||
case QEMU_OPTION_qtest_log:
|
case QEMU_OPTION_qtest_log:
|
||||||
qtest_log = optarg;
|
qtest_log = optarg;
|
||||||
break;
|
break;
|
||||||
|
case QEMU_OPTION_sandbox:
|
||||||
|
opts = qemu_opts_parse(qemu_find_opts("sandbox"), optarg, 1);
|
||||||
|
if (!opts) {
|
||||||
|
exit(0);
|
||||||
|
}
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
os_parse_cmd_args(popt->index, optarg);
|
os_parse_cmd_args(popt->index, optarg);
|
||||||
}
|
}
|
||||||
@ -3267,6 +3285,10 @@ int main(int argc, char **argv, char **envp)
|
|||||||
}
|
}
|
||||||
loc_set_none();
|
loc_set_none();
|
||||||
|
|
||||||
|
if (qemu_opts_foreach(qemu_find_opts("sandbox"), parse_sandbox, NULL, 0)) {
|
||||||
|
exit(1);
|
||||||
|
}
|
||||||
|
|
||||||
if (machine == NULL) {
|
if (machine == NULL) {
|
||||||
fprintf(stderr, "No machine found.\n");
|
fprintf(stderr, "No machine found.\n");
|
||||||
exit(1);
|
exit(1);
|
||||||
|
Loading…
Reference in New Issue
Block a user