From 3871d74bc213e8fd8ef712ef4724df3fe629ad7f Mon Sep 17 00:00:00 2001 From: Hamish Milne Date: Sat, 11 Apr 2020 19:33:21 +0100 Subject: [PATCH] Fix mic sharedmemory not being deallocated --- src/core/hle/service/mic_u.cpp | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) diff --git a/src/core/hle/service/mic_u.cpp b/src/core/hle/service/mic_u.cpp index 08ef5473f4..f0017ac4ca 100644 --- a/src/core/hle/service/mic_u.cpp +++ b/src/core/hle/service/mic_u.cpp @@ -2,6 +2,7 @@ // Licensed under GPLv2 or any later version // Refer to the license.txt file included. +#include #ifdef HAVE_CUBEB #include "audio_core/cubeb_input.h" #endif @@ -69,7 +70,7 @@ constexpr u64 GetBufferUpdateRate(SampleRate sample_rate) { // Variables holding the current mic buffer writing state struct State { - std::shared_ptr memory_ref = nullptr; + std::weak_ptr memory_ref{}; u8* sharedmem_buffer = nullptr; u32 sharedmem_size = 0; std::size_t size = 0; @@ -110,7 +111,9 @@ struct State { private: template void serialize(Archive& ar, const unsigned int) { - ar& memory_ref; + std::shared_ptr _memory_ref = memory_ref.lock(); + ar& _memory_ref; + memory_ref = _memory_ref; ar& sharedmem_size; ar& size; ar& offset; @@ -118,7 +121,7 @@ private: ar& looped_buffer; ar& sample_size; ar& sample_rate; - sharedmem_buffer = memory_ref ? memory_ref->GetPointer() : nullptr; + sharedmem_buffer = _memory_ref ? _memory_ref->GetPointer() : nullptr; } friend class boost::serialization::access; };