forked from eden-emu/eden
		
	Core Timing: Rework Core Timing to run all cores evenly.
This commit is contained in:
		
							parent
							
								
									f9b784f1a6
								
							
						
					
					
						commit
						93a18da674
					
				
					 6 changed files with 89 additions and 38 deletions
				
			
		|  | @ -85,24 +85,16 @@ void Cpu::RunLoop(bool tight_loop) { | |||
|     // instead advance to the next event and try to yield to the next thread
 | ||||
|     if (Kernel::GetCurrentThread() == nullptr) { | ||||
|         LOG_TRACE(Core, "Core-{} idling", core_index); | ||||
| 
 | ||||
|         if (IsMainCore()) { | ||||
|             // TODO(Subv): Only let CoreTiming idle if all 4 cores are idling.
 | ||||
|             core_timing.Idle(); | ||||
|             core_timing.Advance(); | ||||
|         } | ||||
| 
 | ||||
|         core_timing.Idle(); | ||||
|         core_timing.Advance(); | ||||
|         PrepareReschedule(); | ||||
|     } else { | ||||
|         if (IsMainCore()) { | ||||
|             core_timing.Advance(); | ||||
|         } | ||||
| 
 | ||||
|         if (tight_loop) { | ||||
|             arm_interface->Run(); | ||||
|         } else { | ||||
|             arm_interface->Step(); | ||||
|         } | ||||
|         core_timing.Advance(); | ||||
|     } | ||||
| 
 | ||||
|     Reschedule(); | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Fernando Sahmkow
						Fernando Sahmkow