forked from eden-emu/eden
		
	core_timing: Make use of std::chrono with ScheduleEvent
This commit is contained in:
		
							parent
							
								
									263200f982
								
							
						
					
					
						commit
						8b50c660df
					
				
					 13 changed files with 58 additions and 49 deletions
				
			
		|  | @ -28,8 +28,7 @@ | |||
| 
 | ||||
| namespace Service::NVFlinger { | ||||
| 
 | ||||
| constexpr s64 frame_ticks = static_cast<s64>(1000000000 / 60); | ||||
| constexpr s64 frame_ticks_30fps = static_cast<s64>(1000000000 / 30); | ||||
| constexpr auto frame_ns = std::chrono::nanoseconds{1000000000 / 60}; | ||||
| 
 | ||||
| void NVFlinger::VSyncThread(NVFlinger& nv_flinger) { | ||||
|     nv_flinger.SplitVSync(); | ||||
|  | @ -71,16 +70,20 @@ NVFlinger::NVFlinger(Core::System& system) : system(system) { | |||
|         Core::Timing::CreateEvent("ScreenComposition", [this](u64 userdata, s64 ns_late) { | ||||
|             Lock(); | ||||
|             Compose(); | ||||
|             const auto ticks = GetNextTicks(); | ||||
|             this->system.CoreTiming().ScheduleEvent(std::max<s64>(0LL, ticks - ns_late), | ||||
|                                                     composition_event); | ||||
| 
 | ||||
|             const auto ticks = std::chrono::nanoseconds{GetNextTicks()}; | ||||
|             const auto ticks_delta = ticks - std::chrono::nanoseconds{ns_late}; | ||||
|             const auto future_ns = std::max(std::chrono::nanoseconds::zero(), ticks_delta); | ||||
| 
 | ||||
|             this->system.CoreTiming().ScheduleEvent(future_ns, composition_event); | ||||
|         }); | ||||
| 
 | ||||
|     if (system.IsMulticore()) { | ||||
|         is_running = true; | ||||
|         wait_event = std::make_unique<Common::Event>(); | ||||
|         vsync_thread = std::make_unique<std::thread>(VSyncThread, std::ref(*this)); | ||||
|     } else { | ||||
|         system.CoreTiming().ScheduleEvent(frame_ticks, composition_event); | ||||
|         system.CoreTiming().ScheduleEvent(frame_ns, composition_event); | ||||
|     } | ||||
| } | ||||
| 
 | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Lioncash
						Lioncash