forked from eden-emu/eden
		
	Merge pull request #8169 from merryhime/scoped_lock
Replace lock_guard with scoped_lock
This commit is contained in:
		
						commit
						04efd729d6
					
				
					 29 changed files with 105 additions and 105 deletions
				
			
		|  | @ -99,7 +99,7 @@ struct KernelCore::Impl { | |||
|         // Close all open server ports.
 | ||||
|         std::unordered_set<KServerPort*> server_ports_; | ||||
|         { | ||||
|             std::lock_guard lk(server_ports_lock); | ||||
|             std::scoped_lock lk{server_ports_lock}; | ||||
|             server_ports_ = server_ports; | ||||
|             server_ports.clear(); | ||||
|         } | ||||
|  | @ -157,7 +157,7 @@ struct KernelCore::Impl { | |||
| 
 | ||||
|         // Close kernel objects that were not freed on shutdown
 | ||||
|         { | ||||
|             std::lock_guard lk(registered_in_use_objects_lock); | ||||
|             std::scoped_lock lk{registered_in_use_objects_lock}; | ||||
|             if (registered_in_use_objects.size()) { | ||||
|                 for (auto& object : registered_in_use_objects) { | ||||
|                     object->Close(); | ||||
|  | @ -178,7 +178,7 @@ struct KernelCore::Impl { | |||
| 
 | ||||
|         // Track kernel objects that were not freed on shutdown
 | ||||
|         { | ||||
|             std::lock_guard lk(registered_objects_lock); | ||||
|             std::scoped_lock lk{registered_objects_lock}; | ||||
|             if (registered_objects.size()) { | ||||
|                 LOG_DEBUG(Kernel, "{} kernel objects were dangling on shutdown!", | ||||
|                           registered_objects.size()); | ||||
|  | @ -660,7 +660,7 @@ struct KernelCore::Impl { | |||
| 
 | ||||
|         KClientPort* port = &search->second(system.ServiceManager(), system); | ||||
|         { | ||||
|             std::lock_guard lk(server_ports_lock); | ||||
|             std::scoped_lock lk{server_ports_lock}; | ||||
|             server_ports.insert(&port->GetParent()->GetServerPort()); | ||||
|         } | ||||
|         return port; | ||||
|  | @ -929,22 +929,22 @@ KClientPort* KernelCore::CreateNamedServicePort(std::string name) { | |||
| } | ||||
| 
 | ||||
| void KernelCore::RegisterKernelObject(KAutoObject* object) { | ||||
|     std::lock_guard lk(impl->registered_objects_lock); | ||||
|     std::scoped_lock lk{impl->registered_objects_lock}; | ||||
|     impl->registered_objects.insert(object); | ||||
| } | ||||
| 
 | ||||
| void KernelCore::UnregisterKernelObject(KAutoObject* object) { | ||||
|     std::lock_guard lk(impl->registered_objects_lock); | ||||
|     std::scoped_lock lk{impl->registered_objects_lock}; | ||||
|     impl->registered_objects.erase(object); | ||||
| } | ||||
| 
 | ||||
| void KernelCore::RegisterInUseObject(KAutoObject* object) { | ||||
|     std::lock_guard lk(impl->registered_in_use_objects_lock); | ||||
|     std::scoped_lock lk{impl->registered_in_use_objects_lock}; | ||||
|     impl->registered_in_use_objects.insert(object); | ||||
| } | ||||
| 
 | ||||
| void KernelCore::UnregisterInUseObject(KAutoObject* object) { | ||||
|     std::lock_guard lk(impl->registered_in_use_objects_lock); | ||||
|     std::scoped_lock lk{impl->registered_in_use_objects_lock}; | ||||
|     impl->registered_in_use_objects.erase(object); | ||||
| } | ||||
| 
 | ||||
|  |  | |||
|  | @ -24,7 +24,7 @@ TimeManager::TimeManager(Core::System& system_) : system{system_} { | |||
| } | ||||
| 
 | ||||
| void TimeManager::ScheduleTimeEvent(KThread* thread, s64 nanoseconds) { | ||||
|     std::lock_guard lock{mutex}; | ||||
|     std::scoped_lock lock{mutex}; | ||||
|     if (nanoseconds > 0) { | ||||
|         ASSERT(thread); | ||||
|         ASSERT(thread->GetState() != ThreadState::Runnable); | ||||
|  | @ -35,7 +35,7 @@ void TimeManager::ScheduleTimeEvent(KThread* thread, s64 nanoseconds) { | |||
| } | ||||
| 
 | ||||
| void TimeManager::UnscheduleTimeEvent(KThread* thread) { | ||||
|     std::lock_guard lock{mutex}; | ||||
|     std::scoped_lock lock{mutex}; | ||||
|     system.CoreTiming().UnscheduleEvent(time_manager_event_type, | ||||
|                                         reinterpret_cast<uintptr_t>(thread)); | ||||
| } | ||||
|  |  | |||
|  | @ -318,7 +318,7 @@ void Controller_NPad::OnRelease() { | |||
| } | ||||
| 
 | ||||
| void Controller_NPad::RequestPadStateUpdate(Core::HID::NpadIdType npad_id) { | ||||
|     std::lock_guard lock{mutex}; | ||||
|     std::scoped_lock lock{mutex}; | ||||
|     auto& controller = GetControllerFromNpadIdType(npad_id); | ||||
|     const auto controller_type = controller.device->GetNpadStyleIndex(); | ||||
|     if (!controller.device->IsConnected()) { | ||||
|  |  | |||
|  | @ -21,7 +21,7 @@ Status BufferItemConsumer::AcquireBuffer(BufferItem* item, std::chrono::nanoseco | |||
|         return Status::BadValue; | ||||
|     } | ||||
| 
 | ||||
|     std::scoped_lock lock(mutex); | ||||
|     std::scoped_lock lock{mutex}; | ||||
| 
 | ||||
|     if (const auto status = AcquireBufferLocked(item, present_when); status != Status::NoError) { | ||||
|         if (status != Status::NoBufferAvailable) { | ||||
|  | @ -40,7 +40,7 @@ Status BufferItemConsumer::AcquireBuffer(BufferItem* item, std::chrono::nanoseco | |||
| } | ||||
| 
 | ||||
| Status BufferItemConsumer::ReleaseBuffer(const BufferItem& item, Fence& release_fence) { | ||||
|     std::scoped_lock lock(mutex); | ||||
|     std::scoped_lock lock{mutex}; | ||||
| 
 | ||||
|     if (const auto status = AddReleaseFenceLocked(item.buf, item.graphic_buffer, release_fence); | ||||
|         status != Status::NoError) { | ||||
|  |  | |||
|  | @ -19,7 +19,7 @@ BufferQueueConsumer::~BufferQueueConsumer() = default; | |||
| 
 | ||||
| Status BufferQueueConsumer::AcquireBuffer(BufferItem* out_buffer, | ||||
|                                           std::chrono::nanoseconds expected_present) { | ||||
|     std::scoped_lock lock(core->mutex); | ||||
|     std::scoped_lock lock{core->mutex}; | ||||
| 
 | ||||
|     // Check that the consumer doesn't currently have the maximum number of buffers acquired.
 | ||||
|     const s32 num_acquired_buffers{ | ||||
|  | @ -120,7 +120,7 @@ Status BufferQueueConsumer::ReleaseBuffer(s32 slot, u64 frame_number, const Fenc | |||
| 
 | ||||
|     std::shared_ptr<IProducerListener> listener; | ||||
|     { | ||||
|         std::scoped_lock lock(core->mutex); | ||||
|         std::scoped_lock lock{core->mutex}; | ||||
| 
 | ||||
|         // If the frame number has changed because the buffer has been reallocated, we can ignore
 | ||||
|         // this ReleaseBuffer for the old buffer.
 | ||||
|  | @ -180,7 +180,7 @@ Status BufferQueueConsumer::Connect(std::shared_ptr<IConsumerListener> consumer_ | |||
| 
 | ||||
|     LOG_DEBUG(Service_NVFlinger, "controlled_by_app={}", controlled_by_app); | ||||
| 
 | ||||
|     std::scoped_lock lock(core->mutex); | ||||
|     std::scoped_lock lock{core->mutex}; | ||||
| 
 | ||||
|     if (core->is_abandoned) { | ||||
|         LOG_ERROR(Service_NVFlinger, "BufferQueue has been abandoned"); | ||||
|  | @ -199,7 +199,7 @@ Status BufferQueueConsumer::GetReleasedBuffers(u64* out_slot_mask) { | |||
|         return Status::BadValue; | ||||
|     } | ||||
| 
 | ||||
|     std::scoped_lock lock(core->mutex); | ||||
|     std::scoped_lock lock{core->mutex}; | ||||
| 
 | ||||
|     if (core->is_abandoned) { | ||||
|         LOG_ERROR(Service_NVFlinger, "BufferQueue has been abandoned"); | ||||
|  |  | |||
|  | @ -15,7 +15,7 @@ BufferQueueCore::BufferQueueCore() = default; | |||
| BufferQueueCore::~BufferQueueCore() = default; | ||||
| 
 | ||||
| void BufferQueueCore::NotifyShutdown() { | ||||
|     std::scoped_lock lock(mutex); | ||||
|     std::scoped_lock lock{mutex}; | ||||
| 
 | ||||
|     is_shutting_down = true; | ||||
| 
 | ||||
|  |  | |||
|  | @ -38,7 +38,7 @@ BufferQueueProducer::~BufferQueueProducer() { | |||
| Status BufferQueueProducer::RequestBuffer(s32 slot, std::shared_ptr<GraphicBuffer>* buf) { | ||||
|     LOG_DEBUG(Service_NVFlinger, "slot {}", slot); | ||||
| 
 | ||||
|     std::scoped_lock lock(core->mutex); | ||||
|     std::scoped_lock lock{core->mutex}; | ||||
| 
 | ||||
|     if (core->is_abandoned) { | ||||
|         LOG_ERROR(Service_NVFlinger, "BufferQueue has been abandoned"); | ||||
|  | @ -65,7 +65,7 @@ Status BufferQueueProducer::SetBufferCount(s32 buffer_count) { | |||
| 
 | ||||
|     std::shared_ptr<IConsumerListener> listener; | ||||
|     { | ||||
|         std::scoped_lock lock(core->mutex); | ||||
|         std::scoped_lock lock{core->mutex}; | ||||
|         core->WaitWhileAllocatingLocked(); | ||||
| 
 | ||||
|         if (core->is_abandoned) { | ||||
|  | @ -236,7 +236,7 @@ Status BufferQueueProducer::DequeueBuffer(s32* out_slot, Fence* out_fence, bool | |||
|     Status return_flags = Status::NoError; | ||||
|     bool attached_by_consumer = false; | ||||
|     { | ||||
|         std::scoped_lock lock(core->mutex); | ||||
|         std::scoped_lock lock{core->mutex}; | ||||
|         core->WaitWhileAllocatingLocked(); | ||||
| 
 | ||||
|         if (format == PixelFormat::NoFormat) { | ||||
|  | @ -295,7 +295,7 @@ Status BufferQueueProducer::DequeueBuffer(s32* out_slot, Fence* out_fence, bool | |||
|         } | ||||
| 
 | ||||
|         { | ||||
|             std::scoped_lock lock(core->mutex); | ||||
|             std::scoped_lock lock{core->mutex}; | ||||
| 
 | ||||
|             if (core->is_abandoned) { | ||||
|                 LOG_ERROR(Service_NVFlinger, "BufferQueue has been abandoned"); | ||||
|  | @ -320,7 +320,7 @@ Status BufferQueueProducer::DequeueBuffer(s32* out_slot, Fence* out_fence, bool | |||
| Status BufferQueueProducer::DetachBuffer(s32 slot) { | ||||
|     LOG_DEBUG(Service_NVFlinger, "slot {}", slot); | ||||
| 
 | ||||
|     std::scoped_lock lock(core->mutex); | ||||
|     std::scoped_lock lock{core->mutex}; | ||||
| 
 | ||||
|     if (core->is_abandoned) { | ||||
|         LOG_ERROR(Service_NVFlinger, "BufferQueue has been abandoned"); | ||||
|  | @ -356,7 +356,7 @@ Status BufferQueueProducer::DetachNextBuffer(std::shared_ptr<GraphicBuffer>* out | |||
|         return Status::BadValue; | ||||
|     } | ||||
| 
 | ||||
|     std::scoped_lock lock(core->mutex); | ||||
|     std::scoped_lock lock{core->mutex}; | ||||
|     core->WaitWhileAllocatingLocked(); | ||||
| 
 | ||||
|     if (core->is_abandoned) { | ||||
|  | @ -399,7 +399,7 @@ Status BufferQueueProducer::AttachBuffer(s32* out_slot, | |||
|         return Status::BadValue; | ||||
|     } | ||||
| 
 | ||||
|     std::scoped_lock lock(core->mutex); | ||||
|     std::scoped_lock lock{core->mutex}; | ||||
|     core->WaitWhileAllocatingLocked(); | ||||
| 
 | ||||
|     Status return_flags = Status::NoError; | ||||
|  | @ -460,7 +460,7 @@ Status BufferQueueProducer::QueueBuffer(s32 slot, const QueueBufferInput& input, | |||
|     BufferItem item; | ||||
| 
 | ||||
|     { | ||||
|         std::scoped_lock lock(core->mutex); | ||||
|         std::scoped_lock lock{core->mutex}; | ||||
| 
 | ||||
|         if (core->is_abandoned) { | ||||
|             LOG_ERROR(Service_NVFlinger, "BufferQueue has been abandoned"); | ||||
|  | @ -576,7 +576,7 @@ Status BufferQueueProducer::QueueBuffer(s32 slot, const QueueBufferInput& input, | |||
|     // Call back without the main BufferQueue lock held, but with the callback lock held so we can
 | ||||
|     // ensure that callbacks occur in order
 | ||||
|     { | ||||
|         std::scoped_lock lock(callback_mutex); | ||||
|         std::scoped_lock lock{callback_mutex}; | ||||
|         while (callback_ticket != current_callback_ticket) { | ||||
|             callback_condition.wait(callback_mutex); | ||||
|         } | ||||
|  | @ -597,7 +597,7 @@ Status BufferQueueProducer::QueueBuffer(s32 slot, const QueueBufferInput& input, | |||
| void BufferQueueProducer::CancelBuffer(s32 slot, const Fence& fence) { | ||||
|     LOG_DEBUG(Service_NVFlinger, "slot {}", slot); | ||||
| 
 | ||||
|     std::scoped_lock lock(core->mutex); | ||||
|     std::scoped_lock lock{core->mutex}; | ||||
| 
 | ||||
|     if (core->is_abandoned) { | ||||
|         LOG_ERROR(Service_NVFlinger, "BufferQueue has been abandoned"); | ||||
|  | @ -623,7 +623,7 @@ void BufferQueueProducer::CancelBuffer(s32 slot, const Fence& fence) { | |||
| } | ||||
| 
 | ||||
| Status BufferQueueProducer::Query(NativeWindow what, s32* out_value) { | ||||
|     std::scoped_lock lock(core->mutex); | ||||
|     std::scoped_lock lock{core->mutex}; | ||||
| 
 | ||||
|     if (out_value == nullptr) { | ||||
|         LOG_ERROR(Service_NVFlinger, "outValue was nullptr"); | ||||
|  | @ -673,7 +673,7 @@ Status BufferQueueProducer::Query(NativeWindow what, s32* out_value) { | |||
| Status BufferQueueProducer::Connect(const std::shared_ptr<IProducerListener>& listener, | ||||
|                                     NativeWindowApi api, bool producer_controlled_by_app, | ||||
|                                     QueueBufferOutput* output) { | ||||
|     std::scoped_lock lock(core->mutex); | ||||
|     std::scoped_lock lock{core->mutex}; | ||||
| 
 | ||||
|     LOG_DEBUG(Service_NVFlinger, "api = {} producer_controlled_by_app = {}", api, | ||||
|               producer_controlled_by_app); | ||||
|  | @ -730,7 +730,7 @@ Status BufferQueueProducer::Disconnect(NativeWindowApi api) { | |||
|     std::shared_ptr<IConsumerListener> listener; | ||||
| 
 | ||||
|     { | ||||
|         std::scoped_lock lock(core->mutex); | ||||
|         std::scoped_lock lock{core->mutex}; | ||||
| 
 | ||||
|         core->WaitWhileAllocatingLocked(); | ||||
| 
 | ||||
|  | @ -780,7 +780,7 @@ Status BufferQueueProducer::SetPreallocatedBuffer(s32 slot, | |||
|         return Status::BadValue; | ||||
|     } | ||||
| 
 | ||||
|     std::scoped_lock lock(core->mutex); | ||||
|     std::scoped_lock lock{core->mutex}; | ||||
| 
 | ||||
|     slots[slot] = {}; | ||||
|     slots[slot].graphic_buffer = buffer; | ||||
|  |  | |||
|  | @ -18,7 +18,7 @@ ConsumerBase::ConsumerBase(std::unique_ptr<BufferQueueConsumer> consumer_) | |||
|     : consumer{std::move(consumer_)} {} | ||||
| 
 | ||||
| ConsumerBase::~ConsumerBase() { | ||||
|     std::scoped_lock lock(mutex); | ||||
|     std::scoped_lock lock{mutex}; | ||||
| 
 | ||||
|     ASSERT_MSG(is_abandoned, "consumer is not abandoned!"); | ||||
| } | ||||
|  | @ -44,7 +44,7 @@ void ConsumerBase::OnFrameReplaced(const BufferItem& item) { | |||
| } | ||||
| 
 | ||||
| void ConsumerBase::OnBuffersReleased() { | ||||
|     std::scoped_lock lock(mutex); | ||||
|     std::scoped_lock lock{mutex}; | ||||
| 
 | ||||
|     LOG_DEBUG(Service_NVFlinger, "called"); | ||||
| 
 | ||||
|  |  | |||
|  | @ -14,7 +14,7 @@ HosBinderDriverServer::HosBinderDriverServer(Core::System& system_) | |||
| HosBinderDriverServer::~HosBinderDriverServer() {} | ||||
| 
 | ||||
| u64 HosBinderDriverServer::RegisterProducer(std::unique_ptr<android::IBinder>&& binder) { | ||||
|     std::lock_guard lk{lock}; | ||||
|     std::scoped_lock lk{lock}; | ||||
| 
 | ||||
|     last_id++; | ||||
| 
 | ||||
|  | @ -24,7 +24,7 @@ u64 HosBinderDriverServer::RegisterProducer(std::unique_ptr<android::IBinder>&& | |||
| } | ||||
| 
 | ||||
| android::IBinder* HosBinderDriverServer::TryGetProducer(u64 id) { | ||||
|     std::lock_guard lk{lock}; | ||||
|     std::scoped_lock lk{lock}; | ||||
| 
 | ||||
|     if (auto search = producers.find(id); search != producers.end()) { | ||||
|         return search->second.get(); | ||||
|  |  | |||
|  | @ -53,13 +53,13 @@ PerfStats::~PerfStats() { | |||
| } | ||||
| 
 | ||||
| void PerfStats::BeginSystemFrame() { | ||||
|     std::lock_guard lock{object_mutex}; | ||||
|     std::scoped_lock lock{object_mutex}; | ||||
| 
 | ||||
|     frame_begin = Clock::now(); | ||||
| } | ||||
| 
 | ||||
| void PerfStats::EndSystemFrame() { | ||||
|     std::lock_guard lock{object_mutex}; | ||||
|     std::scoped_lock lock{object_mutex}; | ||||
| 
 | ||||
|     auto frame_end = Clock::now(); | ||||
|     const auto frame_time = frame_end - frame_begin; | ||||
|  | @ -79,7 +79,7 @@ void PerfStats::EndGameFrame() { | |||
| } | ||||
| 
 | ||||
| double PerfStats::GetMeanFrametime() const { | ||||
|     std::lock_guard lock{object_mutex}; | ||||
|     std::scoped_lock lock{object_mutex}; | ||||
| 
 | ||||
|     if (current_index <= IgnoreFrames) { | ||||
|         return 0; | ||||
|  | @ -91,7 +91,7 @@ double PerfStats::GetMeanFrametime() const { | |||
| } | ||||
| 
 | ||||
| PerfStatsResults PerfStats::GetAndResetStats(microseconds current_system_time_us) { | ||||
|     std::lock_guard lock{object_mutex}; | ||||
|     std::scoped_lock lock{object_mutex}; | ||||
| 
 | ||||
|     const auto now = Clock::now(); | ||||
|     // Walltime elapsed since stats were reset
 | ||||
|  | @ -120,7 +120,7 @@ PerfStatsResults PerfStats::GetAndResetStats(microseconds current_system_time_us | |||
| } | ||||
| 
 | ||||
| double PerfStats::GetLastFrameTimeScale() const { | ||||
|     std::lock_guard lock{object_mutex}; | ||||
|     std::scoped_lock lock{object_mutex}; | ||||
| 
 | ||||
|     constexpr double FRAME_LENGTH = 1.0 / 60; | ||||
|     return duration_cast<DoubleSecs>(previous_frame_length).count() / FRAME_LENGTH; | ||||
|  |  | |||
|  | @ -80,7 +80,7 @@ bool Freezer::IsActive() const { | |||
| } | ||||
| 
 | ||||
| void Freezer::Clear() { | ||||
|     std::lock_guard lock{entries_mutex}; | ||||
|     std::scoped_lock lock{entries_mutex}; | ||||
| 
 | ||||
|     LOG_DEBUG(Common_Memory, "Clearing all frozen memory values."); | ||||
| 
 | ||||
|  | @ -88,7 +88,7 @@ void Freezer::Clear() { | |||
| } | ||||
| 
 | ||||
| u64 Freezer::Freeze(VAddr address, u32 width) { | ||||
|     std::lock_guard lock{entries_mutex}; | ||||
|     std::scoped_lock lock{entries_mutex}; | ||||
| 
 | ||||
|     const auto current_value = MemoryReadWidth(memory, width, address); | ||||
|     entries.push_back({address, width, current_value}); | ||||
|  | @ -101,7 +101,7 @@ u64 Freezer::Freeze(VAddr address, u32 width) { | |||
| } | ||||
| 
 | ||||
| void Freezer::Unfreeze(VAddr address) { | ||||
|     std::lock_guard lock{entries_mutex}; | ||||
|     std::scoped_lock lock{entries_mutex}; | ||||
| 
 | ||||
|     LOG_DEBUG(Common_Memory, "Unfreezing memory for address={:016X}", address); | ||||
| 
 | ||||
|  | @ -109,13 +109,13 @@ void Freezer::Unfreeze(VAddr address) { | |||
| } | ||||
| 
 | ||||
| bool Freezer::IsFrozen(VAddr address) const { | ||||
|     std::lock_guard lock{entries_mutex}; | ||||
|     std::scoped_lock lock{entries_mutex}; | ||||
| 
 | ||||
|     return FindEntry(address) != entries.cend(); | ||||
| } | ||||
| 
 | ||||
| void Freezer::SetFrozenValue(VAddr address, u64 value) { | ||||
|     std::lock_guard lock{entries_mutex}; | ||||
|     std::scoped_lock lock{entries_mutex}; | ||||
| 
 | ||||
|     const auto iter = FindEntry(address); | ||||
| 
 | ||||
|  | @ -132,7 +132,7 @@ void Freezer::SetFrozenValue(VAddr address, u64 value) { | |||
| } | ||||
| 
 | ||||
| std::optional<Freezer::Entry> Freezer::GetEntry(VAddr address) const { | ||||
|     std::lock_guard lock{entries_mutex}; | ||||
|     std::scoped_lock lock{entries_mutex}; | ||||
| 
 | ||||
|     const auto iter = FindEntry(address); | ||||
| 
 | ||||
|  | @ -144,7 +144,7 @@ std::optional<Freezer::Entry> Freezer::GetEntry(VAddr address) const { | |||
| } | ||||
| 
 | ||||
| std::vector<Freezer::Entry> Freezer::GetEntries() const { | ||||
|     std::lock_guard lock{entries_mutex}; | ||||
|     std::scoped_lock lock{entries_mutex}; | ||||
| 
 | ||||
|     return entries; | ||||
| } | ||||
|  | @ -165,7 +165,7 @@ void Freezer::FrameCallback(std::uintptr_t, std::chrono::nanoseconds ns_late) { | |||
|         return; | ||||
|     } | ||||
| 
 | ||||
|     std::lock_guard lock{entries_mutex}; | ||||
|     std::scoped_lock lock{entries_mutex}; | ||||
| 
 | ||||
|     for (const auto& entry : entries) { | ||||
|         LOG_DEBUG(Common_Memory, | ||||
|  | @ -178,7 +178,7 @@ void Freezer::FrameCallback(std::uintptr_t, std::chrono::nanoseconds ns_late) { | |||
| } | ||||
| 
 | ||||
| void Freezer::FillEntryReads() { | ||||
|     std::lock_guard lock{entries_mutex}; | ||||
|     std::scoped_lock lock{entries_mutex}; | ||||
| 
 | ||||
|     LOG_DEBUG(Common_Memory, "Updating memory freeze entries to current values."); | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 bunnei
						bunnei