debug problem with prelinked libraries
Andrew Stubbs
ams@codesourcery.com
Wed May 5 12:48:00 GMT 2010
Hi all,
I'm trying to get to the bottom of a problem debugging prelinked
libraries. I've fixed a few aspects of the problem, but the further I
get into it the more I think I must be missing something. I mean,
debugging prelinked libraries is supposed to Just Work, right? But I
can't see how it could ever have worked.
First, I should say that I'm trying to debug a core dump that includes
prelinked libraries. Is that different somehow? The target is mips, if
that makes any difference. Also, debugging works fine for the
non-prelinked libraries and core file, so the problem's not there.
I originally encountered the problem with (a somewhat patched)
6.6.50_20070925, but I'm seeing exactly the same trouble in the latest
from CVS.
The problem is that GDB does not find the symbols and debug info for the
code in the prelinked libraries.
Upon closer inspection, I find that the psymtab has the textlow and
texthigh addresses as the original file-offsets, before relocation. This
appears to be because it calculates the section offset as the difference
between the actual address and the ELF VMA, but the file is prelinked,
so the offset is zero, and the debug info and symbols are then not
relocated.
So, I inserted a little code to fixup the offset in the psymtab for the
prelinked cases, but it now loads the symtab with exactly the same
offset troubles. So, I try to fix those, and the problem just moves one
step further on. Surely I can't need to implement prelink support from
scratch, so I must be missing something?
Is there one place that this should be fixed? I think I need to adjust
the base address used by the debug info, but I don't know how to do it
without also changing the base address used for relocating the binaries.
Any other suggestions? Any help would be much appreciated.
Andrew
More information about the Gdb
mailing list