[RFC] libdw: prepend current directory in read_srclines
Torsten Polle
Torsten.Polle@gmx.de
Thu May 4 08:26:00 GMT 2017
Hi Mark,
> Am 29.03.2017 um 22:15 schrieb Torsten Polle <Torsten.Polle@gmx.de>:
>
> Hi Mark,
>
>> Am 27.03.2017 um 22:45 schrieb Mark Wielaard <mark@klomp.org>:
>>
>> Hi Torsten,
>>
>> On Sun, Mar 26, 2017 at 08:35:50PM +0200, Torsten Polle wrote:
>>> I observed that readelf and elfutils sometimes report different results.
>>
>> Do you have an example of this? It would be good to have a testcase.
>>
>>> PFA a patch that corrects this. I’m not sure whether the way I tackled
>>> the problem is acceptable.
>>
>> I see why you are proposing this. The DWARF spec does say about the
>> include_directories "Each path entry is either a full path name or is
>> relative to the current directory of the compilation". So your patch
>> does make sense.
>>
>> But it does depend on what users of dwarf_getsrclines expect.
>> Or any use of Dwarf_Line/Dwarf_Files. I think those users expect that
>> the returned file names can be relative. And that they should make them
>> absolute using index zero or the comp_dir themselves.
>>
>> So if you do have an example where the expected output isn't what you
>> believe it should be we should examine if there is some other way to
>> do the right thing.
>>
>> Cheers,
>> Mark
>
> thanks for the answer. I’ll come back with an example, which is SystemTap based. :-)
>
> Please allow for some delay. I expect to provide an example in about two weeks.
>
> Regards,
> Torsten
Sorry for coming back so late. Please find attached my reproduction.
I compile the simple program relative.c:
int main()
{
return 0;
}
with the command "gcc -g ../2017-05-03-elfutils/relative.c -o relative“.
When I run systemtap with the command
/opt/tooling/adit/systemtap/bin/stap -g -a i386 -B CROSS_COMPILE=i586-poky-linux- -r /home/polle/work/build/poky/build/tmp/work/qemux86-poky-linux/linux-yocto/4.8.12+gitAUTOINC+926c93ae07_021b4aef55-r0/build --sysroot=/home/polle/work/build/poky/build/tmp/work/qemux86-poky-linux/core-image-sato/1.0-r0/rootfs -L 'process("/bin/relative").function("main").call‘
I get the following output:
process("/bin/relative").function("main@../2017-05-03-elfutils/relative.c:1").call
But running nm returns the following.
nm -l | grep relative
080483eb T main /home/polle/work/issues/2017-05-03-elfutils/../2017-05-03-elfutils/relative.c:1
I hope this helps.
Kind Regards,
Torsten
More information about the Elfutils-devel
mailing list