From: Alex Bennée Date: Tue, 27 Feb 2018 09:52:37 +0000 (+0300) Subject: replay/replay-internal.c: track holding of replay_lock X-Git-Tag: v2.12.0-rc0~16^2~10 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=180d30bebeff8e3687b50bd55d44e6a5a83bc4da;p=thirdparty%2Fqemu.git replay/replay-internal.c: track holding of replay_lock This is modelled after the iothread mutex lock. We keep a TLS flag to indicate when that thread has acquired the lock and assert we don't double-lock or release when we shouldn't have. Signed-off-by: Alex Bennée Tested-by: Pavel Dovgalyuk Message-Id: <20180227095237.1060.44661.stgit@pasha-VirtualBox> Signed-off-by: Paolo Bonzini --- diff --git a/replay/replay-internal.c b/replay/replay-internal.c index fca85140129..0d7e1d6bc43 100644 --- a/replay/replay-internal.c +++ b/replay/replay-internal.c @@ -169,6 +169,8 @@ void replay_finish_event(void) replay_fetch_data_kind(); } +static __thread bool replay_locked; + void replay_mutex_init(void) { qemu_mutex_init(&lock); @@ -179,13 +181,22 @@ void replay_mutex_destroy(void) qemu_mutex_destroy(&lock); } +static bool replay_mutex_locked(void) +{ + return replay_locked; +} + void replay_mutex_lock(void) { + g_assert(!replay_mutex_locked()); qemu_mutex_lock(&lock); + replay_locked = true; } void replay_mutex_unlock(void) { + g_assert(replay_mutex_locked()); + replay_locked = false; qemu_mutex_unlock(&lock); }