diff options
author | Richard Henderson <richard.henderson@linaro.org> | 2022-04-17 11:30:06 -0700 |
---|---|---|
committer | Richard Henderson <richard.henderson@linaro.org> | 2022-04-20 10:51:11 -0700 |
commit | 6391c772d7c5928d1b2abd65486330b34c97a42b (patch) | |
tree | 8b1dea837445af2485d8128696ed23a274d033b6 /include/sysemu/os-win32.h | |
parent | 7fc493f8bd5b5eccf761ec9b1caa13c872e289ec (diff) | |
download | qemu-6391c772d7c5928d1b2abd65486330b34c97a42b.zip qemu-6391c772d7c5928d1b2abd65486330b34c97a42b.tar.gz qemu-6391c772d7c5928d1b2abd65486330b34c97a42b.tar.bz2 |
sysemu/os-win32: Test for and use _lock_file/_unlock_file
The bug referenced in os-win32.h was fixed in mingw-w64 v6.
According to repology, version 5 used by ubuntu 18, which is
not yet out of support, so provide a meson link test for it.
Reviewed-by: Alex Bennée <alex.bennee@linaro.org>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
Message-Id: <20220417183019.755276-27-richard.henderson@linaro.org>
Diffstat (limited to 'include/sysemu/os-win32.h')
-rw-r--r-- | include/sysemu/os-win32.h | 16 |
1 files changed, 9 insertions, 7 deletions
diff --git a/include/sysemu/os-win32.h b/include/sysemu/os-win32.h index 3c74a78..edc3b38 100644 --- a/include/sysemu/os-win32.h +++ b/include/sysemu/os-win32.h @@ -109,20 +109,22 @@ 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. +/* + * Older versions of MinGW do not import _lock_file and _unlock_file properly. + * This was fixed for v6.0.0 with commit b48e3ac8969d. */ - static inline void qemu_flockfile(FILE *f) { +#ifdef HAVE__LOCK_FILE + _lock_file(f); +#endif } static inline void qemu_funlockfile(FILE *f) { +#ifdef HAVE__LOCK_FILE + _unlock_file(f); +#endif } /* We wrap all the sockets functions so that we can |