diff options
| author | Zach Hilman <zachhilman@gmail.com> | 2019-05-17 21:43:26 -0400 |
|---|---|---|
| committer | Zach Hilman <zachhilman@gmail.com> | 2019-05-25 16:06:53 -0400 |
| commit | 5574be21ccd8cf86eaba5c50d30ad898bafc8ea8 (patch) | |
| tree | 08dab8c037370c284f46b56335d9b7d8e68ce839 /src/core/arm/arm_interface.h | |
| parent | 2179ad7483bde3c210bf4f638ae8801b3ba11214 (diff) | |
arm_interface: Expand backtrace generation
Returns results as a vector of entries for further processing. Logs addresses, offsets, and mangled name.
Diffstat (limited to 'src/core/arm/arm_interface.h')
| -rw-r--r-- | src/core/arm/arm_interface.h | 11 |
1 files changed, 11 insertions, 0 deletions
diff --git a/src/core/arm/arm_interface.h b/src/core/arm/arm_interface.h index 978b1518f..c6691a8e1 100644 --- a/src/core/arm/arm_interface.h +++ b/src/core/arm/arm_interface.h @@ -5,6 +5,7 @@ #pragma once #include <array> +#include <vector> #include "common/common_types.h" namespace Common { @@ -152,6 +153,16 @@ public: /// Prepare core for thread reschedule (if needed to correctly handle state) virtual void PrepareReschedule() = 0; + struct BacktraceEntry { + std::string module; + u64 address; + u64 original_address; + u64 offset; + std::string name; + }; + + std::vector<BacktraceEntry> GetBacktrace() const; + /// fp (= r29) points to the last frame record. /// Note that this is the frame record for the *previous* frame, not the current one. /// Note we need to subtract 4 from our last read to get the proper address |
