diff options
author | rpaulo <rpaulo@FreeBSD.org> | 2012-09-06 03:19:48 +0000 |
---|---|---|
committer | rpaulo <rpaulo@FreeBSD.org> | 2012-09-06 03:19:48 +0000 |
commit | 0160930e18300f23b566937e2710f55d991c653b (patch) | |
tree | 0198b27538b2d85f949a88fa5c50cc604c4db5da /lib/libproc/proc_sym.c | |
parent | f9b0e29ecf5ba5c982a7708f4a88509d839b19e8 (diff) | |
download | FreeBSD-src-0160930e18300f23b566937e2710f55d991c653b.zip FreeBSD-src-0160930e18300f23b566937e2710f55d991c653b.tar.gz |
Add support for demangling C++ symbols. This requires linking libproc with
libc++rt/libsupc++.
Discussed with: theraven
Diffstat (limited to 'lib/libproc/proc_sym.c')
-rw-r--r-- | lib/libproc/proc_sym.c | 14 |
1 files changed, 12 insertions, 2 deletions
diff --git a/lib/libproc/proc_sym.c b/lib/libproc/proc_sym.c index a72ba04..0940df8 100644 --- a/lib/libproc/proc_sym.c +++ b/lib/libproc/proc_sym.c @@ -46,6 +46,8 @@ #include "_libproc.h" +extern char *__cxa_demangle(const char *, char *, size_t *, int *); + static void proc_rdl2prmap(rd_loadobj_t *, prmap_t *); static void @@ -266,7 +268,11 @@ proc_addr2sym(struct proc_handle *p, uintptr_t addr, char *name, if (addr >= rsym && addr <= (rsym + sym.st_size)) { s = elf_strptr(e, dynsymstridx, sym.st_name); if (s) { - strlcpy(name, s, namesz); + if (strlen(s) > 2 && + s[0] == '_' && s[1] == 'Z') + __cxa_demangle(s, name, &namesz, NULL); + else + strlcpy(name, s, namesz); memcpy(symcopy, &sym, sizeof(sym)); /* * DTrace expects the st_value to contain @@ -302,7 +308,11 @@ symtab: if (addr >= rsym && addr <= (rsym + sym.st_size)) { s = elf_strptr(e, symtabstridx, sym.st_name); if (s) { - strlcpy(name, s, namesz); + if (strlen(s) > 2 && + s[0] == '_' && s[1] == 'Z') + __cxa_demangle(s, name, &namesz, NULL); + else + strlcpy(name, s, namesz); memcpy(symcopy, &sym, sizeof(sym)); /* * DTrace expects the st_value to contain |