This is the mail archive of the
gdb@sources.redhat.com
mailing list for the GDB project.
Re: pthreads debug with gdbserver
On Sat, Nov 20, 2004 at 02:27:13PM +0200, Vladimir Vorobyov wrote:
> Thank for your inputs. I moved further - see below.
>
> > > info shared reports: "No shared libraries loaded at this time".
> > > Straces shows that gdb opens only ld.so file.
> > > When adding printf to solibopen it also shows only ld.so.
> > > Who is responsible for loading shared libs ? What file/function/event?
> >
> > This usually means that the ld.so GDB has opened is not -exactly- the
> > same as the one on your target; and then it has set the solib event
> > breakpoint at the wrong location, and it hasn't been hit. Take a look
> > at solib-svr4.c if you want more details.
>
> As I said in my first message the breakpoint is hit exactly 3 times. I found
> that current_sos in solib-svr4.c can not find any libraries. It was because
> first_link_map_member returned NULL. After this I found that
> SVR4_FETCH_LINK_MAP_OFFSETS did not return correct offsets (which are correct
> for me? ilp32?). I tried to follow those gdbach_data calls but it was too
> difficult. I just assigned svr4_ilp32_fetch_link_map_offsets to
> SVR4_FETCH_LINK_MAP_OFFSETS (how to do it correctly?).
> After this with every shlib breakpoint hit gdb loads appropriate shared lib
> BUT gdbserver reports "Target does not support breakpoints" 3 times for each
> library loaded. What does it mean ?
> I still receive SIG32, info threads still shows only one thread. "info shared"
> shows all libraries that are loaded and td_ta_new() call now returns
> successfully.
Take a look at the source code to gdbserver. Andreas, now I remember
why I enabled thread_db support on a per-target basis - there are other
support routines that have to be written.
--
Daniel Jacobowitz