forked from eden-emu/eden
		
	Core::CoreTiming: add UnscheduleEventThreadsafe
This commit is contained in:
		
							parent
							
								
									34cba027e7
								
							
						
					
					
						commit
						8d6b45cd43
					
				
					 3 changed files with 12 additions and 1 deletions
				
			
		|  | @ -56,6 +56,9 @@ static u64 event_fifo_id; | |||
| // to the event_queue by the emu thread
 | ||||
| static Common::MPSCQueue<Event, false> ts_queue; | ||||
| 
 | ||||
| // the queue for unscheduling the events from other threads threadsafe
 | ||||
| static Common::MPSCQueue<std::pair<const EventType*, u64>, false> unschedule_queue; | ||||
| 
 | ||||
| constexpr int MAX_SLICE_LENGTH = 20000; | ||||
| 
 | ||||
| static s64 idled_cycles; | ||||
|  | @ -158,6 +161,10 @@ void UnscheduleEvent(const EventType* event_type, u64 userdata) { | |||
|     } | ||||
| } | ||||
| 
 | ||||
| void UnscheduleEventThreadsafe(const EventType* event_type, u64 userdata) { | ||||
|     unschedule_queue.Push(std::make_pair(event_type, userdata)); | ||||
| } | ||||
| 
 | ||||
| void RemoveEvent(const EventType* event_type) { | ||||
|     auto itr = std::remove_if(event_queue.begin(), event_queue.end(), | ||||
|                               [&](const Event& e) { return e.type == event_type; }); | ||||
|  | @ -194,6 +201,9 @@ void MoveEvents() { | |||
| 
 | ||||
| void Advance() { | ||||
|     MoveEvents(); | ||||
|     for (std::pair<const EventType*, u64> ev; unschedule_queue.Pop(ev);) { | ||||
|         UnscheduleEvent(ev.first, ev.second); | ||||
|     } | ||||
| 
 | ||||
|     int cycles_executed = slice_length - downcount; | ||||
|     global_timer += cycles_executed; | ||||
|  |  | |||
|  | @ -65,6 +65,7 @@ void ScheduleEvent(s64 cycles_into_future, const EventType* event_type, u64 user | |||
| void ScheduleEventThreadsafe(s64 cycles_into_future, const EventType* event_type, u64 userdata); | ||||
| 
 | ||||
| void UnscheduleEvent(const EventType* event_type, u64 userdata); | ||||
| void UnscheduleEventThreadsafe(const EventType* event_type, u64 userdata); | ||||
| 
 | ||||
| /// We only permit one event of each type in the queue at a time.
 | ||||
| void RemoveEvent(const EventType* event_type); | ||||
|  |  | |||
|  | @ -167,7 +167,7 @@ void Thread::WakeAfterDelay(s64 nanoseconds) { | |||
| } | ||||
| 
 | ||||
| void Thread::CancelWakeupTimer() { | ||||
|     CoreTiming::UnscheduleEvent(ThreadWakeupEventType, callback_handle); | ||||
|     CoreTiming::UnscheduleEventThreadsafe(ThreadWakeupEventType, callback_handle); | ||||
| } | ||||
| 
 | ||||
| static boost::optional<s32> GetNextProcessorId(u64 mask) { | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 B3n30
						B3n30