starpu_thread.h 6.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197
  1. /* StarPU --- Runtime system for heterogeneous multicore architectures.
  2. *
  3. * Copyright (C) 2010, 2012-2013 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. #ifdef STARPU_SIMGRID
  24. #include <xbt/synchro_core.h>
  25. #include <msg/msg.h>
  26. #elif !defined(_MSC_VER)
  27. #include <pthread.h>
  28. #endif
  29. /*
  30. * Encapsulation of the pthread_create function.
  31. */
  32. #ifdef STARPU_SIMGRID
  33. typedef int starpu_pthread_t;
  34. typedef int starpu_pthread_attr_t;
  35. 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);
  36. int starpu_pthread_create(starpu_pthread_t *thread, const starpu_pthread_attr_t *attr, void *(*start_routine) (void *), void *arg);
  37. int starpu_pthread_join(starpu_pthread_t thread, void **retval);
  38. int starpu_pthread_attr_init(starpu_pthread_attr_t *attr);
  39. int starpu_pthread_attr_destroy(starpu_pthread_attr_t *attr);
  40. int starpu_pthread_attr_setdetachstate(starpu_pthread_attr_t *attr, int detachstate);
  41. #elif !defined(_MSC_VER) /* STARPU_SIMGRID */
  42. typedef pthread_t starpu_pthread_t;
  43. typedef pthread_attr_t starpu_pthread_attr_t;
  44. #define starpu_pthread_create pthread_create
  45. #define starpu_pthread_create_on(name, thread, attr, routine, arg, where) starpu_pthread_create(thread, attr, routine, arg)
  46. #define starpu_pthread_join pthread_join
  47. #define starpu_pthread_attr_init pthread_attr_init
  48. #define starpu_pthread_attr_destroy pthread_attr_destroy
  49. #define starpu_pthread_attr_setdetachstate pthread_attr_setdetachstate
  50. #endif /* STARPU_SIMGRID, _MSC_VER */
  51. /*
  52. * Encapsulation of the pthread_mutex_* functions.
  53. */
  54. #ifdef STARPU_SIMGRID
  55. typedef xbt_mutex_t starpu_pthread_mutex_t;
  56. typedef int starpu_pthread_mutexattr_t;
  57. #define STARPU_PTHREAD_MUTEX_INITIALIZER NULL
  58. int starpu_pthread_mutex_init(starpu_pthread_mutex_t *mutex, const starpu_pthread_mutexattr_t *mutexattr);
  59. int starpu_pthread_mutex_destroy(starpu_pthread_mutex_t *mutex);
  60. int starpu_pthread_mutex_lock(starpu_pthread_mutex_t *mutex);
  61. int starpu_pthread_mutex_unlock(starpu_pthread_mutex_t *mutex);
  62. int starpu_pthread_mutex_trylock(starpu_pthread_mutex_t *mutex);
  63. #elif !defined(_MSC_VER) /* !STARPU_SIMGRID */
  64. typedef pthread_mutex_t starpu_pthread_mutex_t;
  65. typedef pthread_mutexattr_t starpu_pthread_mutexattr_t;
  66. #define starpu_pthread_mutex_init pthread_mutex_init
  67. #define starpu_pthread_mutex_destroy pthread_mutex_destroy
  68. int starpu_pthread_mutex_lock(starpu_pthread_mutex_t *mutex);
  69. int starpu_pthread_mutex_unlock(starpu_pthread_mutex_t *mutex);
  70. int starpu_pthread_mutex_trylock(starpu_pthread_mutex_t *mutex);
  71. #define STARPU_PTHREAD_MUTEX_INITIALIZER PTHREAD_MUTEX_INITIALIZER
  72. #endif /* STARPU_SIMGRID, _MSC_VER */
  73. /*
  74. * Encapsulation of the pthread_key_* functions.
  75. */
  76. #ifdef STARPU_SIMGRID
  77. typedef int starpu_pthread_key_t;
  78. int starpu_pthread_key_create(starpu_pthread_key_t *key, void (*destr_function) (void *));
  79. int starpu_pthread_key_delete(starpu_pthread_key_t key);
  80. int starpu_pthread_setspecific(starpu_pthread_key_t key, const void *pointer);
  81. void *starpu_pthread_getspecific(starpu_pthread_key_t key);
  82. #elif !defined(_MSC_VER) /* STARPU_SIMGRID */
  83. typedef pthread_key_t starpu_pthread_key_t;
  84. #define starpu_pthread_key_create pthread_key_create
  85. #define starpu_pthread_key_delete pthread_key_delete
  86. #define starpu_pthread_setspecific pthread_setspecific
  87. #define starpu_pthread_getspecific pthread_getspecific
  88. #endif /* STARPU_SIMGRID, _MSC_VER */
  89. /*
  90. * Encapsulation of the pthread_cond_* functions.
  91. */
  92. #ifdef STARPU_SIMGRID
  93. typedef xbt_cond_t starpu_pthread_cond_t;
  94. typedef int starpu_pthread_condattr_t;
  95. #define STARPU_PTHREAD_COND_INITIALIZER NULL
  96. int starpu_pthread_cond_init(starpu_pthread_cond_t *cond, starpu_pthread_condattr_t *cond_attr);
  97. int starpu_pthread_cond_signal(starpu_pthread_cond_t *cond);
  98. int starpu_pthread_cond_broadcast(starpu_pthread_cond_t *cond);
  99. int starpu_pthread_cond_wait(starpu_pthread_cond_t *cond, starpu_pthread_mutex_t *mutex);
  100. int starpu_pthread_cond_timedwait(starpu_pthread_cond_t *cond, starpu_pthread_mutex_t *mutex, const struct timespec *abstime);
  101. int starpu_pthread_cond_destroy(starpu_pthread_cond_t *cond);
  102. #elif !defined(_MSC_VER) /* STARPU_SIMGRID */
  103. typedef pthread_cond_t starpu_pthread_cond_t;
  104. typedef pthread_condattr_t starpu_pthread_condattr_t;
  105. #define STARPU_PTHREAD_COND_INITIALIZER PTHREAD_COND_INITIALIZER
  106. #define starpu_pthread_cond_init pthread_cond_init
  107. #define starpu_pthread_cond_signal pthread_cond_signal
  108. #define starpu_pthread_cond_broadcast pthread_cond_broadcast
  109. int starpu_pthread_cond_wait(starpu_pthread_cond_t *cond, starpu_pthread_mutex_t *mutex);
  110. #define starpu_pthread_cond_timedwait pthread_cond_timedwait
  111. #define starpu_pthread_cond_destroy pthread_cond_destroy
  112. #endif /* STARPU_SIMGRID, _MSC_VER */
  113. /*
  114. * Encapsulation of the pthread_rwlock_* functions.
  115. */
  116. #ifdef STARPU_SIMGRID
  117. typedef xbt_mutex_t starpu_pthread_rwlock_t;
  118. typedef int starpu_pthread_rwlockattr_t;
  119. int starpu_pthread_rwlock_init(starpu_pthread_rwlock_t *rwlock, const starpu_pthread_rwlockattr_t *attr);
  120. int starpu_pthread_rwlock_destroy(starpu_pthread_rwlock_t *rwlock);
  121. int starpu_pthread_rwlock_rdlock(starpu_pthread_rwlock_t *rwlock);
  122. int starpu_pthread_rwlock_tryrdlock(starpu_pthread_rwlock_t *rwlock);
  123. int starpu_pthread_rwlock_wrlock(starpu_pthread_rwlock_t *rwlock);
  124. int starpu_pthread_rwlock_trywrlock(starpu_pthread_rwlock_t *rwlock);
  125. int starpu_pthread_rwlock_unlock(starpu_pthread_rwlock_t *rwlock);
  126. #elif !defined(_MSC_VER) /* STARPU_SIMGRID */
  127. typedef pthread_rwlock_t starpu_pthread_rwlock_t;
  128. typedef pthread_rwlockattr_t starpu_pthread_rwlockattr_t;
  129. #define starpu_pthread_rwlock_init pthread_rwlock_init
  130. #define starpu_pthread_rwlock_destroy pthread_rwlock_destroy
  131. int starpu_pthread_rwlock_rdlock(starpu_pthread_rwlock_t *rwlock);
  132. int starpu_pthread_rwlock_tryrdlock(starpu_pthread_rwlock_t *rwlock);
  133. int starpu_pthread_rwlock_wrlock(starpu_pthread_rwlock_t *rwlock);
  134. int starpu_pthread_rwlock_trywrlock(starpu_pthread_rwlock_t *rwlock);
  135. int starpu_pthread_rwlock_unlock(starpu_pthread_rwlock_t *rwlock);
  136. #endif /* STARPU_SIMGRID, _MSC_VER */
  137. #ifdef _MSC_VER
  138. typedef void* starpu_pthread_rwlock_t;
  139. typedef void* starpu_pthread_mutex_t;
  140. typedef void* starpu_pthread_cond_t;
  141. #endif /* _MSC_VER */
  142. #ifdef __cplusplus
  143. }
  144. #endif
  145. #endif /* __STARPU_THREAD_H__ */