errno.c 2.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  1. /*
  2. * errno.c
  3. *
  4. * Description:
  5. * This translation unit implements routines associated with spawning a new
  6. * 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. #if defined(NEED_ERRNO)
  38. #include "pthread.h"
  39. #include "implement.h"
  40. static int reallyBad = ENOMEM;
  41. /*
  42. * Re-entrant errno.
  43. *
  44. * Each thread has it's own errno variable in pthread_t.
  45. *
  46. * The benefit of using the pthread_t structure
  47. * instead of another TSD key is TSD keys are limited
  48. * on Win32 to 64 per process. Secondly, to implement
  49. * it properly without using pthread_t you'd need
  50. * to dynamically allocate an int on starting the thread
  51. * and store it manually into TLS and then ensure that you free
  52. * it on thread termination. We get all that for free
  53. * by simply storing the errno on the pthread_t structure.
  54. *
  55. * MSVC and Mingw32 already have their own thread-safe errno.
  56. *
  57. * #if defined( _REENTRANT ) || defined( _MT )
  58. * #define errno *_errno()
  59. *
  60. * int *_errno( void );
  61. * #else
  62. * extern int errno;
  63. * #endif
  64. *
  65. */
  66. int *
  67. _errno (void)
  68. {
  69. pthread_t self;
  70. int *result;
  71. if ((self = pthread_self ()).p == NULL)
  72. {
  73. /*
  74. * Yikes! unable to allocate a thread!
  75. * Throw an exception? return an error?
  76. */
  77. result = &reallyBad;
  78. }
  79. else
  80. {
  81. result = (int *)(&self.p->exitStatus);
  82. }
  83. return (result);
  84. } /* _errno */
  85. #endif /* (NEED_ERRNO) */