diff options
| author | bunnei <bunneidev@gmail.com> | 2021-08-06 23:12:47 -0700 | 
|---|---|---|
| committer | bunnei <bunneidev@gmail.com> | 2021-12-06 16:39:16 -0800 | 
| commit | f412d2027a6e5798fe6fc3b43250bc2f5f1d17fc (patch) | |
| tree | 129eaee0437556121f8b5e986345b83cf7c4af24 /src/core | |
| parent | f13fce3953b376d2321645b4de4d023da0d6713d (diff) | |
core: hle: kernel: k_scheduler: Improve Unload.
Diffstat (limited to 'src/core')
| -rw-r--r-- | src/core/hle/kernel/k_scheduler.cpp | 46 | 
1 files changed, 29 insertions, 17 deletions
| diff --git a/src/core/hle/kernel/k_scheduler.cpp b/src/core/hle/kernel/k_scheduler.cpp index 4bae69f71..5ee4b8adc 100644 --- a/src/core/hle/kernel/k_scheduler.cpp +++ b/src/core/hle/kernel/k_scheduler.cpp @@ -650,6 +650,7 @@ void KScheduler::RescheduleCurrentCore() {      if (state.needs_scheduling.load()) {          Schedule();      } else { +        GetCurrentThread()->EnableDispatch();          guard.Unlock();      }  } @@ -659,26 +660,37 @@ void KScheduler::OnThreadStart() {  }  void KScheduler::Unload(KThread* thread) { +    ASSERT(thread); + +    if (!thread) { +        return; +    } +      LOG_TRACE(Kernel, "core {}, unload thread {}", core_id, thread ? thread->GetName() : "nullptr"); -    if (thread) { -        if (thread->IsCallingSvc()) { -            thread->ClearIsCallingSvc(); -        } -        if (!thread->IsTerminationRequested()) { -            prev_thread = thread; - -            Core::ARM_Interface& cpu_core = system.ArmInterface(core_id); -            cpu_core.SaveContext(thread->GetContext32()); -            cpu_core.SaveContext(thread->GetContext64()); -            // Save the TPIDR_EL0 system register in case it was modified. -            thread->SetTPIDR_EL0(cpu_core.GetTPIDR_EL0()); -            cpu_core.ClearExclusiveState(); -        } else { -            prev_thread = nullptr; -        } -        thread->context_guard.Unlock(); +    if (thread->IsCallingSvc()) { +        thread->ClearIsCallingSvc();      } + +    auto& physical_core = system.Kernel().PhysicalCore(core_id); +    if (!physical_core.IsInitialized()) { +        return; +    } + +    Core::ARM_Interface& cpu_core = physical_core.ArmInterface(); +    cpu_core.SaveContext(thread->GetContext32()); +    cpu_core.SaveContext(thread->GetContext64()); +    // Save the TPIDR_EL0 system register in case it was modified. +    thread->SetTPIDR_EL0(cpu_core.GetTPIDR_EL0()); +    cpu_core.ClearExclusiveState(); + +    if (!thread->IsTerminationRequested() && thread->GetActiveCore() == core_id) { +        prev_thread = thread; +    } else { +        prev_thread = nullptr; +    } + +    thread->context_guard.Unlock();  }  void KScheduler::Reload(KThread* thread) { | 
