sem_post.c 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128
  1. /*
  2. * -------------------------------------------------------------
  3. *
  4. * Module: sem_post.c
  5. *
  6. * Purpose:
  7. * Semaphores aren't actually part of the PThreads standard.
  8. * They are defined by the POSIX Standard:
  9. *
  10. * POSIX 1003.1b-1993 (POSIX.1b)
  11. *
  12. * -------------------------------------------------------------
  13. *
  14. * --------------------------------------------------------------------------
  15. *
  16. * Pthreads-win32 - POSIX Threads Library for Win32
  17. * Copyright(C) 1998 John E. Bossom
  18. * Copyright(C) 1999,2005 Pthreads-win32 contributors
  19. *
  20. * Contact Email: [email protected]
  21. *
  22. * The current list of contributors is contained
  23. * in the file CONTRIBUTORS included with the source
  24. * code distribution. The list can also be seen at the
  25. * following World Wide Web location:
  26. * http://sources.redhat.com/pthreads-win32/contributors.html
  27. *
  28. * This library is free software; you can redistribute it and/or
  29. * modify it under the terms of the GNU Lesser General Public
  30. * License as published by the Free Software Foundation; either
  31. * version 2 of the License, or (at your option) any later version.
  32. *
  33. * This library is distributed in the hope that it will be useful,
  34. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  35. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  36. * Lesser General Public License for more details.
  37. *
  38. * You should have received a copy of the GNU Lesser General Public
  39. * License along with this library in the file COPYING.LIB;
  40. * if not, write to the Free Software Foundation, Inc.,
  41. * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
  42. */
  43. #include "pthread.h"
  44. #include "semaphore.h"
  45. #include "implement.h"
  46. int
  47. sem_post (sem_t * sem)
  48. /*
  49. * ------------------------------------------------------
  50. * DOCPUBLIC
  51. * This function posts a wakeup to a semaphore.
  52. *
  53. * PARAMETERS
  54. * sem
  55. * pointer to an instance of sem_t
  56. *
  57. * DESCRIPTION
  58. * This function posts a wakeup to a semaphore. If there
  59. * are waiting threads (or processes), one is awakened;
  60. * otherwise, the semaphore value is incremented by one.
  61. *
  62. * RESULTS
  63. * 0 successfully posted semaphore,
  64. * -1 failed, error in errno
  65. * ERRNO
  66. * EINVAL 'sem' is not a valid semaphore,
  67. * ENOSYS semaphores are not supported,
  68. * ERANGE semaphore count is too big
  69. *
  70. * ------------------------------------------------------
  71. */
  72. {
  73. int result = 0;
  74. sem_t s = *sem;
  75. if (s == NULL)
  76. {
  77. result = EINVAL;
  78. }
  79. else if ((result = pthread_mutex_lock (&s->lock)) == 0)
  80. {
  81. /* See sem_destroy.c
  82. */
  83. if (*sem == NULL)
  84. {
  85. (void) pthread_mutex_unlock (&s->lock);
  86. result = EINVAL;
  87. return -1;
  88. }
  89. if (s->value < SEM_VALUE_MAX)
  90. {
  91. #if defined(NEED_SEM)
  92. if (++s->value <= 0
  93. && !SetEvent(s->sem))
  94. {
  95. s->value--;
  96. result = EINVAL;
  97. }
  98. #else
  99. if (++s->value <= 0
  100. && !ReleaseSemaphore (s->sem, 1, NULL))
  101. {
  102. s->value--;
  103. result = EINVAL;
  104. }
  105. #endif /* NEED_SEM */
  106. }
  107. else
  108. {
  109. result = ERANGE;
  110. }
  111. (void) pthread_mutex_unlock (&s->lock);
  112. }
  113. if (result != 0)
  114. {
  115. errno = result;
  116. return -1;
  117. }
  118. return 0;
  119. } /* sem_post */