diff options
Diffstat (limited to 'src/core/hle/kernel')
| -rw-r--r-- | src/core/hle/kernel/memory/page_table.cpp | 1 | ||||
| -rw-r--r-- | src/core/hle/kernel/scheduler.cpp | 28 | 
2 files changed, 11 insertions, 18 deletions
| diff --git a/src/core/hle/kernel/memory/page_table.cpp b/src/core/hle/kernel/memory/page_table.cpp index 5d6aac00f..e22e07206 100644 --- a/src/core/hle/kernel/memory/page_table.cpp +++ b/src/core/hle/kernel/memory/page_table.cpp @@ -604,7 +604,6 @@ ResultCode PageTable::MapPages(VAddr addr, const PageLinkedList& page_linked_lis          if (const auto result{                  Operate(cur_addr, node.GetNumPages(), perm, OperationType::Map, node.GetAddress())};              result.IsError()) { -            const MemoryInfo info{block_manager->FindBlock(cur_addr).GetMemoryInfo()};              const std::size_t num_pages{(addr - cur_addr) / PageSize};              ASSERT( diff --git a/src/core/hle/kernel/scheduler.cpp b/src/core/hle/kernel/scheduler.cpp index f93e5e4b0..77c095ef2 100644 --- a/src/core/hle/kernel/scheduler.cpp +++ b/src/core/hle/kernel/scheduler.cpp @@ -663,32 +663,26 @@ void Scheduler::Reload() {  }  void Scheduler::SwitchContextStep2() { -    Thread* previous_thread = current_thread_prev.get(); -    Thread* new_thread = selected_thread.get(); -      // Load context of new thread -    Process* const previous_process = -        previous_thread != nullptr ? previous_thread->GetOwnerProcess() : nullptr; - -    if (new_thread) { -        ASSERT_MSG(new_thread->GetSchedulingStatus() == ThreadSchedStatus::Runnable, +    if (selected_thread) { +        ASSERT_MSG(selected_thread->GetSchedulingStatus() == ThreadSchedStatus::Runnable,                     "Thread must be runnable.");          // Cancel any outstanding wakeup events for this thread -        new_thread->SetIsRunning(true); -        new_thread->last_running_ticks = system.CoreTiming().GetCPUTicks(); -        new_thread->SetWasRunning(false); +        selected_thread->SetIsRunning(true); +        selected_thread->last_running_ticks = system.CoreTiming().GetCPUTicks(); +        selected_thread->SetWasRunning(false);          auto* const thread_owner_process = current_thread->GetOwnerProcess();          if (thread_owner_process != nullptr) {              system.Kernel().MakeCurrentProcess(thread_owner_process);          } -        if (!new_thread->IsHLEThread()) { -            Core::ARM_Interface& cpu_core = new_thread->ArmInterface(); -            cpu_core.LoadContext(new_thread->GetContext32()); -            cpu_core.LoadContext(new_thread->GetContext64()); -            cpu_core.SetTlsAddress(new_thread->GetTLSAddress()); -            cpu_core.SetTPIDR_EL0(new_thread->GetTPIDR_EL0()); +        if (!selected_thread->IsHLEThread()) { +            Core::ARM_Interface& cpu_core = selected_thread->ArmInterface(); +            cpu_core.LoadContext(selected_thread->GetContext32()); +            cpu_core.LoadContext(selected_thread->GetContext64()); +            cpu_core.SetTlsAddress(selected_thread->GetTLSAddress()); +            cpu_core.SetTPIDR_EL0(selected_thread->GetTPIDR_EL0());              cpu_core.ChangeProcessorID(this->core_id);              cpu_core.ClearExclusiveState();          } | 
