This is the mail archive of the gdb@sources.redhat.com mailing list for the GDB project.


Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]
Other format: [Raw text]

Problem with multiple threads using gdbserver on x86.


hi, 
      
this is regarding debugging multi-threaded applications using gdbserver.
I am facing a weird situation with respect to the same. When i try and
run gdbserver on a multi-threaded application and try to debug the same,
gdb is unable to stop all the threads on hitting a breakpoint in one of
the threads. 
	
the steps i followed are the following. 
$>gdbserver localhost:1234 thr
$>gdb thr

(gdb) target remote localhost:1234
Remote debugging using localhost:1234
0x40000be0 in ?? ()

(gdb) set remotelogfile logfile
(gdb) b main
Breakpoint 1 at 0x80484b0: file thr.c, line 11.
(gdb) c
Continuing.
Ignoring packet error, continuing...
Ignoring packet error, continuing...
Ignoring packet error, continuing...

Breakpoint 1, main (argc=1, argv=0xbffff144) at thr.c:11
11           printf("Creating...\n");
(gdb) n
12           pthread_create( &id, NULL, work2, ((void*) 0) );
(gdb) n
13           printf("Created thread.\n"); fflush(stdout);
(gdb) n
15           printf("Waiting...\n");


At this point in time if i do an info threads the only thread it shows
me is the main thread though in gdb it shows me both the threads. 
At the same point of time when the main thread is stopped at this
position the thread which has just been created runs away. ! 
and on doing an info threads i do not get the information about the 
newly created thread. 

Is this a limitation of gdbserver with respect to kernel space threads.
 I saw the comment in thread-db.c in the function
thread_db_find_new_threads. which says "iterate" over user space threads
??
The foll. is the information regarding my machine / environment. 

RedHat linux 9.0 .  gdb v 5.3 gcc version 3.2.2 20030222
GNU gdb Red Hat Linux (5.3post-0.20021129.18rh)


I wonder if anyone else is getting a similar problem ..I am attaching
the 2 files that were used for this purpose. 

build the 2 files as
 gcc -g new.c thr.c -lpthread (obviously !)


regards
Ramana

P.S. the same works fine on a native version of gdb. 



 
#include <stdio.h>
void *work2(void *foo)
{
     while ((int)foo<5) {
	  printf("got %d\n", (int) foo++);
	  sleep(2);
     }
     return (void *)110;
}

#include <stdio.h>
#include <stdlib.h>
#include <pthread.h>

extern int work2(void *);
int main(int argc, char **argv)
{
     pthread_t id; 
     int  retval;

     printf("Creating...\n");
     pthread_create( &id, NULL, work2, ((void*) 0) );
     printf("Created thread.\n"); fflush(stdout);

     printf("Waiting...\n");
     pthread_join(id,(void **)&retval);
     printf("Joined with retval = %d\n",retval);

     return 0;
}




Index Nav: [Date Index] [Subject Index] [Author Index] [Thread Index]
Message Nav: [Date Prev] [Date Next] [Thread Prev] [Thread Next]