diff options
author | Richard Henderson | 2016-09-23 00:17:10 +0200 |
---|---|---|
committer | Richard Henderson | 2016-11-01 17:29:03 +0100 |
commit | 1ee73216f4ccd2f3b6eb818feb165b3cf5a1944c (patch) | |
tree | c4bf6e9433b8c0104e384233fa09a78346673709 /include/sysemu/os-win32.h | |
parent | target-openrisc: Do not dump cpu state with -d in_asm (diff) | |
download | qemu-1ee73216f4ccd2f3b6eb818feb165b3cf5a1944c.tar.gz qemu-1ee73216f4ccd2f3b6eb818feb165b3cf5a1944c.tar.xz qemu-1ee73216f4ccd2f3b6eb818feb165b3cf5a1944c.zip |
log: Add locking to large logging blocks
Reuse the existing locking provided by stdio to keep in_asm, cpu,
op, op_opt, op_ind, and out_asm as contiguous blocks.
While it isn't possible to interleave e.g. in_asm or op_opt logs
because of the TB lock protecting all code generation, it is
possible to interleave cpu logs, or to interleave a cpu dump with
an out_asm dump.
For mingw32, we appear to have no viable solution for this. The locking
functions are not properly exported from the system runtime library.
Reviewed-by: Paolo Bonzini <pbonzini@redhat.com>
Signed-off-by: Richard Henderson <rth@twiddle.net>
Diffstat (limited to 'include/sysemu/os-win32.h')
-rw-r--r-- | include/sysemu/os-win32.h | 15 |
1 files changed, 15 insertions, 0 deletions
diff --git a/include/sysemu/os-win32.h b/include/sysemu/os-win32.h index 17aad3b20f..ff18b23db1 100644 --- a/include/sysemu/os-win32.h +++ b/include/sysemu/os-win32.h @@ -103,6 +103,21 @@ static inline char *realpath(const char *path, char *resolved_path) return resolved_path; } +/* ??? Mingw appears to export _lock_file and _unlock_file as the functions + * with which to lock a stdio handle. But something is wrong in the markup, + * either in the header or the library, such that we get undefined references + * to "_imp___lock_file" etc when linking. Since we seem to have no other + * alternative, and the usage within the logging functions isn't critical, + * ignore FILE locking. + */ + +static inline void qemu_flockfile(FILE *f) +{ +} + +static inline void qemu_funlockfile(FILE *f) +{ +} /* We wrap all the sockets functions so that we can * set errno based on WSAGetLastError() |