summaryrefslogtreecommitdiffstats
path: root/lib/libproc
diff options
context:
space:
mode:
authorsjg <sjg@FreeBSD.org>2014-08-19 06:50:54 +0000
committersjg <sjg@FreeBSD.org>2014-08-19 06:50:54 +0000
commitd7cd1d425cc1ea9451fa235e3af9b6625c3e0de2 (patch)
treeb04f4bd7cd887f50e7d98af35f46b9834ff86c80 /lib/libproc
parent3c8e37b1d04827f33c0c9a7594bd1b1ef7cdb3d3 (diff)
parent4fbde208c6460d576f64d6dc3cdc6cab085a4283 (diff)
downloadFreeBSD-src-d7cd1d425cc1ea9451fa235e3af9b6625c3e0de2.zip
FreeBSD-src-d7cd1d425cc1ea9451fa235e3af9b6625c3e0de2.tar.gz
Merge head from 7/28
Diffstat (limited to 'lib/libproc')
-rw-r--r--lib/libproc/Makefile4
-rw-r--r--lib/libproc/proc_sym.c35
2 files changed, 21 insertions, 18 deletions
diff --git a/lib/libproc/Makefile b/lib/libproc/Makefile
index 9302496..5e5babf 100644
--- a/lib/libproc/Makefile
+++ b/lib/libproc/Makefile
@@ -17,7 +17,9 @@ CFLAGS+= -I${.CURDIR}
# avoid cyclic dependency
CFLAGS+= -I${.CURDIR:H}/librtld_db
-.if ${MK_LIBCPLUSPLUS} != "no"
+.if ${MK_CXX} == "no"
+CFLAGS+= -DNO_CXA_DEMANGLE
+.elif ${MK_LIBCPLUSPLUS} != "no"
LDADD+= -lcxxrt
DPADD+= ${LIBCXXRT}
.else
diff --git a/lib/libproc/proc_sym.c b/lib/libproc/proc_sym.c
index 3777a46..4d60043 100644
--- a/lib/libproc/proc_sym.c
+++ b/lib/libproc/proc_sym.c
@@ -46,27 +46,34 @@
#include "_libproc.h"
+#ifndef NO_CXA_DEMANGLE
extern char *__cxa_demangle(const char *, char *, size_t *, int *);
+#endif /* NO_CXA_DEMANGLE */
static void proc_rdl2prmap(rd_loadobj_t *, prmap_t *);
static void
demangle(const char *symbol, char *buf, size_t len)
{
+#ifndef NO_CXA_DEMANGLE
char *dembuf;
- size_t demlen = len;
+ size_t demlen;
- dembuf = malloc(len);
- if (!dembuf)
- goto fail;
- dembuf = __cxa_demangle(symbol, dembuf, &demlen, NULL);
- if (!dembuf)
- goto fail;
- strlcpy(buf, dembuf, len);
- free(dembuf);
+ if (symbol[0] == '_' && symbol[1] == 'Z' && symbol[2]) {
+ dembuf = malloc(len);
+ if (!dembuf)
+ goto fail;
+ demlen = len;
+ dembuf = __cxa_demangle(symbol, dembuf, &demlen, NULL);
+ if (!dembuf)
+ goto fail;
+ strlcpy(buf, dembuf, len);
+ free(dembuf);
+ }
return;
fail:
+#endif /* NO_CXA_DEMANGLE */
strlcpy(buf, symbol, len);
}
@@ -297,10 +304,7 @@ 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) {
- if (s[0] == '_' && s[1] == 'Z' && s[2])
- demangle(s, name, namesz);
- else
- strlcpy(name, s, namesz);
+ demangle(s, name, namesz);
memcpy(symcopy, &sym, sizeof(sym));
/*
* DTrace expects the st_value to contain
@@ -335,10 +339,7 @@ symtab:
if (addr >= rsym && addr < rsym + sym.st_size) {
s = elf_strptr(e, symtabstridx, sym.st_name);
if (s) {
- if (s[0] == '_' && s[1] == 'Z' && s[2])
- demangle(s, name, namesz);
- else
- strlcpy(name, s, namesz);
+ demangle(s, name, namesz);
memcpy(symcopy, &sym, sizeof(sym));
/*
* DTrace expects the st_value to contain
OpenPOWER on IntegriCloud