From 5f9f6aa7f2f9dc2a91692d6db876b21caa60ee12 Mon Sep 17 00:00:00 2001 From: Henning Baldersheim Date: Tue, 13 Oct 2020 20:23:50 +0000 Subject: Properly lock criticalk section. --- .../src/vespa/storageframework/generic/thread/tickingthread.cpp | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) (limited to 'storageframework') diff --git a/storageframework/src/vespa/storageframework/generic/thread/tickingthread.cpp b/storageframework/src/vespa/storageframework/generic/thread/tickingthread.cpp index 51afa75ea98..258306b6416 100644 --- a/storageframework/src/vespa/storageframework/generic/thread/tickingthread.cpp +++ b/storageframework/src/vespa/storageframework/generic/thread/tickingthread.cpp @@ -124,9 +124,10 @@ class TickingThreadPoolImpl final : public TickingThreadPool { void broadcast() override {} }; struct CriticalGuard final : public TickingLockGuard::Impl { + std::unique_lock _guard; std::condition_variable &_cond; - explicit CriticalGuard(std::condition_variable & cond) : _cond(cond) {} + explicit CriticalGuard(std::mutex & lock, std::condition_variable & cond) : _guard(lock), _cond(cond) {} void broadcast() override { _cond.notify_all(); } }; @@ -179,7 +180,7 @@ public: } TickingLockGuard freezeCriticalTicks() override { - return TickingLockGuard(std::make_unique(_cond)); + return TickingLockGuard(std::make_unique(_lock, _cond)); } void stop() override { -- cgit v1.2.3