yuzu/src/core/hle/kernel/physical_core.h

105 lines
2.3 KiB
C++
Raw Normal View History

2020-01-24 20:38:20 +01:00
// Copyright 2020 yuzu Emulator Project
// Licensed under GPLv2 or any later version
// Refer to the license.txt file included.
#pragma once
2020-01-26 21:14:18 +01:00
#include <cstddef>
#include <memory>
#include "core/arm/cpu_interrupt_handler.h"
namespace Common {
class SpinLock;
}
2020-01-24 20:38:20 +01:00
namespace Kernel {
class Scheduler;
} // namespace Kernel
namespace Core {
2020-01-24 20:38:20 +01:00
class ARM_Interface;
class ExclusiveMonitor;
class System;
} // namespace Core
2020-01-24 20:38:20 +01:00
namespace Kernel {
class PhysicalCore {
public:
PhysicalCore(Core::System& system, std::size_t id, Core::ExclusiveMonitor& exclusive_monitor);
2020-01-26 21:14:18 +01:00
~PhysicalCore();
2020-01-24 20:38:20 +01:00
PhysicalCore(const PhysicalCore&) = delete;
PhysicalCore& operator=(const PhysicalCore&) = delete;
PhysicalCore(PhysicalCore&&) = default;
PhysicalCore& operator=(PhysicalCore&&) = default;
2020-01-24 20:38:20 +01:00
/// Execute current jit state
void Run();
/// Clear Exclusive state.
void ClearExclusive();
/// Set this core in IdleState.
void Idle();
2020-01-24 20:38:20 +01:00
/// Execute a single instruction in current jit.
void Step();
/// Stop JIT execution/exit
void Stop();
/// Interrupt this physical core.
void Interrupt();
/// Clear this core's interrupt
void ClearInterrupt();
/// Check if this core is interrupted
bool IsInterrupted() const {
return interrupt_handler.IsInterrupted();
}
// Shutdown this physical core.
void Shutdown();
Core::ARM_Interface& ArmInterface() {
2020-01-24 20:38:20 +01:00
return *arm_interface;
}
const Core::ARM_Interface& ArmInterface() const {
2020-01-24 20:38:20 +01:00
return *arm_interface;
}
bool IsMainCore() const {
return core_index == 0;
}
bool IsSystemCore() const {
return core_index == 3;
}
std::size_t CoreIndex() const {
return core_index;
}
Kernel::Scheduler& Scheduler() {
2020-01-24 20:38:20 +01:00
return *scheduler;
}
const Kernel::Scheduler& Scheduler() const {
2020-01-24 20:38:20 +01:00
return *scheduler;
}
void SetIs64Bit(bool is_64_bit);
2020-01-24 20:38:20 +01:00
private:
Core::CPUInterruptHandler interrupt_handler;
2020-01-24 20:38:20 +01:00
std::size_t core_index;
std::unique_ptr<Core::ARM_Interface> arm_interface_32;
std::unique_ptr<Core::ARM_Interface> arm_interface_64;
std::unique_ptr<Kernel::Scheduler> scheduler;
Core::ARM_Interface* arm_interface{};
std::unique_ptr<Common::SpinLock> guard;
};
2020-01-24 20:38:20 +01:00
} // namespace Kernel