forked from eden-emu/eden
		
	core_timing: Convert core timing into a class
Gets rid of the largest set of mutable global state within the core. This also paves a way for eliminating usages of GetInstance() on the System class as a follow-up. Note that no behavioral changes have been made, and this simply extracts the functionality into a class. This also has the benefit of making dependencies on the core timing functionality explicit within the relevant interfaces.
This commit is contained in:
		
							parent
							
								
									fcc3aa0bbf
								
							
						
					
					
						commit
						bd983414f6
					
				
					 53 changed files with 536 additions and 400 deletions
				
			
		|  | @ -14,8 +14,9 @@ | |||
| #include "common/common_types.h" | ||||
| 
 | ||||
| namespace Core::Timing { | ||||
| class CoreTiming; | ||||
| struct EventType; | ||||
| } | ||||
| } // namespace Core::Timing
 | ||||
| 
 | ||||
| namespace AudioCore { | ||||
| 
 | ||||
|  | @ -42,8 +43,8 @@ public: | |||
|     /// Callback function type, used to change guest state on a buffer being released
 | ||||
|     using ReleaseCallback = std::function<void()>; | ||||
| 
 | ||||
|     Stream(u32 sample_rate, Format format, ReleaseCallback&& release_callback, | ||||
|            SinkStream& sink_stream, std::string&& name_); | ||||
|     Stream(Core::Timing::CoreTiming& core_timing, u32 sample_rate, Format format, | ||||
|            ReleaseCallback&& release_callback, SinkStream& sink_stream, std::string&& name_); | ||||
| 
 | ||||
|     /// Plays the audio stream
 | ||||
|     void Play(); | ||||
|  | @ -100,6 +101,7 @@ private: | |||
|     std::queue<BufferPtr> queued_buffers;     ///< Buffers queued to be played in the stream
 | ||||
|     std::queue<BufferPtr> released_buffers;   ///< Buffers recently released from the stream
 | ||||
|     SinkStream& sink_stream;                  ///< Output sink for the stream
 | ||||
|     Core::Timing::CoreTiming& core_timing;    ///< Core timing instance.
 | ||||
|     std::string name;                         ///< Name of the stream, must be unique
 | ||||
| }; | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Lioncash
						Lioncash