mirror of
				https://github.com/RGBCube/serenity
				synced 2025-10-31 08:32:43 +00:00 
			
		
		
		
	Kernel: Move Scheduler current time method to the TimeManagement code
This commit is contained in:
		
							parent
							
								
									3651d9701e
								
							
						
					
					
						commit
						7520acd4eb
					
				
					 5 changed files with 29 additions and 22 deletions
				
			
		|  | @ -928,7 +928,7 @@ void Processor::enter_trap(TrapFrame& trap, bool raise_irq) | |||
|         // The cs register of this trap tells us where we will return back to
 | ||||
|         auto new_previous_mode = ((trap.regs->cs & 3) != 0) ? Thread::PreviousMode::UserMode : Thread::PreviousMode::KernelMode; | ||||
|         if (current_thread->set_previous_mode(new_previous_mode) && trap.prev_irq_level == 0) { | ||||
|             current_thread->update_time_scheduled(Scheduler::current_time(), new_previous_mode == Thread::PreviousMode::KernelMode, false); | ||||
|             current_thread->update_time_scheduled(TimeManagement::scheduler_current_time(), new_previous_mode == Thread::PreviousMode::KernelMode, false); | ||||
|         } | ||||
|     } else { | ||||
|         trap.next_trap = nullptr; | ||||
|  | @ -975,7 +975,7 @@ void Processor::exit_trap(TrapFrame& trap) | |||
|         } | ||||
| 
 | ||||
|         if (current_thread->set_previous_mode(new_previous_mode)) | ||||
|             current_thread->update_time_scheduled(Scheduler::current_time(), true, false); | ||||
|             current_thread->update_time_scheduled(TimeManagement::scheduler_current_time(), true, false); | ||||
|     } | ||||
| 
 | ||||
|     VERIFY_INTERRUPTS_DISABLED(); | ||||
|  |  | |||
|  | @ -8,7 +8,6 @@ | |||
| #include <AK/ScopeGuard.h> | ||||
| #include <AK/Singleton.h> | ||||
| #include <AK/Time.h> | ||||
| #include <Kernel/Arch/CurrentTime.h> | ||||
| #include <Kernel/Arch/InterruptDisabler.h> | ||||
| #include <Kernel/Arch/x86/TrapFrame.h> | ||||
| #include <Kernel/Debug.h> | ||||
|  | @ -51,10 +50,6 @@ static Singleton<SpinlockProtected<ThreadReadyQueues>> g_ready_queues; | |||
| 
 | ||||
| static SpinlockProtected<TotalTimeScheduled> g_total_time_scheduled { LockRank::None }; | ||||
| 
 | ||||
| // The Scheduler::current_time function provides a current time for scheduling purposes,
 | ||||
| // which may not necessarily relate to wall time
 | ||||
| u64 (*Scheduler::current_time)(); | ||||
| 
 | ||||
| static void dump_thread_list(bool = false); | ||||
| 
 | ||||
| static inline u32 thread_priority_to_priority_index(u32 thread_priority) | ||||
|  | @ -309,7 +304,7 @@ void Scheduler::enter_current(Thread& prev_thread) | |||
|     VERIFY(g_scheduler_lock.is_locked_by_current_processor()); | ||||
| 
 | ||||
|     // We already recorded the scheduled time when entering the trap, so this merely accounts for the kernel time since then
 | ||||
|     auto scheduler_time = Scheduler::current_time(); | ||||
|     auto scheduler_time = TimeManagement::scheduler_current_time(); | ||||
|     prev_thread.update_time_scheduled(scheduler_time, true, true); | ||||
|     auto* current_thread = Thread::current(); | ||||
|     current_thread->update_time_scheduled(scheduler_time, true, false); | ||||
|  | @ -366,21 +361,10 @@ Process* Scheduler::colonel() | |||
|     return s_colonel_process; | ||||
| } | ||||
| 
 | ||||
| static u64 current_time_monotonic() | ||||
| { | ||||
|     // We always need a precise timestamp here, we cannot rely on a coarse timestamp
 | ||||
|     return (u64)TimeManagement::the().monotonic_time(TimePrecision::Precise).to_nanoseconds(); | ||||
| } | ||||
| 
 | ||||
