diff options
author | bunnei <bunneidev@gmail.com> | 2020-12-31 11:13:02 +0100 |
---|---|---|
committer | bunnei <bunneidev@gmail.com> | 2021-01-29 06:42:25 +0100 |
commit | 47829850131f04075950b733cb93a3688e8afb5b (patch) | |
tree | 26f0cf0a7f9b01c0266b2b3752fb600953875129 /src/core/cpu_manager.cpp | |
parent | hle: kernel: KThread: Remove thread types that do not exist. (diff) | |
download | yuzu-47829850131f04075950b733cb93a3688e8afb5b.tar yuzu-47829850131f04075950b733cb93a3688e8afb5b.tar.gz yuzu-47829850131f04075950b733cb93a3688e8afb5b.tar.bz2 yuzu-47829850131f04075950b733cb93a3688e8afb5b.tar.lz yuzu-47829850131f04075950b733cb93a3688e8afb5b.tar.xz yuzu-47829850131f04075950b733cb93a3688e8afb5b.tar.zst yuzu-47829850131f04075950b733cb93a3688e8afb5b.zip |
Diffstat (limited to '')
-rw-r--r-- | src/core/cpu_manager.cpp | 13 |
1 files changed, 7 insertions, 6 deletions
diff --git a/src/core/cpu_manager.cpp b/src/core/cpu_manager.cpp index 018cd2e25..719258250 100644 --- a/src/core/cpu_manager.cpp +++ b/src/core/cpu_manager.cpp @@ -217,9 +217,9 @@ void CpuManager::SingleCoreRunGuestLoop() { physical_core = &kernel.CurrentPhysicalCore(); } system.ExitDynarmicProfile(); - thread->SetPhantomMode(true); + kernel.SetIsPhantomModeForSingleCore(true); system.CoreTiming().Advance(); - thread->SetPhantomMode(false); + kernel.SetIsPhantomModeForSingleCore(false); physical_core->ArmInterface().ClearExclusiveState(); PreemptSingleCore(); auto& scheduler = kernel.Scheduler(current_core); @@ -255,22 +255,23 @@ void CpuManager::SingleCoreRunSuspendThread() { void CpuManager::PreemptSingleCore(bool from_running_enviroment) { { - auto& scheduler = system.Kernel().Scheduler(current_core); + auto& kernel = system.Kernel(); + auto& scheduler = kernel.Scheduler(current_core); Kernel::KThread* current_thread = scheduler.GetCurrentThread(); if (idle_count >= 4 || from_running_enviroment) { if (!from_running_enviroment) { system.CoreTiming().Idle(); idle_count = 0; } - current_thread->SetPhantomMode(true); + kernel.SetIsPhantomModeForSingleCore(true); system.CoreTiming().Advance(); - current_thread->SetPhantomMode(false); + kernel.SetIsPhantomModeForSingleCore(false); } current_core.store((current_core + 1) % Core::Hardware::NUM_CPU_CORES); system.CoreTiming().ResetTicks(); scheduler.Unload(scheduler.GetCurrentThread()); - auto& next_scheduler = system.Kernel().Scheduler(current_core); + auto& next_scheduler = kernel.Scheduler(current_core); Common::Fiber::YieldTo(current_thread->GetHostContext(), next_scheduler.ControlContext()); } |