forked from eden-emu/eden
		
	General: Recover Prometheus project from harddrive failure
This commit: Implements CPU Interrupts, Replaces Cycle Timing for Host Timing, Reworks the Kernel's Scheduler, Introduce Idle State and Suspended State, Recreates the bootmanager, Initializes Multicore system.
This commit is contained in:
		
							parent
							
								
									a83f0b607e
								
							
						
					
					
						commit
						7ee76003ad
					
				
					 57 changed files with 1349 additions and 824 deletions
				
			
		|  | @ -5,12 +5,18 @@ | |||
| #pragma once | ||||
| 
 | ||||
| #include <array> | ||||
| #include <functional> | ||||
| #include <memory> | ||||
| #include <thread> | ||||
| #include "core/hardware_properties.h" | ||||
| 
 | ||||
| namespace Common { | ||||
| class Event; | ||||
| class Fiber; | ||||
| } // namespace Common
 | ||||
| 
 | ||||
| namespace Core { | ||||
| 
 | ||||
| class CoreManager; | ||||
| class System; | ||||
| 
 | ||||
| class CpuManager { | ||||
|  | @ -27,21 +33,40 @@ public: | |||
|     void Initialize(); | ||||
|     void Shutdown(); | ||||
| 
 | ||||
|     CoreManager& GetCoreManager(std::size_t index); | ||||
|     const CoreManager& GetCoreManager(std::size_t index) const; | ||||
|     void Pause(bool paused); | ||||
| 
 | ||||
|     CoreManager& GetCurrentCoreManager(); | ||||
|     const CoreManager& GetCurrentCoreManager() const; | ||||
| 
 | ||||
|     std::size_t GetActiveCoreIndex() const { | ||||
|         return active_core; | ||||
|     } | ||||
| 
 | ||||
|     void RunLoop(bool tight_loop); | ||||
|     std::function<void(void*)> GetGuestThreadStartFunc(); | ||||
|     std::function<void(void*)> GetIdleThreadStartFunc(); | ||||
|     std::function<void(void*)> GetSuspendThreadStartFunc(); | ||||
|     void* GetStartFuncParamater(); | ||||
| 
 | ||||
| private: | ||||
|     std::array<std::unique_ptr<CoreManager>, Hardware::NUM_CPU_CORES> core_managers; | ||||
|     std::size_t active_core{}; ///< Active core, only used in single thread mode
 | ||||
|     static void GuestThreadFunction(void* cpu_manager); | ||||
|     static void IdleThreadFunction(void* cpu_manager); | ||||
|     static void SuspendThreadFunction(void* cpu_manager); | ||||
| 
 | ||||
|     void RunGuestThread(); | ||||
|     void RunIdleThread(); | ||||
|     void RunSuspendThread(); | ||||
| 
 | ||||
|     static void ThreadStart(CpuManager& cpu_manager, std::size_t core); | ||||
| 
 | ||||
|     void RunThread(std::size_t core); | ||||
| 
 | ||||
|     struct CoreData { | ||||
|         std::shared_ptr<Common::Fiber> host_context; | ||||
|         std::unique_ptr<Common::Event> enter_barrier; | ||||
|         std::unique_ptr<Common::Event> exit_barrier; | ||||
|         std::atomic<bool> is_running; | ||||
|         std::atomic<bool> is_paused; | ||||
|         std::atomic<bool> initialized; | ||||
|         std::unique_ptr<std::thread> host_thread; | ||||
|     }; | ||||
| 
 | ||||
|     std::atomic<bool> running_mode{}; | ||||
|     std::atomic<bool> paused_state{}; | ||||
| 
 | ||||
|     std::array<CoreData, Core::Hardware::NUM_CPU_CORES> core_data{}; | ||||
| 
 | ||||
|     System& system; | ||||
| }; | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Fernando Sahmkow
						Fernando Sahmkow