diff options
| author | 2022-05-30 19:35:01 -0400 | |
|---|---|---|
| committer | 2022-06-01 00:01:25 -0400 | |
| commit | fb4b3c127f7c390358d7f4cadd2f58de116fec48 (patch) | |
| tree | e2588a859d364a32be0cd9e0401a345c6492d1a7 /src/core/debugger/gdbstub_arch.h | |
| parent | Merge pull request #8368 from german77/seventimes (diff) | |
| download | yuzu-fb4b3c127f7c390358d7f4cadd2f58de116fec48.tar.gz yuzu-fb4b3c127f7c390358d7f4cadd2f58de116fec48.tar.xz yuzu-fb4b3c127f7c390358d7f4cadd2f58de116fec48.zip | |
core/debugger: Implement new GDB stub debugger
Diffstat (limited to 'src/core/debugger/gdbstub_arch.h')
| -rw-r--r-- | src/core/debugger/gdbstub_arch.h | 67 |
1 files changed, 67 insertions, 0 deletions
diff --git a/src/core/debugger/gdbstub_arch.h b/src/core/debugger/gdbstub_arch.h new file mode 100644 index 000000000..e943848e5 --- /dev/null +++ b/src/core/debugger/gdbstub_arch.h | |||
| @@ -0,0 +1,67 @@ | |||
| 1 | // SPDX-FileCopyrightText: Copyright 2022 yuzu Emulator Project | ||
| 2 | // SPDX-License-Identifier: GPL-2.0-or-later | ||
| 3 | |||
| 4 | #pragma once | ||
| 5 | |||
| 6 | #include <string> | ||
| 7 | |||
| 8 | #include "common/common_types.h" | ||
| 9 | |||
| 10 | namespace Kernel { | ||
| 11 | class KThread; | ||
| 12 | } | ||
| 13 | |||
| 14 | namespace Core { | ||
| 15 | |||
| 16 | class GDBStubArch { | ||
| 17 | public: | ||
| 18 | virtual std::string GetTargetXML() const = 0; | ||
| 19 | virtual std::string RegRead(const Kernel::KThread* thread, size_t id) const = 0; | ||
| 20 | virtual void RegWrite(Kernel::KThread* thread, size_t id, std::string_view value) const = 0; | ||
| 21 | virtual std::string ReadRegisters(const Kernel::KThread* thread) const = 0; | ||
| 22 | virtual void WriteRegisters(Kernel::KThread* thread, std::string_view register_data) const = 0; | ||
| 23 | virtual std::string ThreadStatus(const Kernel::KThread* thread, u8 signal) const = 0; | ||
| 24 | virtual u32 BreakpointInstruction() const = 0; | ||
| 25 | }; | ||
| 26 | |||
| 27 | class GDBStubA64 final : public GDBStubArch { | ||
| 28 | public: | ||
| 29 | std::string GetTargetXML() const override; | ||
| 30 | std::string RegRead(const Kernel::KThread* thread, size_t id) const override; | ||
| 31 | void RegWrite(Kernel::KThread* thread, size_t id, std::string_view value) const override; | ||
| 32 | std::string ReadRegisters(const Kernel::KThread* thread) const override; | ||
| 33 | void WriteRegisters(Kernel::KThread* thread, std::string_view register_data) const override; | ||
| 34 | std::string ThreadStatus(const Kernel::KThread* thread, u8 signal) const override; | ||
| 35 | u32 BreakpointInstruction() const override; | ||
| 36 | |||
| 37 | private: | ||
| 38 | static constexpr u32 LR_REGISTER = 30; | ||
| 39 | static constexpr u32 SP_REGISTER = 31; | ||
| 40 | static constexpr u32 PC_REGISTER = 32; | ||
| 41 | static constexpr u32 PSTATE_REGISTER = 33; | ||
| 42 | static constexpr u32 Q0_REGISTER = 34; | ||
| 43 | static constexpr u32 FPCR_REGISTER = 66; | ||
| 44 | static constexpr u32 FPSR_REGISTER = 67; | ||
| 45 | }; | ||
| 46 | |||
| 47 | class GDBStubA32 final : public GDBStubArch { | ||
| 48 | public: | ||
| 49 | std::string GetTargetXML() const override; | ||
| 50 | std::string RegRead(const Kernel::KThread* thread, size_t id) const override; | ||
| 51 | void RegWrite(Kernel::KThread* thread, size_t id, std::string_view value) const override; | ||
| 52 | std::string ReadRegisters(const Kernel::KThread* thread) const override; | ||
| 53 | void WriteRegisters(Kernel::KThread* thread, std::string_view register_data) const override; | ||
| 54 | std::string ThreadStatus(const Kernel::KThread* thread, u8 signal) const override; | ||
| 55 | u32 BreakpointInstruction() const override; | ||
| 56 | |||
| 57 | private: | ||
| 58 | static constexpr u32 SP_REGISTER = 13; | ||
| 59 | static constexpr u32 LR_REGISTER = 14; | ||
| 60 | static constexpr u32 PC_REGISTER = 15; | ||
| 61 | static constexpr u32 CPSR_REGISTER = 25; | ||
| 62 | static constexpr u32 D0_REGISTER = 32; | ||
| 63 | static constexpr u32 Q0_REGISTER = 64; | ||
| 64 | static constexpr u32 FPSCR_REGISTER = 80; | ||
| 65 | }; | ||
| 66 | |||
| 67 | } // namespace Core | ||