mirror of https://gitee.com/openkylin/qemu.git
fuzz: fix broken qtest check at rcu_disable_atfork
The qtest_enabled check introduced in d6919e4
always returns false, as
it is called prior to configure_accelerators(). Instead of trying to
skip rcu_disable_atfork in qemu_main, simply call rcu_enable_atfork in
the fuzzer, after qemu_main returns.
Reported-by: Thomas Huth <thuth@redhat.com>
Signed-off-by: Alexander Bulekov <alxndr@bu.edu>
Message-Id: <20200618160516.2817-1-alxndr@bu.edu>
Signed-off-by: Thomas Huth <thuth@redhat.com>
This commit is contained in:
parent
eb6490f544
commit
45222b9a90
10
softmmu/vl.c
10
softmmu/vl.c
|
@ -3832,17 +3832,7 @@ void qemu_init(int argc, char **argv, char **envp)
|
||||||
machine_class);
|
machine_class);
|
||||||
|
|
||||||
os_daemonize();
|
os_daemonize();
|
||||||
|
|
||||||
/*
|
|
||||||
* If QTest is enabled, keep the rcu_atfork enabled, since system processes
|
|
||||||
* may be forked testing purposes (e.g. fork-server based fuzzing) The fork
|
|
||||||
* should happen before a signle cpu instruction is executed, to prevent
|
|
||||||
* deadlocks. See commit 73c6e40, rcu: "completely disable pthread_atfork
|
|
||||||
* callbacks as soon as possible"
|
|
||||||
*/
|
|
||||||
if (!qtest_enabled()) {
|
|
||||||
rcu_disable_atfork();
|
rcu_disable_atfork();
|
||||||
}
|
|
||||||
|
|
||||||
if (pid_file && !qemu_write_pidfile(pid_file, &err)) {
|
if (pid_file && !qemu_write_pidfile(pid_file, &err)) {
|
||||||
error_reportf_err(err, "cannot create PID file: ");
|
error_reportf_err(err, "cannot create PID file: ");
|
||||||
|
|
|
@ -211,5 +211,8 @@ int LLVMFuzzerInitialize(int *argc, char ***argv, char ***envp)
|
||||||
|
|
||||||
qemu_init(result.we_wordc, result.we_wordv, NULL);
|
qemu_init(result.we_wordc, result.we_wordv, NULL);
|
||||||
|
|
||||||
|
/* re-enable the rcu atfork, which was previously disabled in qemu_init */
|
||||||
|
rcu_enable_atfork();
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue