diff options
| author | Alexey Samsonov <samsonov@google.com> | 2012-06-15 14:00:25 +0000 |
|---|---|---|
| committer | Alexey Samsonov <samsonov@google.com> | 2012-06-15 14:00:25 +0000 |
| commit | 0d76e8983f820d37496cc61eb2f2e8986274e3c9 (patch) | |
| tree | 7c3d5c6c002ee39007c4e4207e47b010e62a26e9 /compiler-rt/lib/asan/asan_stack.cc | |
| parent | f500be025afd6eb1d2ca98937d710b2d5105c9fa (diff) | |
| download | bcm5719-llvm-0d76e8983f820d37496cc61eb2f2e8986274e3c9.tar.gz bcm5719-llvm-0d76e8983f820d37496cc61eb2f2e8986274e3c9.zip | |
[Sanitizer] Use ProcessMaps in symbolizer to get module name and offset for instruction address
llvm-svn: 158522
Diffstat (limited to 'compiler-rt/lib/asan/asan_stack.cc')
| -rw-r--r-- | compiler-rt/lib/asan/asan_stack.cc | 27 |
1 files changed, 16 insertions, 11 deletions
diff --git a/compiler-rt/lib/asan/asan_stack.cc b/compiler-rt/lib/asan/asan_stack.cc index e7246bd00e6..1c60565e85a 100644 --- a/compiler-rt/lib/asan/asan_stack.cc +++ b/compiler-rt/lib/asan/asan_stack.cc @@ -42,22 +42,27 @@ void AsanStackTrace::PrintStack(uptr *addr, uptr size) { ProcessMaps proc_maps; uptr frame_num = 0; for (uptr i = 0; i < size && addr[i]; i++) { - proc_maps.Reset(); uptr pc = addr[i]; - uptr offset; - char filename[4096]; + AddressInfo addr_frames[64]; + uptr addr_frames_num = 0; if (FLAG_symbolize) { - AddressInfoList *address_info_list = SymbolizeCode(pc); - for (AddressInfoList *entry = address_info_list; entry; - entry = entry->next) { - AddressInfo info = entry->info; - AsanPrintf(" #%zu 0x%zx %s:%d:%d\n", frame_num, pc, - (info.file) ? info.file : "", - info.line, info.column); + addr_frames_num = SymbolizeCode(pc, addr_frames, + ASAN_ARRAY_SIZE(addr_frames)); + } + if (addr_frames_num > 0) { + for (uptr j = 0; j < addr_frames_num; j++) { + AddressInfo &info = addr_frames[j]; + AsanPrintf(" #%zu 0x%zx", frame_num, pc); + if (info.module) { + AsanPrintf(" (%s+0x%zx)", info.module, info.module_offset); + } + AsanPrintf("\n"); + info.Clear(); frame_num++; } - address_info_list->Clear(); } else { + uptr offset; + char filename[4096]; if (proc_maps.GetObjectNameAndOffset(pc, &offset, filename, sizeof(filename))) { AsanPrintf(" #%zu 0x%zx (%s+0x%zx)\n", frame_num, pc, filename, |

