From bc03b2dbee8a7458a3ed89abd643bf004f0f403b Mon Sep 17 00:00:00 2001 From: Amlal El Mahrouss Date: Wed, 26 Mar 2025 09:29:01 +0100 Subject: feat(debugger): Better design for LibDebugger, and a patch for the POSIX CLI. Signed-off-by: Amlal El Mahrouss --- dev/LibDebugger/POSIXContract.h | 106 ++++++++++++++++++++++++++++++++++++++++ 1 file changed, 106 insertions(+) create mode 100644 dev/LibDebugger/POSIXContract.h (limited to 'dev/LibDebugger/POSIXContract.h') diff --git a/dev/LibDebugger/POSIXContract.h b/dev/LibDebugger/POSIXContract.h new file mode 100644 index 0000000..5a8ae48 --- /dev/null +++ b/dev/LibDebugger/POSIXContract.h @@ -0,0 +1,106 @@ +/*** + (C) 2025 Amlal El Mahrouss + */ + +#pragma once + +#ifdef _WIN32 +#error Windows doesn't have a POSIX subsystem, please combine with windows instead. +#endif + +#include + +#include +#include +#include +#include +#include +#include + +#ifdef __APPLE__ +#define PTRACE_ATTACH PT_ATTACHEXC +#define PTRACE_DETACH PT_DETACH +#define PTRACE_POKETEXT PT_WRITE_I +#define PTRACE_CONT PT_CONTINUE +#define PTRACE_PEEKTEXT PT_READ_I +#endif + +namespace LibDebugger::POSIX +{ + /// \brief POSIXDebuggerContract engine interface class in C++ + /// \author Amlal El Mahrouss + class POSIXDebuggerContract final : public DebuggerContract + { + public: + explicit POSIXDebuggerContract() = default; + ~POSIXDebuggerContract() override = default; + + public: + POSIXDebuggerContract& operator=(const POSIXDebuggerContract&) = default; + POSIXDebuggerContract(const POSIXDebuggerContract&) = default; + + public: + bool Attach(ProcessID pid) noexcept override + { + if (ptrace(PTRACE_ATTACH, pid, nullptr, 0) == -1) + { + return false; + } + + this->m_pid = pid; + + waitpid(m_pid, nullptr, 0); + + return true; + } + + bool Break(CAddress addr) noexcept override + { + uintptr_t original_data = ptrace(PTRACE_PEEKTEXT, m_pid, addr, 0); + + if (original_data == -1) + { + return false; + } + + constexpr uint8_t kInt3x86 = 0xCC; + + uintptr_t data_with_int3 = (original_data & ~0xFF) | kInt3x86; // Insert INT3 (0xCC) + + if (ptrace(PTRACE_POKETEXT, m_pid, addr, data_with_int3) == -1) + { + return false; + } + + m_breakpoints[reinterpret_cast(addr)] = original_data; // Store original data + + return true; + } + + bool Continue() noexcept override + { + if (ptrace(PTRACE_CONT, m_pid, nullptr, 0) == -1) + { + return false; + } + + int status; + waitpid(m_pid, &status, 0); + + return WIFSTOPPED(status) && WSTOPSIG(status) == SIGTRAP; + } + + bool Detach() noexcept override + { + if (ptrace(PTRACE_DETACH, m_pid, nullptr, 0) == -1) + { + return false; + } + + return true; + } + + private: + pid_t m_pid; + }; +} // namespace LibDebugger::POSIX -- cgit v1.2.3