starpu_thread.h 8.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231
  1. /* StarPU --- Runtime system for heterogeneous multicore architectures.
  2. *
  3. * Copyright (C) 2010, 2012-2014 Université de Bordeaux 1
  4. * Copyright (C) 2010, 2011, 2012, 2013 Centre National de la Recherche Scientifique
  5. *
  6. * StarPU is free software; you can redistribute it and/or modify
  7. * it under the terms of the GNU Lesser General Public License as published by
  8. * the Free Software Foundation; either version 2.1 of the License, or (at
  9. * your option) any later version.
  10. *
  11. * StarPU is distributed in the hope that it will be useful, but
  12. * WITHOUT ANY WARRANTY; without even the implied warranty of
  13. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
  14. *
  15. * See the GNU Lesser General Public License in COPYING.LGPL for more details.
  16. */
  17. #ifndef __STARPU_THREAD_H__
  18. #define __STARPU_THREAD_H__
  19. #ifdef __cplusplus
  20. extern "C"
  21. {
  22. #endif
  23. #include <starpu_config.h>
  24. #ifdef STARPU_SIMGRID
  25. #include <xbt/synchro_core.h>
  26. #include <msg/msg.h>
  27. #elif !defined(_MSC_VER)
  28. #include <pthread.h>
  29. #endif
  30. /*
  31. * Encapsulation of the pthread_create function.
  32. */
  33. #ifdef STARPU_SIMGRID
  34. typedef int starpu_pthread_t;
  35. typedef int starpu_pthread_attr_t;
  36. int starpu_pthread_create_on(char *name, starpu_pthread_t *thread, const starpu_pthread_attr_t *attr, void *(*start_routine) (void *), void *arg, int where);
  37. int starpu_pthread_create(starpu_pthread_t *thread, const starpu_pthread_attr_t *attr, void *(*start_routine) (void *), void *arg);
  38. int starpu_pthread_join(starpu_pthread_t thread, void **retval);
  39. int starpu_pthread_attr_init(starpu_pthread_attr_t *attr);
  40. int starpu_pthread_attr_destroy(starpu_pthread_attr_t *attr);
  41. int starpu_pthread_attr_setdetachstate(starpu_pthread_attr_t *attr, int detachstate);
  42. #elif !defined(_MSC_VER) /* STARPU_SIMGRID */
  43. typedef pthread_t starpu_pthread_t;
  44. typedef pthread_attr_t starpu_pthread_attr_t;
  45. #define starpu_pthread_create pthread_create
  46. #define starpu_pthread_create_on(name, thread, attr, routine, arg, where) starpu_pthread_create(thread, attr, routine, arg)
  47. #define starpu_pthread_join pthread_join
  48. #define starpu_pthread_attr_init pthread_attr_init
  49. #define starpu_pthread_attr_destroy pthread_attr_destroy
  50. #define starpu_pthread_attr_setdetachstate pthread_attr_setdetachstate
  51. #endif /* STARPU_SIMGRID, _MSC_VER */
  52. /*
  53. * Encapsulation of the pthread_mutex_* functions.
  54. */
  55. #ifdef STARPU_SIMGRID
  56. typedef xbt_mutex_t starpu_pthread_mutex_t;
  57. typedef int starpu_pthread_mutexattr_t;
  58. #define STARPU_PTHREAD_MUTEX_INITIALIZER NULL
  59. int starpu_pthread_mutex_init(starpu_pthread_mutex_t *mutex, const starpu_pthread_mutexattr_t *mutexattr);
  60. int starpu_pthread_mutex_destroy(starpu_pthread_mutex_t *mutex);
  61. int starpu_pthread_mutex_lock(starpu_pthread_mutex_t *mutex);
  62. int starpu_pthread_mutex_unlock(starpu_pthread_mutex_t *mutex);
  63. int starpu_pthread_mutex_trylock(starpu_pthread_mutex_t *mutex);
  64. #elif !defined(_MSC_VER) /* !STARPU_SIMGRID */
  65. typedef pthread_mutex_t starpu_pthread_mutex_t;
  66. typedef pthread_mutexattr_t starpu_pthread_mutexattr_t;
  67. #define starpu_pthread_mutex_init pthread_mutex_init
  68. #define starpu_pthread_mutex_destroy pthread_mutex_destroy
  69. int starpu_pthread_mutex_lock(starpu_pthread_mutex_t *mutex);
  70. int starpu_pthread_mutex_unlock(starpu_pthread_mutex_t *mutex);
  71. int starpu_pthread_mutex_trylock(starpu_pthread_mutex_t *mutex);
  72. #define STARPU_PTHREAD_MUTEX_INITIALIZER PTHREAD_MUTEX_INITIALIZER
  73. #endif /* STARPU_SIMGRID, _MSC_VER */
  74. /*
  75. * Encapsulation of the pthread_key_* functions.
  76. */
  77. #ifdef STARPU_SIMGRID
  78. typedef int starpu_pthread_key_t;
  79. int starpu_pthread_key_create(starpu_pthread_key_t *key, void (*destr_function) (void *));
  80. int starpu_pthread_key_delete(starpu_pthread_key_t key);
  81. int starpu_pthread_setspecific(starpu_pthread_key_t key, const void *pointer);
  82. void *starpu_pthread_getspecific(starpu_pthread_key_t key);
  83. #elif !defined(_MSC_VER) /* STARPU_SIMGRID */
  84. typedef pthread_key_t starpu_pthread_key_t;
  85. #define starpu_pthread_key_create pthread_key_create
  86. #define starpu_pthread_key_delete pthread_key_delete
  87. #define starpu_pthread_setspecific pthread_setspecific
  88. #define starpu_pthread_getspecific pthread_getspecific
  89. #endif /* STARPU_SIMGRID, _MSC_VER */
  90. /*
  91. * Encapsulation of the pthread_cond_* functions.
  92. */
  93. #ifdef STARPU_SIMGRID
  94. typedef xbt_cond_t starpu_pthread_cond_t;
  95. typedef int starpu_pthread_condattr_t;
  96. #define STARPU_PTHREAD_COND_INITIALIZER NULL
  97. int starpu_pthread_cond_init(starpu_pthread_cond_t *cond, starpu_pthread_condattr_t *cond_attr);
  98. int starpu_pthread_cond_signal(starpu_pthread_cond_t *cond);
  99. int starpu_pthread_cond_broadcast(starpu_pthread_cond_t *cond);
  100. int starpu_pthread_cond_wait(starpu_pthread_cond_t *cond, starpu_pthread_mutex_t *mutex);
  101. int starpu_pthread_cond_timedwait(starpu_pthread_cond_t *cond, starpu_pthread_mutex_t *mutex, const struct timespec *abstime);
  102. int starpu_pthread_cond_destroy(starpu_pthread_cond_t *cond);
  103. #elif !defined(_MSC_VER) /* STARPU_SIMGRID */
  104. typedef pthread_cond_t starpu_pthread_cond_t;
  105. typedef pthread_condattr_t starpu_pthread_condattr_t;
  106. #define STARPU_PTHREAD_COND_INITIALIZER PTHREAD_COND_INITIALIZER
  107. #define starpu_pthread_cond_init pthread_cond_init
  108. #define starpu_pthread_cond_signal pthread_cond_signal
  109. #define starpu_pthread_cond_broadcast pthread_cond_broadcast
  110. int starpu_pthread_cond_wait(starpu_pthread_cond_t *cond, starpu_pthread_mutex_t *mutex);
  111. #define starpu_pthread_cond_timedwait pthread_cond_timedwait
  112. #define starpu_pthread_cond_destroy pthread_cond_destroy
  113. #endif /* STARPU_SIMGRID, _MSC_VER */
  114. /*
  115. * Encapsulation of the pthread_rwlock_* functions.
  116. */
  117. #ifdef STARPU_SIMGRID
  118. typedef xbt_mutex_t starpu_pthread_rwlock_t;
  119. typedef int starpu_pthread_rwlockattr_t;
  120. int starpu_pthread_rwlock_init(starpu_pthread_rwlock_t *rwlock, const starpu_pthread_rwlockattr_t *attr);
  121. int starpu_pthread_rwlock_destroy(starpu_pthread_rwlock_t *rwlock);
  122. int starpu_pthread_rwlock_rdlock(starpu_pthread_rwlock_t *rwlock);
  123. int starpu_pthread_rwlock_tryrdlock(starpu_pthread_rwlock_t *rwlock);
  124. int starpu_pthread_rwlock_wrlock(starpu_pthread_rwlock_t *rwlock);
  125. int starpu_pthread_rwlock_trywrlock(starpu_pthread_rwlock_t *rwlock);
  126. int starpu_pthread_rwlock_unlock(starpu_pthread_rwlock_t *rwlock);
  127. #elif !defined(_MSC_VER) /* STARPU_SIMGRID */
  128. typedef pthread_rwlock_t starpu_pthread_rwlock_t;
  129. typedef pthread_rwlockattr_t starpu_pthread_rwlockattr_t;
  130. #define starpu_pthread_rwlock_init pthread_rwlock_init
  131. #define starpu_pthread_rwlock_destroy pthread_rwlock_destroy
  132. int starpu_pthread_rwlock_rdlock(starpu_pthread_rwlock_t *rwlock);
  133. int starpu_pthread_rwlock_tryrdlock(starpu_pthread_rwlock_t *rwlock);
  134. int starpu_pthread_rwlock_wrlock(starpu_pthread_rwlock_t *rwlock);
  135. int starpu_pthread_rwlock_trywrlock(starpu_pthread_rwlock_t *rwlock);
  136. int starpu_pthread_rwlock_unlock(starpu_pthread_rwlock_t *rwlock);
  137. #endif /* STARPU_SIMGRID, _MSC_VER */
  138. /*
  139. * Encapsulation of the pthread_barrier_* functions.
  140. */
  141. #ifdef STARPU_SIMGRID
  142. typedef struct {
  143. starpu_pthread_mutex_t mutex;
  144. starpu_pthread_cond_t cond;
  145. unsigned count;
  146. unsigned done;
  147. } starpu_pthread_barrier_t;
  148. typedef int starpu_pthread_barrierattr_t;
  149. #define STARPU_PTHREAD_BARRIER_SERIAL_THREAD -1
  150. int starpu_pthread_barrier_init(starpu_pthread_barrier_t *barrier, const starpu_pthread_barrierattr_t *attr, unsigned count);
  151. int starpu_pthread_barrier_destroy(starpu_pthread_barrier_t *barrier);
  152. int starpu_pthread_barrier_wait(starpu_pthread_barrier_t *barrier);
  153. #elif !defined(_MSC_VER) /* STARPU_SIMGRID */
  154. typedef pthread_barrier_t starpu_pthread_barrier_t;
  155. typedef pthread_barrierattr_t starpu_pthread_barrierattr_t;
  156. #define starpu_pthread_barrier_init pthread_barrier_init
  157. #define starpu_pthread_barrier_destroy pthread_barrier_destroy
  158. int starpu_pthread_barrier_wait(starpu_pthread_barrier_t *barrier);
  159. #define STARPU_PTHREAD_BARRIER_SERIAL_THREAD PTHREAD_BARRIER_SERIAL_THREAD
  160. #endif /* STARPU_SIMGRID, _MSC_VER */
  161. #ifdef _MSC_VER
  162. typedef void* starpu_pthread_rwlock_t;
  163. typedef void* starpu_pthread_mutex_t;
  164. typedef void* starpu_pthread_cond_t;
  165. typedef void* starpu_pthread_barrier_t;
  166. #endif /* _MSC_VER */
  167. #ifdef __cplusplus
  168. }
  169. #endif
  170. #endif /* __STARPU_THREAD_H__ */