diff options
| author | balika011 <balika011@gmail.com> | 2018-10-05 14:51:16 -0400 | 
|---|---|---|
| committer | Lioncash <mathew1800@gmail.com> | 2018-10-05 14:53:01 -0400 | 
| commit | 1a5d6de0d46371b74828a2582506f1b3b2362589 (patch) | |
| tree | 4bbb722ae36f032c031018bf8650bcc3f2cd8faf /src/core/hle/kernel | |
| parent | e51d715700a35a8f14e5b804b6f7553c9a40888b (diff) | |
thread: Make the scheduler pointer a regular pointer
Conceptually, it doesn't make sense for a thread to be able to persist
the lifetime of a scheduler. A scheduler should be taking care of the
threads; the threads should not be taking care of the scheduler.
If the threads outlive the scheduler (or we simply don't actually
terminate/shutdown the threads), then it should be considered a bug
that we need to fix.
Attributing this to balika011, as they opened #1317 to attempt to fix
this in a similar way, but my refactoring of the kernel code caused
quite a few conflicts.
Diffstat (limited to 'src/core/hle/kernel')
| -rw-r--r-- | src/core/hle/kernel/thread.cpp | 6 | ||||
| -rw-r--r-- | src/core/hle/kernel/thread.h | 2 | 
2 files changed, 4 insertions, 4 deletions
| diff --git a/src/core/hle/kernel/thread.cpp b/src/core/hle/kernel/thread.cpp index 354043c53..8e514cf9a 100644 --- a/src/core/hle/kernel/thread.cpp +++ b/src/core/hle/kernel/thread.cpp @@ -169,7 +169,7 @@ void Thread::ResumeFromWait() {      next_scheduler->ScheduleThread(this, current_priority);      // Change thread's scheduler -    scheduler = next_scheduler; +    scheduler = next_scheduler.get();      Core::System::GetInstance().CpuCore(processor_id).PrepareReschedule();  } @@ -233,7 +233,7 @@ ResultVal<SharedPtr<Thread>> Thread::Create(KernelCore& kernel, std::string name      thread->name = std::move(name);      thread->callback_handle = kernel.ThreadWakeupCallbackHandleTable().Create(thread).Unwrap();      thread->owner_process = owner_process; -    thread->scheduler = Core::System::GetInstance().Scheduler(processor_id); +    thread->scheduler = Core::System::GetInstance().Scheduler(processor_id).get();      thread->scheduler->AddThread(thread, priority);      thread->tls_address = thread->owner_process->MarkNextAvailableTLSSlotAsUsed(*thread); @@ -400,7 +400,7 @@ void Thread::ChangeCore(u32 core, u64 mask) {      next_scheduler->ScheduleThread(this, current_priority);      // Change thread's scheduler -    scheduler = next_scheduler; +    scheduler = next_scheduler.get();      Core::System::GetInstance().CpuCore(processor_id).PrepareReschedule();  } diff --git a/src/core/hle/kernel/thread.h b/src/core/hle/kernel/thread.h index d2b191357..c6ffbd28c 100644 --- a/src/core/hle/kernel/thread.h +++ b/src/core/hle/kernel/thread.h @@ -419,7 +419,7 @@ private:      /// available. In case of a timeout, the object will be nullptr.      WakeupCallback wakeup_callback; -    std::shared_ptr<Scheduler> scheduler; +    Scheduler* scheduler = nullptr;      u32 ideal_core{0xFFFFFFFF};      u64 affinity_mask{0x1}; | 
