// Copyright 2016 Citra Emulator Project // Licensed under GPLv2 or any later version // Refer to the license.txt file included. #pragma once #include #include #include #include "common/common_types.h" #include "core/arm/arm_interface.h" #include "core/arm/dynarmic/arm_dynarmic_cp15.h" namespace Memory { struct PageTable; class MemorySystem; } // namespace Memory namespace Core { class DynarmicUserCallbacks; class DynarmicExclusiveMonitor; class ExclusiveMonitor; class System; class ARM_Dynarmic final : public ARM_Interface { public: explicit ARM_Dynarmic(Core::System& system_, Memory::MemorySystem& memory_, u32 core_id_, std::shared_ptr timer, Core::ExclusiveMonitor& exclusive_monitor_); ~ARM_Dynarmic() override; void Run() override; void Step() override; void SetPC(u32 pc) override; u32 GetPC() const override; u32 GetReg(int index) const override; void SetReg(int index, u32 value) override; u32 GetVFPReg(int index) const override; void SetVFPReg(int index, u32 value) override; u32 GetVFPSystemReg(VFPSystemRegister reg) const override; void SetVFPSystemReg(VFPSystemRegister reg, u32 value) override; u32 GetCPSR() const override; void SetCPSR(u32 cpsr) override; u32 GetCP15Register(CP15Register reg) const override; void SetCP15Register(CP15Register reg, u32 value) override; void SaveContext(ThreadContext& ctx) override; void LoadContext(const ThreadContext& ctx) override; void PrepareReschedule() override; void ClearInstructionCache() override; void InvalidateCacheRange(u32 start_address, std::size_t length) override; void ClearExclusiveState() override; void SetPageTable(const std::shared_ptr& page_table) override; protected: std::shared_ptr GetPageTable() const override; private: void ServeBreak(); friend class DynarmicUserCallbacks; Core::System& system; Memory::MemorySystem& memory; std::unique_ptr cb; std::unique_ptr MakeJit(); u32 fpexc = 0; CP15State cp15_state; Core::DynarmicExclusiveMonitor& exclusive_monitor; Dynarmic::A32::Jit* jit = nullptr; std::shared_ptr current_page_table = nullptr; std::map, std::unique_ptr> jits; }; } // namespace Core