log: Fix qemu_set_log_filename() error handling
When qemu_set_log_filename() detects an invalid file name, it reports an error, closes the log file (if any), and starts logging to stderr (unless daemonized or nothing is being logged). This is wrong. Asking for an invalid log file on the command line should be fatal. Asking for one in the monitor should fail without messing up an existing logfile. Fix by converting qemu_set_log_filename() to Error. Pass it &error_fatal, except for hmp_logfile report errors. This also permits testing without a subprocess, so do that. Signed-off-by: Markus Armbruster <armbru@redhat.com> Message-Id: <1466011636-6112-4-git-send-email-armbru@redhat.com> Reviewed-by: Eric Blake <eblake@redhat.com>
This commit is contained in:
		| @@ -21,6 +21,7 @@ | ||||
| #include <sys/syscall.h> | ||||
| #include <sys/resource.h> | ||||
|  | ||||
| #include "qapi/error.h" | ||||
| #include "qemu.h" | ||||
| #include "qemu/path.h" | ||||
| #include "qemu/cutils.h" | ||||
| @@ -3845,7 +3846,7 @@ static void handle_arg_log(const char *arg) | ||||
|  | ||||
| static void handle_arg_log_filename(const char *arg) | ||||
| { | ||||
|     qemu_set_log_filename(arg); | ||||
|     qemu_set_log_filename(arg, &error_fatal); | ||||
| } | ||||
|  | ||||
| static void handle_arg_set_env(const char *arg) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user