forked from eden-emu/eden
		
	audio: Wait for samples on the emulated DSP side to avoid desyncs
Waiting on the host side is inaccurate and leads to desyncs in the event of the sink missing a deadline that require stalls to fix. By waiting for the sink to have space before even starting rendering such desyncs can be avoided.
This commit is contained in:
		
							parent
							
								
									d8fc3f403b
								
							
						
					
					
						commit
						ea5dd02db9
					
				
					 6 changed files with 28 additions and 24 deletions
				
			
		|  | @ -189,6 +189,8 @@ void AudioRenderer::ThreadFunc() { | |||
|                     max_time = std::min(command_buffer.time_limit, max_time); | ||||
|                     command_list_processor.SetProcessTimeMax(max_time); | ||||
| 
 | ||||
|                     streams[index]->WaitFreeSpace(); | ||||
| 
 | ||||
|                     // Process the command list
 | ||||
|                     { | ||||
|                         MICROPROFILE_SCOPE(Audio_Renderer); | ||||
|  |  | |||
|  | @ -12,6 +12,7 @@ | |||
| #include "common/common_types.h" | ||||
| #include "common/reader_writer_queue.h" | ||||
| #include "common/thread.h" | ||||
| #include "common/polyfill_thread.h" | ||||
| 
 | ||||
| namespace Core { | ||||
| namespace Timing { | ||||
|  |  | |||
|  | @ -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
 | ||||
|  |  | |||
|  | @ -68,11 +68,6 @@ private: | |||
|      */ | ||||
|     void ThreadFunc(); | ||||
| 
 | ||||
|     /**
 | ||||
|      * Signalling core timing thread to run ThreadFunc. | ||||
|      */ | ||||
|     std::optional<std::chrono::nanoseconds> ThreadFunc2(s64 time); | ||||
| 
 | ||||
|     enum class StreamState { | ||||
|         Filling, | ||||
|         Steady, | ||||
|  | @ -95,8 +90,6 @@ private: | |||
|     ADSP::ADSP& adsp; | ||||
|     /// AudioRenderer mailbox for communication
 | ||||
|     ADSP::AudioRenderer_Mailbox* mailbox{}; | ||||
|     /// Core timing event to signal main thread
 | ||||
|     std::shared_ptr<Core::Timing::EventType> thread_event; | ||||
|     /// Atomic for main thread to wait on
 | ||||
|     std::atomic<bool> update{}; | ||||
| }; | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Billy Laws
						Billy Laws