diff options
author | Kostya Serebryany <kcc@google.com> | 2012-08-28 13:49:49 +0000 |
---|---|---|
committer | Kostya Serebryany <kcc@google.com> | 2012-08-28 13:49:49 +0000 |
commit | cc347222d55967fdb775429a8a0a3a5d795b8b50 (patch) | |
tree | 0377b71864da176f2a50c940bd88b0ec72940112 /lib/asan/asan_stack.h | |
parent | 2b939c3abc8b7713ef28000bd768ca6d77445f45 (diff) | |
download | compiler-rt-cc347222d55967fdb775429a8a0a3a5d795b8b50.tar.gz compiler-rt-cc347222d55967fdb775429a8a0a3a5d795b8b50.tar.bz2 compiler-rt-cc347222d55967fdb775429a8a0a3a5d795b8b50.tar.xz |
[asan] even more refactoring to move StackTrace to sanitizer_common
git-svn-id: https://llvm.org/svn/llvm-project/compiler-rt/trunk@162754 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/asan/asan_stack.h')
-rw-r--r-- | lib/asan/asan_stack.h | 14 |
1 files changed, 8 insertions, 6 deletions
diff --git a/lib/asan/asan_stack.h b/lib/asan/asan_stack.h index 0d483b9a..2c725031 100644 --- a/lib/asan/asan_stack.h +++ b/lib/asan/asan_stack.h @@ -21,13 +21,14 @@ namespace __asan { static const uptr kStackTraceMax = 64; struct StackTrace { + typedef bool (*SymbolizeCallback)(const void *pc, char *out_buffer, + int out_size); uptr size; uptr max_size; uptr trace[kStackTraceMax]; - static void PrintStack(uptr *addr, uptr size); - void PrintStack() { - PrintStack(this->trace, this->size); - } + static void PrintStack(uptr *addr, uptr size, + bool symbolize, const char *strip_file_prefix, + SymbolizeCallback symbolize_callback); void CopyTo(uptr *dst, uptr dst_size) { for (uptr i = 0; i < size && i < dst_size; i++) dst[i] = trace[i]; @@ -53,7 +54,8 @@ struct StackTrace { u32 *compressed, uptr size); }; -void GetStackTrace(StackTrace *trace, uptr max_s, uptr pc, uptr bp); +void GetStackTrace(StackTrace *stack, uptr max_s, uptr pc, uptr bp); +void PrintStack(StackTrace *stack); @@ -100,7 +102,7 @@ void GetStackTrace(StackTrace *trace, uptr max_s, uptr pc, uptr bp); #define PRINT_CURRENT_STACK() \ { \ GET_STACK_TRACE_HERE(kStackTraceMax); \ - stack.PrintStack(); \ + PrintStack(&stack); \ } #endif // ASAN_STACK_H |