summaryrefslogtreecommitdiffstats
path: root/src/core/hle/kernel/physical_core.cpp
diff options
context:
space:
mode:
authorbunnei <bunneidev@gmail.com>2022-01-09 11:17:17 +0100
committerbunnei <bunneidev@gmail.com>2022-01-12 01:28:11 +0100
commit49a0e4330ee37bdfa503918f841ab9599ccc1c24 (patch)
treee38e9dc90acbbf4fa8d64ea8c30736a86f32b37b /src/core/hle/kernel/physical_core.cpp
parenthle: service: ldr: UnmapCodeMemory BSS only when set. (diff)
downloadyuzu-49a0e4330ee37bdfa503918f841ab9599ccc1c24.tar
yuzu-49a0e4330ee37bdfa503918f841ab9599ccc1c24.tar.gz
yuzu-49a0e4330ee37bdfa503918f841ab9599ccc1c24.tar.bz2
yuzu-49a0e4330ee37bdfa503918f841ab9599ccc1c24.tar.lz
yuzu-49a0e4330ee37bdfa503918f841ab9599ccc1c24.tar.xz
yuzu-49a0e4330ee37bdfa503918f841ab9599ccc1c24.tar.zst
yuzu-49a0e4330ee37bdfa503918f841ab9599ccc1c24.zip
Diffstat (limited to '')
-rw-r--r--src/core/hle/kernel/physical_core.cpp18
1 files changed, 13 insertions, 5 deletions
diff --git a/src/core/hle/kernel/physical_core.cpp b/src/core/hle/kernel/physical_core.cpp
index 7f02d9471..7477668e4 100644
--- a/src/core/hle/kernel/physical_core.cpp
+++ b/src/core/hle/kernel/physical_core.cpp
@@ -16,17 +16,25 @@ namespace Kernel {
PhysicalCore::PhysicalCore(std::size_t core_index_, Core::System& system_, KScheduler& scheduler_,
Core::CPUInterrupts& interrupts_)
: core_index{core_index_}, system{system_}, scheduler{scheduler_},
- interrupts{interrupts_}, guard{std::make_unique<Common::SpinLock>()} {}
+ interrupts{interrupts_}, guard{std::make_unique<Common::SpinLock>()} {
+#ifdef ARCHITECTURE_x86_64
+ // TODO(bunnei): Initialization relies on a core being available. We may later replace this with
+ // a 32-bit instance of Dynarmic. This should be abstracted out to a CPU manager.
+ auto& kernel = system.Kernel();
+ arm_interface = std::make_unique<Core::ARM_Dynarmic_64>(
+ system, interrupts, kernel.IsMulticore(), kernel.GetExclusiveMonitor(), core_index);
+#else
+#error Platform not supported yet.
+#endif
+}
PhysicalCore::~PhysicalCore() = default;
void PhysicalCore::Initialize([[maybe_unused]] bool is_64_bit) {
#ifdef ARCHITECTURE_x86_64
auto& kernel = system.Kernel();
- if (is_64_bit) {
- arm_interface = std::make_unique<Core::ARM_Dynarmic_64>(
- system, interrupts, kernel.IsMulticore(), kernel.GetExclusiveMonitor(), core_index);
- } else {
+ if (!is_64_bit) {
+ // We already initialized a 64-bit core, replace with a 32-bit one.
arm_interface = std::make_unique<Core::ARM_Dynarmic_32>(
system, interrupts, kernel.IsMulticore(), kernel.GetExclusiveMonitor(), core_index);
}