svn commit: r240156 - head/lib/libproc
Rui Paulo
rpaulo at FreeBSD.org
Thu Sep 6 19:58:44 UTC 2012
On 6 Sep 2012, at 02:42, Gennady Proskurin <gprspb at mail.ru> wrote:
> On Thu, Sep 06, 2012 at 03:19:49AM +0000, Rui Paulo wrote:
>> Author: rpaulo
>> Date: Thu Sep 6 03:19:48 2012
>> New Revision: 240156
>> URL: http://svn.freebsd.org/changeset/base/240156
>>
>> Log:
>> Add support for demangling C++ symbols. This requires linking libproc with
>> libc++rt/libsupc++.
>>
>> Discussed with: theraven
>>
>> Modified:
>> head/lib/libproc/Makefile
>> head/lib/libproc/proc_sym.c
>>
>> Modified: head/lib/libproc/Makefile
>> ==============================================================================
>> --- head/lib/libproc/Makefile Thu Sep 6 02:07:58 2012 (r240155)
>> +++ head/lib/libproc/Makefile Thu Sep 6 03:19:48 2012 (r240156)
>> @@ -1,5 +1,7 @@
>> # $FreeBSD$
>>
>> +.include <bsd.own.mk>
>> +
>> LIB= proc
>>
>> SRCS= proc_bkpt.c \
>> @@ -13,6 +15,14 @@ INCS= libproc.h
>>
>> CFLAGS+= -I${.CURDIR}
>>
>> +.if ${MK_LIBCPLUSPLUS} != "no"
>> +LDADD+= -lcxxrt
>> +DPADD+= ${LIBCXXRT}
>> +.else
>> +LDADD+= -lsupc++
>> +DPADD+= ${LIBSTDCPLUSPLUS}
>> +.endif
>> +
>> SHLIB_MAJOR= 2
>>
>> WITHOUT_MAN=
>>
>> Modified: head/lib/libproc/proc_sym.c
>> ==============================================================================
>> --- head/lib/libproc/proc_sym.c Thu Sep 6 02:07:58 2012 (r240155)
>> +++ head/lib/libproc/proc_sym.c Thu Sep 6 03:19:48 2012 (r240156)
>> @@ -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, uin
>> 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')
> checking "strlen(s) > 2" is useless and not optimal here, you can omit it completely
> checking s[0] and s[1] is enough, it implies that length is >=2
> you may add something like "s[2] != 0" if length should be strictly >2
It's not really useless but can be considered non-optimal, yes. That said, the C++ demangler we're calling doesn't really care about being fast :-)
Regards,
--
Rui Paulo
More information about the svn-src-head
mailing list