[llvm-commits] [compiler-rt] r163376 - /compiler-rt/trunk/utils/llvm-symbolizer/llvm-symbolizer.cpp
Alexey Samsonov
samsonov at google.com
Fri Sep 7 00:26:35 PDT 2012
Author: samsonov
Date: Fri Sep 7 02:26:35 2012
New Revision: 163376
URL: http://llvm.org/viewvc/llvm-project?rev=163376&view=rev
Log:
[Sanitizer] add --demangle option to llvm-symbolizer (for now just assume that __cxa_demangle option is available)
Modified:
compiler-rt/trunk/utils/llvm-symbolizer/llvm-symbolizer.cpp
Modified: compiler-rt/trunk/utils/llvm-symbolizer/llvm-symbolizer.cpp
URL: http://llvm.org/viewvc/llvm-project/compiler-rt/trunk/utils/llvm-symbolizer/llvm-symbolizer.cpp?rev=163376&r1=163375&r2=163376&view=diff
==============================================================================
--- compiler-rt/trunk/utils/llvm-symbolizer/llvm-symbolizer.cpp (original)
+++ compiler-rt/trunk/utils/llvm-symbolizer/llvm-symbolizer.cpp Fri Sep 7 02:26:35 2012
@@ -50,6 +50,10 @@
PrintInlining("inlining", cl::init(true),
cl::desc("Print all inlined frames for a given address"));
+static cl::opt<bool>
+Demangle("demangle", cl::init(true),
+ cl::desc("Demangle function names"));
+
static StringRef ToolInvocationPath;
static bool error(error_code ec) {
@@ -237,6 +241,10 @@
return Info;
}
+// Assume that __cxa_demangle is provided by libcxxabi.
+extern "C" char *__cxa_demangle(const char *mangled_name, char *output_buffer,
+ size_t *length, int *status);
+
static void printDILineInfo(DILineInfo LineInfo) {
// By default, DILineInfo contains "<invalid>" for function/filename it
// cannot fetch. We replace it to "??" to make our output closer to addr2line.
@@ -246,6 +254,15 @@
string FunctionName = LineInfo.getFunctionName();
if (FunctionName == kDILineInfoBadString)
FunctionName = kSymbolizerBadString;
+ if (Demangle) {
+ int status = 0;
+ char *DemangledName = __cxa_demangle(
+ FunctionName.c_str(), 0, 0, &status);
+ if (status == 0) {
+ FunctionName = DemangledName;
+ free(DemangledName);
+ }
+ }
outs() << FunctionName << "\n";
}
string Filename = LineInfo.getFileName();
More information about the llvm-commits
mailing list