pthread_exit.c 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  1. /*
  2. * pthread_exit.c
  3. *
  4. * Description:
  5. * This translation unit implements routines associated with exiting from
  6. * a thread.
  7. *
  8. * --------------------------------------------------------------------------
  9. *
  10. * Pthreads-win32 - POSIX Threads Library for Win32
  11. * Copyright(C) 1998 John E. Bossom
  12. * Copyright(C) 1999,2005 Pthreads-win32 contributors
  13. *
  14. * Contact Email: [email protected]
  15. *
  16. * The current list of contributors is contained
  17. * in the file CONTRIBUTORS included with the source
  18. * code distribution. The list can also be seen at the
  19. * following World Wide Web location:
  20. * http://sources.redhat.com/pthreads-win32/contributors.html
  21. *
  22. * This library is free software; you can redistribute it and/or
  23. * modify it under the terms of the GNU Lesser General Public
  24. * License as published by the Free Software Foundation; either
  25. * version 2 of the License, or (at your option) any later version.
  26. *
  27. * This library is distributed in the hope that it will be useful,
  28. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  29. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  30. * Lesser General Public License for more details.
  31. *
  32. * You should have received a copy of the GNU Lesser General Public
  33. * License along with this library in the file COPYING.LIB;
  34. * if not, write to the Free Software Foundation, Inc.,
  35. * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
  36. */
  37. #include "pthread.h"
  38. #include "implement.h"
  39. #if !defined(_UWIN)
  40. /*# include <process.h> */
  41. #endif
  42. void
  43. pthread_exit (void *value_ptr)
  44. /*
  45. * ------------------------------------------------------
  46. * DOCPUBLIC
  47. * This function terminates the calling thread, returning
  48. * the value 'value_ptr' to any joining thread.
  49. *
  50. * PARAMETERS
  51. * value_ptr
  52. * a generic data value (i.e. not the address of a value)
  53. *
  54. *
  55. * DESCRIPTION
  56. * This function terminates the calling thread, returning
  57. * the value 'value_ptr' to any joining thread.
  58. * NOTE: thread should be joinable.
  59. *
  60. * RESULTS
  61. * N/A
  62. *
  63. * ------------------------------------------------------
  64. */
  65. {
  66. ptw32_thread_t * sp;
  67. /*
  68. * Don't use pthread_self() to avoid creating an implicit POSIX thread handle
  69. * unnecessarily.
  70. */
  71. sp = (ptw32_thread_t *) pthread_getspecific (ptw32_selfThreadKey);
  72. #if defined(_UWIN)
  73. if (--pthread_count <= 0)
  74. exit ((int) value_ptr);
  75. #endif
  76. if (NULL == sp)
  77. {
  78. /*
  79. * A POSIX thread handle was never created. I.e. this is a
  80. * Win32 thread that has never called a pthreads-win32 routine that
  81. * required a POSIX handle.
  82. *
  83. * Implicit POSIX handles are cleaned up in ptw32_throw() now.
  84. */
  85. #if ! (defined (__MINGW64__) || defined(__MINGW32__)) || defined (__MSVCRT__) || defined (__DMC__)
  86. _endthreadex ((unsigned) (size_t) value_ptr);
  87. #else
  88. _endthread ();
  89. #endif
  90. /* Never reached */
  91. }
  92. sp->exitStatus = value_ptr;
  93. ptw32_throw (PTW32_EPS_EXIT);
  94. /* Never reached. */
  95. }