Date: Mon, 04 Mar 2013 12:50:02 +0100 From: Dimitry Andric <dim@FreeBSD.org> To: Andriy Gapon <avg@FreeBSD.org> Cc: freebsd-hackers@FreeBSD.org Subject: Re: clang generated code sometimes confuses fbt Message-ID: <51348A6A.3070606@FreeBSD.org> In-Reply-To: <5133AC3B.5040504@FreeBSD.org> References: <5132387E.8010808@FreeBSD.org> <51323C62.4040506@FreeBSD.org> <51325FB3.7080300@FreeBSD.org> <51337018.30000@FreeBSD.org> <51337C27.7000105@FreeBSD.org> <5133AC3B.5040504@FreeBSD.org>
next in thread | previous in thread | raw e-mail | index | archive | help
This is a multi-part message in MIME format. --------------060403060209040404050200 Content-Type: text/plain; charset=ISO-8859-1; format=flowed Content-Transfer-Encoding: 7bit On 2013-03-03 21:02, Dimitry Andric wrote: > On 2013-03-03 17:36, Andriy Gapon wrote: >> on 03/03/2013 17:45 Dimitry Andric said the following: ... > So to fix this inconsistency, we could either change dw_read() to use > the full name instead of the basename, or change sort_iidescs() to use > the basename instead of the full name. > > The only upstream I have been able to find, Illumos, had the same code > as FreeBSD for both of these functions, so it is likely they never > noticed it before... > > My preference would be to remove the basename() call from dw_read(), as > in the attached diff. That seems to fix the problem here; the diff of > ctfdump output before and after becomes: Actually, that way of fixing breaks it for gcc, so it should really be fixed in sort_iidescs() instead. See attached diff; I verified it works for both gcc-compiled and clang-compiled objects. --------------060403060209040404050200 Content-Type: text/x-diff; name="ctfconvert-output-1.diff" Content-Transfer-Encoding: 7bit Content-Disposition: attachment; filename="ctfconvert-output-1.diff" Index: cddl/contrib/opensolaris/tools/ctf/cvt/output.c =================================================================== --- cddl/contrib/opensolaris/tools/ctf/cvt/output.c (revision 247448) +++ cddl/contrib/opensolaris/tools/ctf/cvt/output.c (working copy) @@ -363,6 +363,7 @@ sort_iidescs(Elf *elf, const char *file, tdata_t * for (i = 0; i < nent; i++) { GElf_Sym sym; + char *bname; iidesc_t **tolist; GElf_Sym ssym; iidesc_match_t smatch; @@ -377,6 +378,8 @@ sort_iidescs(Elf *elf, const char *file, tdata_t * switch (GELF_ST_TYPE(sym.st_info)) { case STT_FILE: + bname = strrchr(match.iim_name, '/'); + bname = bname == NULL ? match.iim_name : bname + 1; match.iim_file = match.iim_name; continue; case STT_OBJECT: --------------060403060209040404050200--
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?51348A6A.3070606>