From: Carmelo Amoroso <carmelo73@gmail.com>
To: Michael Snyder <Michael.Snyder@palmsource.com>
Cc: gdb@sourceware.org
Subject: Re: howto debug libthread_db
Date: Sat, 30 Sep 2006 16:46:00 -0000 [thread overview]
Message-ID: <451E9FC4.5040304@gmail.com> (raw)
In-Reply-To: <1159553569.9768.264.camel@localhost.localdomain>
Michael Snyder wrote:
> On Fri, 2006-09-29 at 11:08 +0200, Carmelo Amoroso wrote:
>> Well,
>> after a few days of debugging my gdbserver (with uClibc-nptl on sh4),
>> I found the bug into uClibc,
>> that was causing a stack frame corruption due to a buffer overrun.
>> This was the reason for which the td_ta_map_lwp2thr was never
>> returning to the caller
>> (the stack location where the PR had been saved was corupted).
>>
>> It was a very interesting debugging session. I successfully used a
>> native gdb (glibc base)on target
>> to debug a gdbserver (uClinc-nptl based) I connect to with a gdb
>> client from a linux host.
>>
>> At the end I did not need to use a double remote gdb session.
>>
>> Thanks to Michael for his very usefull tips.
>
>
> So, does that mean that there was no actual problem with gdb,
> with respect to stepping in libthread_db?
Yes, it was my thread_db that was failing killing the gdbserver
This works now?
Yes, it works perfectly, even with multithreadrd applications.
Carmelo
>
> Thanks,
> Michael
>
>
>> On 9/27/06, Carmelo Amoroso <carmelo73@gmail.com> wrote:
>>> Michael Snyder wrote:
>>>> On Wed, 2006-09-27 at 08:23 +0200, Carmelo Amoroso wrote:
>>>>> Michael Snyder wrote:
>>>>>> On Tue, 2006-09-26 at 16:06 +0200, Carmelo Amoroso wrote:
>>>>>>> Hi All,
>>>>>>> I'm trying to debug a simple multithread application on a remote target,
>>>>>>> and I like to debug the libthread_db itself... is it possible to do it?
>>>>>>> is it possible to set some breakpoints and stepping through?
>>>>>>> Is there anyone already played with it?
>>>>>>>
>>>>>>> I tried to use symbol-file to gdb client, and I successfully added a
>>>>>>> breakpoint, but I cannot reach it after I connected to the target and
>>>>>>> issued 'continue'.
>>>>>>>
>>>>>>> Any help will be appreciated
>>>>>> Interesting. I haven't done it (or not much anyway).
>>>>>>
>>>>>> The first thing you must bear in mind is that libthread_db is not
>>>>>> part of the target application -- it is part of gdb (or in the
>>>>>> remote debugging context, part of gdbserver). So to debug it,
>>>>>> you must debug gdb, or in your case gdbserver.
>>>>>>
>>>>> Yes. it's what I want to do
>>>>>> It might be easier if you try this out first using a native gdb,
>>>>>> debugging itself.
>>>>>>
>>>>>> When you debug gdb with gdb, it is easier if you change the prompt.
>>>>>> I usually do this in the 'parent' gdb, so I can tell it apart from
>>>>>> the 'child' gdb:
>>>>>>
>>>>>> (gdb) set prompt (GDB)
>>>>>> (GDB)
>>>>>>
>>>>>> Now, in the parent GDB, you should be able to set your
>>>>>> breakpoints in libthread_db, then start the child gdb,
>>>>>> load the multi-threaded program, and begin debugging it.
>>>>>>
>>>>> Does the native gdb use the thread_db as the gdbserver does?
>>>> Yes.
>>>>
>>>>> I was thinking to run gdb --args my-gdbserver <application>
>>>>> on the target, and connect to the my-gdbserver from the host
>>>>> just to trigger the thread_db initialization process.
>>>>> Comments?
>>>> Oh, so you can actually run gdb on the target?
>>> Yes, I'm using it after I read your reply. So I'm running
>>> a working gdb (glibc/sh4 based) to debug a half-working gdbserver
>>> (uClibc-nptl/sh4 based).
>>> I was able to set breakpoint on gdbserver itself
>>> (thread_db_find_new_threads function for example) and to step into
>>> my thread_db library. But up to now I could not reach the
>>> td_ta_map_lp2thr function due to some failures in packets transmission
>>> between gdb remote client and target gdbserver, so the tbread_db
>>> initializaition is failing before entering in that function.
>>> I'm still working on it.
>>>
>>> I'd like to describe the problem I have in case some one may have an idea:
>>> The stack is as follows:
>>>
>>> td_ta_map_lwp2thr
>>> iterate_list_thread
>>> td_ta_thr_iter
>>> thread_db_find_new_threads
>>> thread_db_init
>>>
>>> The td_ta_map_lwp2thr funtcion reach its end successfully
>>> (performing any symbol lookup; I also printed out the thread pointer
>>> and its value is just the same as printed by the pthread_self function
>>> from the libpthread), but when returns to the caller it produces a
>>> SIGSEV due to a misaligned access (as reported by dmesg command).
>>> Any printf after the function's invocation is never executed!
>>>
>>> The thread_db code is he same as the glibc, so I cannot understand
>>> where it's failing. The gdbserver version is 6.4 (built using a
>>> sh4-linux-gcc configured for uClibc) and it is the same code used to
>>> build the glibc based version.
>>>
>>>
>>>> Yes, that would make things simpler, and what you
>>>> suggest above is pretty much what I would recommend.
>>>>
>>>>
>>>>>> When you get ready to try this with gdbserver, you will
>>>>>> have to start one gdbserver and attach to it with another
>>>>>> gdbserver. Then you'll again have two gdbs running on the
>>>>>> host side, which you can again think of as parent and child,
>>>>>> only now the parent is debugging the child's gdbserver, not
>>>>>> the child gdb itself.
>>>>>>
>>>>> Well, just before reading your reply, I tried with this:
>>>>>
>>>>> target:
>>>>> gdbserver localhost:999 my-gdbserver localhost:998 <applcation>
>>>>>
>>>>> host:
>>>>> xxx-gdb my-gdbserver (connecting to port 999)
>>>>>
>>>>> xxx-gdb application (connecting to port 998)
>>>>>
>>>>> With the first gdb session I was able to set a breakpoint into
>>>>> thread_db, but not able to stepping through the code.
>>>>>
>>>>> Is this approach as well as the gdb native session.
>>>> Hmmm, that's pretty much what I would have tried.
>>>> What happened when you tried to step? How did it fail?
>>>>
>>> Difficult to describe; I'm trying to follow the native approach for now,
>>> but I'd like trying this again later; I'll report any failure or success
>>> with more details.
>>>
>>> Thanks a lot again
>>> Carmelo
>>>
>
next prev parent reply other threads:[~2006-09-30 16:46 UTC|newest]
Thread overview: 14+ messages / expand[flat|nested] mbox.gz Atom feed top
2006-09-26 14:05 Carmelo Amoroso
2006-09-26 14:07 ` Daniel Jacobowitz
2006-09-26 14:24 ` Carmelo Amoroso
2006-09-26 18:20 ` Michael Snyder
2006-09-26 22:26 ` Andreas Schwab
2006-09-27 6:21 ` Carmelo Amoroso
2006-09-27 18:11 ` Michael Snyder
2006-09-27 6:21 ` Carmelo Amoroso
2006-09-27 18:15 ` Michael Snyder
2006-09-27 21:02 ` Carmelo Amoroso
2006-09-29 9:08 ` Carmelo Amoroso
2006-09-29 18:12 ` Michael Snyder
2006-09-30 16:46 ` Carmelo Amoroso [this message]
2006-10-02 18:07 ` Michael Snyder
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=451E9FC4.5040304@gmail.com \
--to=carmelo73@gmail.com \
--cc=Michael.Snyder@palmsource.com \
--cc=gdb@sourceware.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox