diff options
author | Lioncash <mathew1800@gmail.com> | 2019-04-09 19:25:54 +0200 |
---|---|---|
committer | Lioncash <mathew1800@gmail.com> | 2019-04-12 04:11:40 +0200 |
commit | f2331a804a2fa300d9a7dc0d012e3242b7accdaf (patch) | |
tree | d7f61aa201effed9e37fc07c626218759fc75288 /src/core/cpu_core_manager.cpp | |
parent | Merge pull request #2235 from ReinUsesLisp/spirv-decompiler (diff) | |
download | yuzu-f2331a804a2fa300d9a7dc0d012e3242b7accdaf.tar yuzu-f2331a804a2fa300d9a7dc0d012e3242b7accdaf.tar.gz yuzu-f2331a804a2fa300d9a7dc0d012e3242b7accdaf.tar.bz2 yuzu-f2331a804a2fa300d9a7dc0d012e3242b7accdaf.tar.lz yuzu-f2331a804a2fa300d9a7dc0d012e3242b7accdaf.tar.xz yuzu-f2331a804a2fa300d9a7dc0d012e3242b7accdaf.tar.zst yuzu-f2331a804a2fa300d9a7dc0d012e3242b7accdaf.zip |
Diffstat (limited to '')
-rw-r--r-- | src/core/cpu_core_manager.cpp | 6 |
1 files changed, 4 insertions, 2 deletions
diff --git a/src/core/cpu_core_manager.cpp b/src/core/cpu_core_manager.cpp index 93bc5619c..8fcb4eeb1 100644 --- a/src/core/cpu_core_manager.cpp +++ b/src/core/cpu_core_manager.cpp @@ -19,17 +19,19 @@ void RunCpuCore(const System& system, Cpu& cpu_state) { } } // Anonymous namespace -CpuCoreManager::CpuCoreManager() = default; +CpuCoreManager::CpuCoreManager(System& system) : system{system} {} CpuCoreManager::~CpuCoreManager() = default; -void CpuCoreManager::Initialize(System& system) { +void CpuCoreManager::Initialize() { barrier = std::make_unique<CpuBarrier>(); exclusive_monitor = Cpu::MakeExclusiveMonitor(cores.size()); for (std::size_t index = 0; index < cores.size(); ++index) { cores[index] = std::make_unique<Cpu>(system, *exclusive_monitor, *barrier, index); } +} +void CpuCoreManager::StartThreads() { // Create threads for CPU cores 1-3, and build thread_to_cpu map // CPU core 0 is run on the main thread thread_to_cpu[std::this_thread::get_id()] = cores[0].get(); |