starpu_thread.h 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189
  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 STARPU_SIMGRID
  20. #include <xbt/synchro_core.h>
  21. #include <msg/msg.h>
  22. #elif !defined(_MSC_VER)
  23. #include <pthread.h>
  24. #endif
  25. #ifdef __cplusplus
  26. extern "C"
  27. {
  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. #define starpu_pthread_mutex_lock pthread_mutex_lock
  69. #define starpu_pthread_mutex_unlock pthread_mutex_unlock
  70. #define starpu_pthread_mutex_trylock pthread_mutex_trylock
  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. #define starpu_pthread_cond_wait pthread_cond_wait
  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_wrlock(starpu_pthread_rwlock_t *rwlock);
  123. int starpu_pthread_rwlock_unlock(starpu_pthread_rwlock_t *rwlock);
  124. #elif !defined(_MSC_VER) /* STARPU_SIMGRID */
  125. typedef pthread_rwlock_t starpu_pthread_rwlock_t;
  126. typedef pthread_rwlockattr_t starpu_pthread_rwlockattr_t;
  127. #define starpu_pthread_rwlock_init pthread_rwlock_init
  128. #define starpu_pthread_rwlock_destroy pthread_rwlock_destroy
  129. #define starpu_pthread_rwlock_rdlock pthread_rwlock_rdlock
  130. #define starpu_pthread_rwlock_wrlock pthread_rwlock_wrlock
  131. #define starpu_pthread_rwlock_unlock pthread_rwlock_unlock
  132. #endif /* STARPU_SIMGRID, _MSC_VER */
  133. #ifdef _MSC_VER
  134. typedef void* starpu_pthread_rwlock_t;
  135. typedef void* starpu_pthread_mutex_t;
  136. typedef void* starpu_pthread_cond_t;
  137. #endif /* _MSC_VER */
  138. #ifdef __cplusplus
  139. }
  140. #endif
  141. #endif /* __STARPU_THREAD_H__ */