forked from eden-emu/eden
		
	android: Separate emulation states from emulation mutex
Emulation states are repeatedly checked by input and performance stats. During startup and shutdown, this could lead to a long halt on the UI thread because the call to IsRunning will be waiting on the emulation mutex to be unlocked. Using atomics should replace the existing functionality without causing problems.
This commit is contained in:
		
							parent
							
								
									5b69f2967e
								
							
						
					
					
						commit
						351caad5db
					
				
					 1 changed files with 2 additions and 4 deletions
				
			
		|  | @ -203,12 +203,10 @@ public: | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     bool IsRunning() const { |     bool IsRunning() const { | ||||||
|         std::scoped_lock lock(m_mutex); |  | ||||||
|         return m_is_running; |         return m_is_running; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     bool IsPaused() const { |     bool IsPaused() const { | ||||||
|         std::scoped_lock lock(m_mutex); |  | ||||||
|         return m_is_running && m_is_paused; |         return m_is_running && m_is_paused; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  | @ -544,8 +542,8 @@ private: | ||||||
|     Core::PerfStatsResults m_perf_stats{}; |     Core::PerfStatsResults m_perf_stats{}; | ||||||
|     std::shared_ptr<FileSys::VfsFilesystem> m_vfs; |     std::shared_ptr<FileSys::VfsFilesystem> m_vfs; | ||||||
|     Core::SystemResultStatus m_load_result{Core::SystemResultStatus::ErrorNotInitialized}; |     Core::SystemResultStatus m_load_result{Core::SystemResultStatus::ErrorNotInitialized}; | ||||||
|     bool m_is_running{}; |     std::atomic<bool> m_is_running = false; | ||||||
|     bool m_is_paused{}; |     std::atomic<bool> m_is_paused = false; | ||||||
|     SoftwareKeyboard::AndroidKeyboard* m_software_keyboard{}; |     SoftwareKeyboard::AndroidKeyboard* m_software_keyboard{}; | ||||||
|     std::unique_ptr<Service::Account::ProfileManager> m_profile_manager; |     std::unique_ptr<Service::Account::ProfileManager> m_profile_manager; | ||||||
|     std::unique_ptr<FileSys::ManualContentProvider> m_manual_provider; |     std::unique_ptr<FileSys::ManualContentProvider> m_manual_provider; | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Charles Lombardo
						Charles Lombardo