diff options
author | mmentovai <mmentovai@4c0a9323-5329-0410-9bdc-e9ce6186880e> | 2006-09-25 18:29:48 +0000 |
---|---|---|
committer | mmentovai <mmentovai@4c0a9323-5329-0410-9bdc-e9ce6186880e> | 2006-09-25 18:29:48 +0000 |
commit | 960e5277ee489960c40c50c6222606200419302a (patch) | |
tree | 33a3b8a0ecba5cd6c961966d93f6270acc7a40d9 /src/processor/stackwalker_x86.cc | |
parent | Add ppc support to minidump reader (#27). r=bryner. (diff) | |
download | breakpad-960e5277ee489960c40c50c6222606200419302a.tar.xz |
ppc stackwalker (#30). r=bryner
- Implementation of PowerPC stackwalker. Tested using stackwalker_selftest
(#18).
- Hook up processor-side multi-CPU support in MinidumpProcessor and
minidump_stackwalk using the new Stackwalker::StackwalkerForCPU method.
http://groups.google.com/group/airbag-dev/browse_thread/thread/1c2fa7c5182a77a9
git-svn-id: http://google-breakpad.googlecode.com/svn/trunk@34 4c0a9323-5329-0410-9bdc-e9ce6186880e
Diffstat (limited to 'src/processor/stackwalker_x86.cc')
-rw-r--r-- | src/processor/stackwalker_x86.cc | 35 |
1 files changed, 16 insertions, 19 deletions
diff --git a/src/processor/stackwalker_x86.cc b/src/processor/stackwalker_x86.cc index e51bf3e8..a5819c86 100644 --- a/src/processor/stackwalker_x86.cc +++ b/src/processor/stackwalker_x86.cc @@ -37,44 +37,39 @@ #include "processor/stackwalker_x86.h" #include "processor/minidump.h" - namespace google_airbag { -StackwalkerX86::StackwalkerX86(MinidumpContext* context, - MemoryRegion* memory, - MinidumpModuleList* modules, - SymbolSupplier* supplier) +StackwalkerX86::StackwalkerX86(const MDRawContextX86 *context, + MemoryRegion *memory, + MinidumpModuleList *modules, + SymbolSupplier *supplier) : Stackwalker(memory, modules, supplier), - last_frame_pointer_(0) { + context_(context) { if (memory_->GetBase() + memory_->GetSize() - 1 > 0xffffffff) { // The x86 is a 32-bit CPU, the limits of the supplied stack are invalid. // Mark memory_ = NULL, which will cause stackwalking to fail. memory_ = NULL; } - - // If |context| is not an x86 context, context_ will be set to NULL, - // which will cause GetContextFrame to fail when called by Walk. - // For StackwalkerX86, |context| should only ever be an x86 context. - context_ = context->GetContextX86(); } -bool StackwalkerX86::GetContextFrame(StackFrame* frame) { +bool StackwalkerX86::GetContextFrame(StackFrame *frame) { if (!context_ || !memory_ || !frame) return false; // The frame and instruction pointers are stored directly in registers, // so pull them straight out of the CPU context structure. - frame->frame_pointer = last_frame_pointer_ = context_->ebp; + frame->frame_pointer = context_->ebp; frame->instruction = context_->eip; return true; } -bool StackwalkerX86::GetCallerFrame(StackFrame* frame) { - if (!memory_ || !frame) +bool StackwalkerX86::GetCallerFrame(StackFrame *frame, + const StackFrames *walked_frames) { + if (!memory_ || !frame || !walked_frames) return false; // The frame and instruction pointers for previous frames are saved on the @@ -93,24 +88,26 @@ bool StackwalkerX86::GetCallerFrame(StackFrame* frame) { // considerably more difficult, requiring debugging information. This // stackwalker doesn't attempt to solve that problem (at this point). + u_int32_t last_frame_pointer = walked_frames->back().frame_pointer; + // Don't pass frame.frame_pointer or frame.instruction directly // ReadMemory, because their types are too wide (64-bit), and we // specifically want to read 32-bit quantities for both. u_int32_t frame_pointer; - if (!memory_->GetMemoryAtAddress(last_frame_pointer_, &frame_pointer)) + if (!memory_->GetMemoryAtAddress(last_frame_pointer, &frame_pointer)) return false; // A caller frame must reside higher in memory than its callee frames. // Anything else is an error, or an indication that we've reached the // end of the stack. - if (frame_pointer <= last_frame_pointer_) + if (frame_pointer <= last_frame_pointer) return false; u_int32_t instruction; - if (!memory_->GetMemoryAtAddress(last_frame_pointer_ + 4, &instruction)) + if (!memory_->GetMemoryAtAddress(last_frame_pointer + 4, &instruction)) return false; - frame->frame_pointer = last_frame_pointer_ = frame_pointer; + frame->frame_pointer = frame_pointer; frame->instruction = instruction; return true; |