|
|
|
@ -12,6 +12,7 @@ |
|
|
|
|
|
|
|
#include "core/core.h"
|
|
|
|
#include "core/core_timing.h"
|
|
|
|
#include "core/core_timing_util.h"
|
|
|
|
#include "core/hle/kernel/address_arbiter.h"
|
|
|
|
#include "core/hle/kernel/client_port.h"
|
|
|
|
#include "core/hle/kernel/handle_table.h"
|
|
|
|
@ -96,6 +97,7 @@ struct KernelCore::Impl { |
|
|
|
|
|
|
|
InitializeSystemResourceLimit(kernel); |
|
|
|
InitializeThreads(); |
|
|
|
InitializePreemption(); |
|
|
|
} |
|
|
|
|
|
|
|
void Shutdown() { |
|
|
|
@ -111,6 +113,7 @@ struct KernelCore::Impl { |
|
|
|
|
|
|
|
thread_wakeup_callback_handle_table.Clear(); |
|
|
|
thread_wakeup_event_type = nullptr; |
|
|
|
preemption_event = nullptr; |
|
|
|
|
|
|
|
named_ports.clear(); |
|
|
|
} |
|
|
|
@ -133,6 +136,18 @@ struct KernelCore::Impl { |
|
|
|
system.CoreTiming().RegisterEvent("ThreadWakeupCallback", ThreadWakeupCallback); |
|
|
|
} |
|
|
|
|
|
|
|
void InitializePreemption() { |
|
|
|
preemption_event = system.CoreTiming().RegisterEvent( |
|
|
|
"PreemptionCallback", [this](u64 userdata, s64 cycles_late) { |
|
|
|
global_scheduler.PreemptThreads(); |
|
|
|
s64 time_interval = Core::Timing::msToCycles(std::chrono::milliseconds(10)); |
|
|
|
system.CoreTiming().ScheduleEvent(time_interval, preemption_event); |
|
|
|
}); |
|
|
|
|
|
|
|
s64 time_interval = Core::Timing::msToCycles(std::chrono::milliseconds(10)); |
|
|
|
system.CoreTiming().ScheduleEvent(time_interval, preemption_event); |
|
|
|
} |
|
|
|
|
|
|
|
std::atomic<u32> next_object_id{0}; |
|
|
|
std::atomic<u64> next_kernel_process_id{Process::InitialKIPIDMin}; |
|
|
|
std::atomic<u64> next_user_process_id{Process::ProcessIDMin}; |
|
|
|
@ -146,6 +161,7 @@ struct KernelCore::Impl { |
|
|
|
SharedPtr<ResourceLimit> system_resource_limit; |
|
|
|
|
|
|
|
Core::Timing::EventType* thread_wakeup_event_type = nullptr; |
|
|
|
Core::Timing::EventType* preemption_event = nullptr; |
|
|
|
// TODO(yuriks): This can be removed if Thread objects are explicitly pooled in the future,
|
|
|
|
// allowing us to simply use a pool index or similar.
|
|
|
|
Kernel::HandleTable thread_wakeup_callback_handle_table; |
|
|
|
|