pthread_kill.c 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  1. /*
  2. * pthread_kill.c
  3. *
  4. * Description:
  5. * This translation unit implements the pthread_kill routine.
  6. *
  7. * --------------------------------------------------------------------------
  8. *
  9. * Pthreads-win32 - POSIX Threads Library for Win32
  10. * Copyright(C) 1998 John E. Bossom
  11. * Copyright(C) 1999,2005 Pthreads-win32 contributors
  12. *
  13. * Contact Email: [email protected]
  14. *
  15. * The current list of contributors is contained
  16. * in the file CONTRIBUTORS included with the source
  17. * code distribution. The list can also be seen at the
  18. * following World Wide Web location:
  19. * http://sources.redhat.com/pthreads-win32/contributors.html
  20. *
  21. * This library is free software; you can redistribute it and/or
  22. * modify it under the terms of the GNU Lesser General Public
  23. * License as published by the Free Software Foundation; either
  24. * version 2 of the License, or (at your option) any later version.
  25. *
  26. * This library is distributed in the hope that it will be useful,
  27. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  28. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  29. * Lesser General Public License for more details.
  30. *
  31. * You should have received a copy of the GNU Lesser General Public
  32. * License along with this library in the file COPYING.LIB;
  33. * if not, write to the Free Software Foundation, Inc.,
  34. * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
  35. */
  36. #include "pthread.h"
  37. #include "implement.h"
  38. /*
  39. * Not needed yet, but defining it should indicate clashes with build target
  40. * environment that should be fixed.
  41. */
  42. #if !defined(WINCE)
  43. # include <signal.h>
  44. #endif
  45. int
  46. pthread_kill (pthread_t thread, int sig)
  47. /*
  48. * ------------------------------------------------------
  49. * DOCPUBLIC
  50. * This function requests that a signal be delivered to the
  51. * specified thread. If sig is zero, error checking is
  52. * performed but no signal is actually sent such that this
  53. * function can be used to check for a valid thread ID.
  54. *
  55. * PARAMETERS
  56. * thread reference to an instances of pthread_t
  57. * sig signal. Currently only a value of 0 is supported.
  58. *
  59. *
  60. * DESCRIPTION
  61. * This function requests that a signal be delivered to the
  62. * specified thread. If sig is zero, error checking is
  63. * performed but no signal is actually sent such that this
  64. * function can be used to check for a valid thread ID.
  65. *
  66. * RESULTS
  67. * ESRCH the thread is not a valid thread ID,
  68. * EINVAL the value of the signal is invalid
  69. * or unsupported.
  70. * 0 the signal was successfully sent.
  71. *
  72. * ------------------------------------------------------
  73. */
  74. {
  75. int result = 0;
  76. ptw32_thread_t * tp;
  77. ptw32_mcs_local_node_t node;
  78. ptw32_mcs_lock_acquire(&ptw32_thread_reuse_lock, &node);
  79. tp = (ptw32_thread_t *) thread.p;
  80. if (NULL == tp
  81. || thread.x != tp->ptHandle.x
  82. || NULL == tp->threadH)
  83. {
  84. result = ESRCH;
  85. }
  86. ptw32_mcs_lock_release(&node);
  87. if (0 == result && 0 != sig)
  88. {
  89. /*
  90. * Currently does not support any signals.
  91. */
  92. result = EINVAL;
  93. }
  94. return result;
  95. } /* pthread_kill */