td_ta_tsd_iter.c 1.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. /* Iterate over a process's thread-specific data.
  2. Copyright (C) 1999 Free Software Foundation, Inc.
  3. This file is part of the GNU C Library.
  4. Contributed by Ulrich Drepper <drepper@cygnus.com>, 1999.
  5. The GNU C Library is free software; you can redistribute it and/or
  6. modify it under the terms of the GNU Library General Public License as
  7. published by the Free Software Foundation; either version 2 of the
  8. License, or (at your option) any later version.
  9. The GNU C Library is distributed in the hope that it will be useful,
  10. but WITHOUT ANY WARRANTY; without even the implied warranty of
  11. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  12. Library General Public License for more details.
  13. You should have received a copy of the GNU Library General Public
  14. License along with the GNU C Library; see the file COPYING.LIB. If not,
  15. write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
  16. Boston, MA 02111-1307, USA. */
  17. #include <stdlib.h>
  18. #include "thread_dbP.h"
  19. td_err_e
  20. td_ta_tsd_iter (const td_thragent_t *ta, td_key_iter_f *callback,
  21. void *cbdata_p)
  22. {
  23. struct pthread_key_struct *keys;
  24. int pthread_keys_max;
  25. int cnt;
  26. LOG (__FUNCTION__);
  27. /* Test whether the TA parameter is ok. */
  28. if (! ta_ok (ta))
  29. return TD_BADTA;
  30. pthread_keys_max = ta->pthread_keys_max;
  31. keys = (struct pthread_key_struct *) alloca (sizeof (keys[0])
  32. * pthread_keys_max);
  33. /* Read all the information about the keys. */
  34. if (ps_pdread (ta->ph, ta->keys, keys,
  35. sizeof (keys[0]) * pthread_keys_max) != PS_OK)
  36. return TD_ERR; /* XXX Other error value? */
  37. /* Now get all descriptors, one after the other. */
  38. for (cnt = 0; cnt < pthread_keys_max; ++cnt)
  39. if (keys[cnt].in_use
  40. /* Return with an error if the callback returns a nonzero value. */
  41. && callback (cnt, keys[cnt].destr, cbdata_p) != 0)
  42. return TD_DBERR;
  43. return TD_OK;
  44. }