diff options
author | Billy Laws <blaws05@gmail.com> | 2023-03-18 21:57:00 +0100 |
---|---|---|
committer | Billy Laws <blaws05@gmail.com> | 2023-03-27 22:34:28 +0200 |
commit | ea5dd02db9bdb9759a400907672ec6606bebb96b (patch) | |
tree | 9f6f4f4662eb48ad57fe713e29f6b98778f263bf /src/audio_core/renderer/system_manager.cpp | |
parent | audio: Interpolate system manager sample count using host sink sample info (diff) | |
download | yuzu-ea5dd02db9bdb9759a400907672ec6606bebb96b.tar yuzu-ea5dd02db9bdb9759a400907672ec6606bebb96b.tar.gz yuzu-ea5dd02db9bdb9759a400907672ec6606bebb96b.tar.bz2 yuzu-ea5dd02db9bdb9759a400907672ec6606bebb96b.tar.lz yuzu-ea5dd02db9bdb9759a400907672ec6606bebb96b.tar.xz yuzu-ea5dd02db9bdb9759a400907672ec6606bebb96b.tar.zst yuzu-ea5dd02db9bdb9759a400907672ec6606bebb96b.zip |
Diffstat (limited to '')
-rw-r--r-- | src/audio_core/renderer/system_manager.cpp | 18 |
1 files changed, 1 insertions, 17 deletions
diff --git a/src/audio_core/renderer/system_manager.cpp b/src/audio_core/renderer/system_manager.cpp index 9ddfa4a91..07d8ed093 100644 --- a/src/audio_core/renderer/system_manager.cpp +++ b/src/audio_core/renderer/system_manager.cpp @@ -17,11 +17,7 @@ MICROPROFILE_DEFINE(Audio_RenderSystemManager, "Audio", "Render System Manager", namespace AudioCore::AudioRenderer { SystemManager::SystemManager(Core::System& core_) - : core{core_}, adsp{core.AudioCore().GetADSP()}, mailbox{adsp.GetRenderMailbox()}, - thread_event{Core::Timing::CreateEvent( - "AudioRendererSystemManager", [this](std::uintptr_t, s64 time, std::chrono::nanoseconds) { - return ThreadFunc2(time); - })} {} + : core{core_}, adsp{core.AudioCore().GetADSP()}, mailbox{adsp.GetRenderMailbox()} {} SystemManager::~SystemManager() { Stop(); @@ -32,8 +28,6 @@ bool SystemManager::InitializeUnsafe() { if (adsp.Start()) { active = true; thread = std::jthread([this](std::stop_token stop_token) { ThreadFunc(); }); - core.CoreTiming().ScheduleLoopingEvent(std::chrono::nanoseconds(0), RENDER_TIME, - thread_event); } } @@ -44,7 +38,6 @@ void SystemManager::Stop() { if (!active) { return; } - core.CoreTiming().UnscheduleEvent(thread_event, {}); active = false; update.store(true); update.notify_all(); @@ -110,16 +103,7 @@ void SystemManager::ThreadFunc() { adsp.Signal(); adsp.Wait(); - - update.wait(false); - update.store(false); } } -std::optional<std::chrono::nanoseconds> SystemManager::ThreadFunc2(s64 time) { - update.store(true); - update.notify_all(); - return std::nullopt; -} - } // namespace AudioCore::AudioRenderer |