diff options
| author | bunnei <bunneidev@gmail.com> | 2018-12-29 22:58:13 -0500 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2018-12-29 22:58:13 -0500 |
| commit | 331c252509aa6c7712d983b388ba3533d3047df1 (patch) | |
| tree | bdffbe558bab81adac706ed7ead2e6b91ed5a394 /src/core/arm/arm_interface.cpp | |
| parent | f80229b67671f87d3adcd3bcfc7b1fa14ee1eda3 (diff) | |
| parent | 22d4e106642ac9d6a0dabc700c4dcd47be08ff41 (diff) | |
Merge pull request #1847 from ogniK5377/backtrace-break
Print backtrace on svcBreak
Diffstat (limited to 'src/core/arm/arm_interface.cpp')
| -rw-r--r-- | src/core/arm/arm_interface.cpp | 26 |
1 files changed, 26 insertions, 0 deletions
diff --git a/src/core/arm/arm_interface.cpp b/src/core/arm/arm_interface.cpp new file mode 100644 index 000000000..bcc812da4 --- /dev/null +++ b/src/core/arm/arm_interface.cpp @@ -0,0 +1,26 @@ +// Copyright 2018 yuzu emulator team +// Licensed under GPLv2 or any later version +// Refer to the license.txt file included. + +#include "arm_interface.h" +#include "common/common_types.h" +#include "common/logging/log.h" +#include "core/memory.h" + +namespace Core { +void ARM_Interface::LogBacktrace() { + VAddr fp = GetReg(29); + VAddr lr = GetReg(30); + VAddr sp = GetReg(13); + VAddr pc = GetPC(); + LOG_ERROR(Core_ARM, "Backtrace, sp={:016X}, pc={:016X}", sp, pc); + for (;;) { + LOG_ERROR(Core_ARM, "{:016X}", lr); + if (!fp) { + break; + } + lr = Memory::Read64(fp + 8) - 4; + fp = Memory::Read64(fp); + } +} +}; // namespace Core |