| UNMAP_AFTER_INIT void Scheduler::initialize() | ||||
| { | ||||
|     VERIFY(Processor::is_initialized()); // sanity check
 | ||||
| 
 | ||||
|     auto* possible_arch_specific_current_time_function = optional_current_time(); | ||||
|     if (possible_arch_specific_current_time_function) | ||||
|         current_time = possible_arch_specific_current_time_function; | ||||
|     else | ||||
|         current_time = current_time_monotonic; | ||||
|     VERIFY(TimeManagement::is_initialized()); | ||||
| 
 | ||||
|     LockRefPtr<Thread> idle_thread; | ||||
|     g_finalizer_wait_queue = new WaitQueue; | ||||
|  | @ -440,7 +424,7 @@ void Scheduler::timer_tick(RegisterState const& regs) | |||
|         // Because the previous mode when entering/exiting kernel threads never changes
 | ||||
|         // we never update the time scheduled. So we need to update it manually on the
 | ||||
|         // timer interrupt
 | ||||
|         current_thread->update_time_scheduled(current_time(), true, false); | ||||
|         current_thread->update_time_scheduled(TimeManagement::scheduler_current_time(), true, false); | ||||
|     } | ||||
| 
 | ||||
|     if (current_thread->previous_mode() == Thread::PreviousMode::UserMode && current_thread->should_die() && !current_thread->is_blocked()) { | ||||
|  |  | |||
|  | @ -55,7 +55,6 @@ public: | |||
|     static bool is_initialized(); | ||||
|     static TotalTimeScheduled get_total_time_scheduled(); | ||||
|     static void add_time_scheduled(u64, bool); | ||||
|     static u64 (*current_time)(); | ||||
| }; | ||||
| 
 | ||||
| } | ||||
|  |  | |||
|  | @ -17,6 +17,7 @@ | |||
| #    include <Kernel/Arch/x86/common/Interrupts/APIC.h> | ||||
| #    include <Kernel/Arch/x86/common/RTC.h> | ||||
| #endif | ||||
| #include <Kernel/Arch/CurrentTime.h> | ||||
| #include <Kernel/CommandLine.h> | ||||
| #include <Kernel/Firmware/ACPI/Parser.h> | ||||
| #include <Kernel/PerformanceManager.h> | ||||
|  | @ -40,6 +41,22 @@ TimeManagement& TimeManagement::the() | |||
|     return *s_the; | ||||
| } | ||||
| 
 | ||||
| // The s_scheduler_specific_current_time function provides a current time for scheduling purposes,
 | ||||
| // which may not necessarily relate to wall time
 | ||||
| static u64 (*s_scheduler_current_time)(); | ||||
| 
 | ||||
| static u64 current_time_monotonic() | ||||
| { | ||||
|     // We always need a precise timestamp here, we cannot rely on a coarse timestamp
 | ||||
|     return (u64)TimeManagement::the().monotonic_time(TimePrecision::Precise).to_nanoseconds(); | ||||
| } | ||||
| 
 | ||||
| u64 TimeManagement::scheduler_current_time() | ||||
| { | ||||
|     VERIFY(s_scheduler_current_time); | ||||
|     return s_scheduler_current_time(); | ||||
| } | ||||
| 
 | ||||
| ErrorOr<void> TimeManagement::validate_clock_id(clockid_t clock_id) | ||||
| { | ||||
|     switch (clock_id) { | ||||
|  | @ -163,6 +180,11 @@ UNMAP_AFTER_INIT void TimeManagement::initialize([[maybe_unused]] u32 cpu) | |||
|             apic_timer->enable_local_timer(); | ||||
|         } | ||||
|     } | ||||
|     auto* possible_arch_specific_current_time_function = optional_current_time(); | ||||
|     if (possible_arch_specific_current_time_function) | ||||
|         s_scheduler_current_time = possible_arch_specific_current_time_function; | ||||
|     else | ||||
|         s_scheduler_current_time = current_time_monotonic; | ||||
| #endif | ||||
| } | ||||
| 
 | ||||
|  |  | |||
|  | @ -37,6 +37,8 @@ public: | |||
|     static bool is_initialized(); | ||||
|     static TimeManagement& the(); | ||||
| 
 | ||||
|     static u64 scheduler_current_time(); | ||||
| 
 | ||||
|     static ErrorOr<void> validate_clock_id(clockid_t); | ||||
|     Time current_time(clockid_t) const; | ||||
|     Time monotonic_time(TimePrecision = TimePrecision::Coarse) const; | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Liav A
						Liav A