From 424fdb5c5026ec5bdd7553271190397f63fb503e Mon Sep 17 00:00:00 2001 From: Liam Date: Wed, 9 Nov 2022 16:40:32 -0500 Subject: [PATCH] a64_interface: stub for A64 backend --- src/dynarmic/CMakeLists.txt | 3 + src/dynarmic/backend/arm64/a64_interface.cpp | 146 +++++++++++++++++++ 2 files changed, 149 insertions(+) create mode 100644 src/dynarmic/backend/arm64/a64_interface.cpp diff --git a/src/dynarmic/CMakeLists.txt b/src/dynarmic/CMakeLists.txt index 9b7d7cb1..8ae02cf3 100644 --- a/src/dynarmic/CMakeLists.txt +++ b/src/dynarmic/CMakeLists.txt @@ -406,6 +406,9 @@ elseif(ARCHITECTURE STREQUAL "arm64") backend/arm64/a32_address_space.h backend/arm64/a32_core.h backend/arm64/a32_interface.cpp + + # Move this to the list below when implemented + backend/arm64/a64_interface.cpp ) endif() diff --git a/src/dynarmic/backend/arm64/a64_interface.cpp b/src/dynarmic/backend/arm64/a64_interface.cpp new file mode 100644 index 00000000..36ffbdc4 --- /dev/null +++ b/src/dynarmic/backend/arm64/a64_interface.cpp @@ -0,0 +1,146 @@ +/* This file is part of the dynarmic project. + * Copyright (c) 2021 MerryMage + * SPDX-License-Identifier: 0BSD + */ + +#include +#include + +#include +#include +#include +#include + +#include "dynarmic/common/atomic.h" +#include "dynarmic/interface/A64/a64.h" +#include "dynarmic/interface/A64/config.h" + +namespace Dynarmic::A64 { + +struct Jit::Impl {}; + +Jit::Jit(UserConfig conf) { + (void)conf; +} + +Jit::~Jit() = default; + +HaltReason Jit::Run() { + ASSERT_FALSE("not implemented"); +} + +HaltReason Jit::Step() { + ASSERT_FALSE("not implemented"); +} + +void Jit::ClearCache() { +} + +void Jit::InvalidateCacheRange(std::uint64_t start_address, std::size_t length) { + (void)start_address; + (void)length; +} + +void Jit::Reset() { +} + +void Jit::HaltExecution(HaltReason hr) { + (void)hr; +} + +void Jit::ClearHalt(HaltReason hr) { + (void)hr; +} + +std::uint64_t Jit::GetSP() const { + return 0; +} + +void Jit::SetSP(std::uint64_t value) { + (void)value; +} + +std::uint64_t Jit::GetPC() const { + return 0; +} + +void Jit::SetPC(std::uint64_t value) { + (void)value; +} + +std::uint64_t Jit::GetRegister(std::size_t index) const { + (void)index; + return 0; +} + +void Jit::SetRegister(size_t index, std::uint64_t value) { + (void)index; + (void)value; +} + +std::array Jit::GetRegisters() const { + return {}; +} + +void Jit::SetRegisters(const std::array& value) { + (void)value; +} + +Vector Jit::GetVector(std::size_t index) const { + (void)index; + return {}; +} + +void Jit::SetVector(std::size_t index, Vector value) { + (void)index; + (void)value; +} + +std::array Jit::GetVectors() const { + return {}; +} + +void Jit::SetVectors(const std::array& value) { + (void)value; +} + +std::uint32_t Jit::GetFpcr() const { + return 0; +} + +void Jit::SetFpcr(std::uint32_t value) { + (void)value; +} + +std::uint32_t Jit::GetFpsr() const { + return 0; +} + +void Jit::SetFpsr(std::uint32_t value) { + (void)value; +} + +std::uint32_t Jit::GetPstate() const { + return 0; +} + +void Jit::SetPstate(std::uint32_t value) { + (void)value; +} + +void Jit::ClearExclusiveState() { +} + +bool Jit::IsExecuting() const { + return false; +} + +void Jit::DumpDisassembly() const { + ASSERT_FALSE("not implemented"); +} + +std::vector Jit::Disassemble() const { + ASSERT_FALSE("not implemented"); +} + +} // namespace Dynarmic::A64