Pretty printing.
[kopensolaris-gnu/glibc.git] / nptl_db / td_thr_get_info.c
index 0686649..985c8d7 100644 (file)
@@ -1,5 +1,5 @@
 /* Get thread information.
-   Copyright (C) 1999, 2000, 2001, 2002 Free Software Foundation, Inc.
+   Copyright (C) 1999, 2000, 2001, 2002, 2003 Free Software Foundation, Inc.
    This file is part of the GNU C Library.
    Contributed by Ulrich Drepper <drepper@redhat.com>, 1999.
 
@@ -38,22 +38,22 @@ td_thr_get_info (const td_thrhandle_t *th, td_thrinfo_t *infop)
      results for the fields we do not fill in.  */
   memset (infop, '\0', sizeof (td_thrinfo_t));
 
-  infop->ti_tid = pds.tid;
+  infop->ti_tid = th->th_unique;
   infop->ti_tls = (char *) pds.specific;
   infop->ti_pri = (pds.schedpolicy == SCHED_OTHER
                   ? 0 : pds.schedparam.sched_priority);
   infop->ti_type = TD_THR_USER;
 
-  if ((pds.cancelhandling & EXITING_BIT) == 0)
+  if ((pds.cancelhandling & EXITING_BITMASK) == 0)
     /* XXX For now there is no way to get more information.  */
     infop->ti_state = TD_THR_ACTIVE;
-  else if ((pds.cancelhandling & TERMINATED_BIT) == 0)
+  else if ((pds.cancelhandling & TERMINATED_BITMASK) == 0)
     infop->ti_state = TD_THR_ZOMBIE;
   else
     infop->ti_state = TD_THR_UNKNOWN;
 
   /* Initialization which are the same in both cases.  */
-  infop->ti_lid = ps_getpid (th->th_ta_p->ph);
+  infop->ti_lid = pds.tid ?: ps_getpid (th->th_ta_p->ph);
   infop->ti_ta_p = th->th_ta_p;
   infop->ti_startfunc = pds.start_routine;
   memcpy (&infop->ti_events, &pds.eventbuf.eventmask,