aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorted.mielczarek <ted.mielczarek@4c0a9323-5329-0410-9bdc-e9ce6186880e>2010-02-09 12:16:45 +0000
committerted.mielczarek <ted.mielczarek@4c0a9323-5329-0410-9bdc-e9ce6186880e>2010-02-09 12:16:45 +0000
commitbad560bb69fce7fb03c5490c85efca23a2a79627 (patch)
tree15aa691e0880f25b3c6d72b70e1d90d541d95341 /src
parentRefactor Chrome's out-of-process Linux code into CrashGeneration{Server,Clien... (diff)
downloadbreakpad-bad560bb69fce7fb03c5490c85efca23a2a79627.tar.xz
Print ARM register values in minidump_stackwalk. r=nealsid at http://breakpad.appspot.com/57002
git-svn-id: http://google-breakpad.googlecode.com/svn/trunk@516 4c0a9323-5329-0410-9bdc-e9ce6186880e
Diffstat (limited to 'src')
-rw-r--r--src/processor/minidump_stackwalk.cc11
1 files changed, 11 insertions, 0 deletions
diff --git a/src/processor/minidump_stackwalk.cc b/src/processor/minidump_stackwalk.cc
index 6b7931bd..368d64fa 100644
--- a/src/processor/minidump_stackwalk.cc
+++ b/src/processor/minidump_stackwalk.cc
@@ -70,6 +70,7 @@ using google_breakpad::StackFramePPC;
using google_breakpad::StackFrameSPARC;
using google_breakpad::StackFrameX86;
using google_breakpad::StackFrameAMD64;
+using google_breakpad::StackFrameARM;
// Separator character for machine readable output.
static const char kOutputSeparator = '|';
@@ -211,6 +212,16 @@ static void PrintStack(const CallStack *stack, const string &cpu) {
sequence = PrintRegister("fp", frame_sparc->context.g_r[30], sequence);
if (frame_sparc->context_validity & StackFrameSPARC::CONTEXT_VALID_PC)
sequence = PrintRegister("pc", frame_sparc->context.pc, sequence);
+ } else if (cpu == "arm") {
+ const StackFrameARM *frame_arm =
+ reinterpret_cast<const StackFrameARM*>(frame);
+
+ if (frame_arm->context_validity & StackFrameARM::CONTEXT_VALID_R13)
+ sequence = PrintRegister("r13", frame_arm->context.iregs[13], sequence);
+ if (frame_arm->context_validity & StackFrameARM::CONTEXT_VALID_R14)
+ sequence = PrintRegister("r14", frame_arm->context.iregs[14], sequence);
+ if (frame_arm->context_validity & StackFrameARM::CONTEXT_VALID_R15)
+ sequence = PrintRegister("r15", frame_arm->context.iregs[15], sequence);
}
printf("\n");
}