diff options
| author | bunnei <bunneidev@gmail.com> | 2022-04-11 21:13:01 -0700 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2022-04-11 21:13:01 -0700 | 
| commit | fd5e1e80dac515ecb4a1cf9a12665b6645349370 (patch) | |
| tree | 5ce6c5bc77fe663428b9b66d1990c3bd64332581 | |
| parent | fc258f1d7aa39870c3ca1bc1ab5850576a247d57 (diff) | |
| parent | b976cac49dd7bbfc461802d64d467f9c5b73ce3b (diff) | |
Merge pull request #8157 from lat9nq/kernel-races
kernel: Fix some data races
| -rw-r--r-- | src/core/hle/kernel/board/nintendo/nx/k_system_control.cpp | 6 | ||||
| -rw-r--r-- | src/core/hle/kernel/k_auto_object.h | 2 | ||||
| -rw-r--r-- | src/core/hle/kernel/k_process.h | 2 | ||||
| -rw-r--r-- | src/core/hle/kernel/k_scheduler_lock.h | 3 | ||||
| -rw-r--r-- | src/core/hle/kernel/k_thread.cpp | 4 | ||||
| -rw-r--r-- | src/core/hle/kernel/k_thread.h | 3 | ||||
| -rw-r--r-- | src/core/hle/kernel/kernel.cpp | 8 | 
7 files changed, 15 insertions, 13 deletions
| diff --git a/src/core/hle/kernel/board/nintendo/nx/k_system_control.cpp b/src/core/hle/kernel/board/nintendo/nx/k_system_control.cpp index 8027bec00..7765e7848 100644 --- a/src/core/hle/kernel/board/nintendo/nx/k_system_control.cpp +++ b/src/core/hle/kernel/board/nintendo/nx/k_system_control.cpp @@ -148,9 +148,9 @@ u64 GenerateUniformRange(u64 min, u64 max, F f) {  } // Anonymous namespace  u64 KSystemControl::GenerateRandomU64() { -    static std::random_device device; -    static std::mt19937 gen(device()); -    static std::uniform_int_distribution<u64> distribution(1, std::numeric_limits<u64>::max()); +    std::random_device device; +    std::mt19937 gen(device()); +    std::uniform_int_distribution<u64> distribution(1, std::numeric_limits<u64>::max());      return distribution(gen);  } diff --git a/src/core/hle/kernel/k_auto_object.h b/src/core/hle/kernel/k_auto_object.h index 05779f2d5..abdb8ae7c 100644 --- a/src/core/hle/kernel/k_auto_object.h +++ b/src/core/hle/kernel/k_auto_object.h @@ -163,7 +163,7 @@ public:          do {              ASSERT(cur_ref_count > 0);          } while (!m_ref_count.compare_exchange_weak(cur_ref_count, cur_ref_count - 1, -                                                    std::memory_order_relaxed)); +                                                    std::memory_order_acq_rel));          // If ref count hits zero, destroy the object.          if (cur_ref_count - 1 == 0) { diff --git a/src/core/hle/kernel/k_process.h b/src/core/hle/kernel/k_process.h index 48b17fc74..9f171e3da 100644 --- a/src/core/hle/kernel/k_process.h +++ b/src/core/hle/kernel/k_process.h @@ -422,7 +422,7 @@ private:      bool is_64bit_process = true;      /// Total running time for the process in ticks. -    u64 total_process_running_time_ticks = 0; +    std::atomic<u64> total_process_running_time_ticks = 0;      /// Per-process handle table for storing created object handles in.      KHandleTable handle_table; diff --git a/src/core/hle/kernel/k_scheduler_lock.h b/src/core/hle/kernel/k_scheduler_lock.h index 93c47f1b1..016e0a818 100644 --- a/src/core/hle/kernel/k_scheduler_lock.h +++ b/src/core/hle/kernel/k_scheduler_lock.h @@ -4,6 +4,7 @@  #pragma once +#include <atomic>  #include "common/assert.h"  #include "core/hle/kernel/k_spin_lock.h"  #include "core/hle/kernel/k_thread.h" @@ -75,7 +76,7 @@ private:      KernelCore& kernel;      KAlignedSpinLock spin_lock{};      s32 lock_count{}; -    KThread* owner_thread{}; +    std::atomic<KThread*> owner_thread{};  };  } // namespace Kernel diff --git a/src/core/hle/kernel/k_thread.cpp b/src/core/hle/kernel/k_thread.cpp index 94c8faf68..d3bb1c871 100644 --- a/src/core/hle/kernel/k_thread.cpp +++ b/src/core/hle/kernel/k_thread.cpp @@ -723,7 +723,7 @@ void KThread::UpdateState() {      ASSERT(kernel.GlobalSchedulerContext().IsLocked());      // Set our suspend flags in state. -    const auto old_state = thread_state; +    const ThreadState old_state = thread_state;      const auto new_state =          static_cast<ThreadState>(this->GetSuspendFlags()) | (old_state & ThreadState::Mask);      thread_state = new_state; @@ -738,7 +738,7 @@ void KThread::Continue() {      ASSERT(kernel.GlobalSchedulerContext().IsLocked());      // Clear our suspend flags in state. -    const auto old_state = thread_state; +    const ThreadState old_state = thread_state;      thread_state = old_state & ThreadState::Mask;      // Note the state change in scheduler. diff --git a/src/core/hle/kernel/k_thread.h b/src/core/hle/kernel/k_thread.h index f46db7298..d0fd85130 100644 --- a/src/core/hle/kernel/k_thread.h +++ b/src/core/hle/kernel/k_thread.h @@ -5,6 +5,7 @@  #pragma once  #include <array> +#include <atomic>  #include <span>  #include <string>  #include <utility> @@ -751,7 +752,7 @@ private:      KAffinityMask original_physical_affinity_mask{};      s32 original_physical_ideal_core_id{};      s32 num_core_migration_disables{}; -    ThreadState thread_state{}; +    std::atomic<ThreadState> thread_state{};      std::atomic<bool> termination_requested{};      bool wait_cancelled{};      bool cancellable{}; diff --git a/src/core/hle/kernel/kernel.cpp b/src/core/hle/kernel/kernel.cpp index 134a0b8e9..481a0d7cb 100644 --- a/src/core/hle/kernel/kernel.cpp +++ b/src/core/hle/kernel/kernel.cpp @@ -85,7 +85,7 @@ struct KernelCore::Impl {      void InitializeCores() {          for (u32 core_id = 0; core_id < Core::Hardware::NUM_CPU_CORES; core_id++) { -            cores[core_id].Initialize(current_process->Is64BitProcess()); +            cores[core_id].Initialize((*current_process).Is64BitProcess());              system.Memory().SetCurrentPageTable(*current_process, core_id);          }      } @@ -168,11 +168,11 @@ struct KernelCore::Impl {          // Shutdown all processes.          if (current_process) { -            current_process->Finalize(); +            (*current_process).Finalize();              // current_process->Close();              // TODO: The current process should be destroyed based on accurate ref counting after              // calling Close(). Adding a manual Destroy() call instead to avoid a memory leak. -            current_process->Destroy(); +            (*current_process).Destroy();              current_process = nullptr;          } @@ -704,7 +704,7 @@ struct KernelCore::Impl {      // Lists all processes that exist in the current session.      std::vector<KProcess*> process_list; -    KProcess* current_process{}; +    std::atomic<KProcess*> current_process{};      std::unique_ptr<Kernel::GlobalSchedulerContext> global_scheduler_context;      Kernel::TimeManager time_manager; | 
