mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-01 23:03:54 -06:00
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>
This commit is contained in:
parent
9acbf7d8ca
commit
1ee73216f4
25 changed files with 98 additions and 1 deletions
|
@ -87,4 +87,16 @@ void *qemu_alloc_stack(size_t *sz);
|
|||
*/
|
||||
void qemu_free_stack(void *stack, size_t sz);
|
||||
|
||||
/* POSIX and Mingw32 differ in the name of the stdio lock functions. */
|
||||
|
||||
static inline void qemu_flockfile(FILE *f)
|
||||
{
|
||||
flockfile(f);
|
||||
}
|
||||
|
||||
static inline void qemu_funlockfile(FILE *f)
|
||||
{
|
||||
funlockfile(f);
|
||||
}
|
||||
|
||||
#endif
|
||||
|
|
|
@ -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()
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue