public inbox for gdb@sourceware.org
 help / color / mirror / Atom feed
* Re: Relocation question
@ 2005-08-11 13:51 Ton van Overbeek
  2005-08-15  4:00 ` Missing "angeldll.h" in gdb/rdi-shareestion Dave Murphy
  0 siblings, 1 reply; 6+ messages in thread
From: Ton van Overbeek @ 2005-08-11 13:51 UTC (permalink / raw)
  To: Stefan Burström, Andreas Schwab; +Cc: gdb

Andreas Schwab wrote:

>Stefan Burström <f94sbu@efd.lth.se> writes:
>
>> Can someone explain to me how gdb is supposed to handle relocated
>> executables? I am porting gdb to AmigaOS4 which relocates its
>> executables
>> when they are loaded. However, when I run an application through gdb,
>> gdb uses the bfd functions to build its map over the file. However, the
>> bfd library always relocates everything relative to 0 (since it
>> obviously doesn't know anything else to relocate it to)
>
> That reminds me of an old port of gdb 3.6 for the AtariST (which has the
> same problem).  It used CREATE_INFERIOR_HOOK (now called
> TARGET_CREATE_INFERIOR_HOOK) to query the load address of the just
> started
> process and then patched the gdb symtabs and breakpoint addresses by the
> load offset.  But I don't think that would still work nowadays.

Have a look at how we solved this in prc-tools for PalmOS:
http://prc-tools.sourceforge.net. Go to the cvs and look at the patch for
gdb. It is for gdb 5.3, but the mechanism still works for 6.x.
PalmOS can also have multiple code sections whose start addresses are not
known untill runtime. A patch supporting that is on
http://www.v-overbeek.nl/msectgdb.

Basically when execution starts (either on a real PalmOS device or on an
emulator) the start addresses of the .text and .data and other code
sections are reported to gdb, which then relocates the symbol tables.
(PalmOS is also m68k).

Hope this helps.

Ton van Overbeek
(for Andreas: my first Linux experience was with Linux-68k on Atari-TT)
(for Stefan: gjorde mitt examensarbete på LTH, Reglerteknik)

^ permalink raw reply	[flat|nested] 6+ messages in thread
* Relocation question 
@ 2005-08-10 19:00 Stefan Burström
  2005-08-10 19:54 ` Simon Richter
  2005-08-10 21:33 ` Andreas Schwab
  0 siblings, 2 replies; 6+ messages in thread
From: Stefan Burström @ 2005-08-10 19:00 UTC (permalink / raw)
  To: gdb

Hello!
Can someone explain to me how gdb is supposed to handle relocated
executables? I am porting gdb to AmigaOS4 which relocates its executables
when they are loaded. However, when I run an application through gdb, gdb
uses the bfd functions to build its map over the file. However, the bfd
library always relocates everything relative to 0 (since it obviously
doesn't know anything else to relocate it to)

So, in order for gdb to build the symbol tables etc. it needs to use the
relocated addresses instead of the ones retreived directly from the file.
What is the prefered way of doing this? I tried to set up the section
offsets (real address - address from the bfd code) in the section offsets
field, but I am not quite sure exactly when I can set up this table. I tried
to set it up in the default_symfile_offsets function and that results in the
small symbol table to be correct. However, the addr and endaddr ptrs in the
objfile/osections are already set up at this point and will then contain
addresses near 0 instead. Which means that every search for an address vill
fail since it wont fall between addr and endaddr of the sections loaded from
the bfd file.

Is this possible to solive in a nice way?

regards,
Stefan Burström

^ permalink raw reply	[flat|nested] 6+ messages in thread

end of thread, other threads:[~2005-08-15  4:08 UTC | newest]

Thread overview: 6+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2005-08-11 13:51 Relocation question Ton van Overbeek
2005-08-15  4:00 ` Missing "angeldll.h" in gdb/rdi-shareestion Dave Murphy
2005-08-15  4:08   ` Daniel Jacobowitz
  -- strict thread matches above, loose matches on Subject: below --
2005-08-10 19:00 Relocation question Stefan Burström
2005-08-10 19:54 ` Simon Richter
2005-08-10 21:33 ` Andreas Schwab

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).