Mirror of the gdb mailing list
 help / color / mirror / Atom feed
From: jbbachky@aim.com
To: gdb@sources.redhat.com
Subject: gdbserver/gdb-6/4 and lots of pthreads
Date: Wed, 15 Nov 2006 16:12:00 -0000	[thread overview]
Message-ID: <8C8D6E7E15FE5F6-5D0-723B@mblk-d22.sysops.aol.com> (raw)

Hi,
I've got an application with about 40 pthreads running under linux 
2.6.10 w/glibc-2.2.3, compiled with gcc-3.4.3 running on powerpc (and 
eventually a few other architectures). I've been a happy gdb-5.0 user 
for a number of years, with my linux kernel(s) performing the 
breakpoint removal/replacement on context switches.
I've been hoping to remove that code and let gdb handle when and if to 
break based on process id.

In attempting to upgrade to gdb-6.4, I'm afraid that I've run into a 
problem which might require some hacking.

Gdbserver attaches to my main thread and opens a socket, and then after 
invoking gdb and specifying my remote target, I select the particular 
thread that I wish to debug. Info threads shows all of my threads, and 
I see that gdbserver now attaches to all of them.

Any attempt to single-step or continue with a breakpoint results in a 
"thrashing system". A counter in my context switching code shows almost 
150k switchs/second, up from about 1200/sec when not attached with gdb. 
One of the 40 pthreads handle a 10ms SIGALRM. Almost all of the others 
are waiting for messages.

Is there a fundamental problem with the number of threads and 
attaching/detaching/waking them all?
Do I need to continue to "hide" my other threads from gdb/gdbserver?. I 
am building with dynamic linking, and gdbserver finds and uses 
libthread_db.so.

Thanks for any help or advice.
________________________________________________________________________
Check Out the new free AIM(R) Mail -- 2 GB of storage and 
industry-leading spam and email virus protection.


             reply	other threads:[~2006-11-15 16:12 UTC|newest]

Thread overview: 12+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2006-11-15 16:12 jbbachky [this message]
2006-11-15 16:50 ` Daniel Jacobowitz
2006-11-15 17:08   ` jbbachky
2006-11-16 15:15     ` Daniel Jacobowitz
2006-11-16 21:53   ` jbbachky
2006-11-16 22:04     ` Daniel Jacobowitz
2006-11-17 18:47       ` jbbachky
2006-11-17 19:08         ` Daniel Jacobowitz
2006-11-17 20:01           ` jbbachky
2006-11-17 20:14             ` Daniel Jacobowitz
2006-11-29 15:23               ` jbbachky
2006-11-29 15:26                 ` Daniel Jacobowitz

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=8C8D6E7E15FE5F6-5D0-723B@mblk-d22.sysops.aol.com \
    --to=jbbachky@aim.com \
    --cc=gdb@sources.redhat.com \
    /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