starpu_thread.h 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179
  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. #include <starpu.h>
  20. #ifdef STARPU_SIMGRID
  21. #include <xbt/synchro_core.h>
  22. #include <msg/msg.h>
  23. #else
  24. #include <pthread.h>
  25. #endif
  26. #ifdef __cplusplus
  27. extern "C"
  28. {
  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(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. #else /* 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_join pthread_join
  46. #define starpu_pthread_attr_init pthread_attr_init
  47. #define starpu_pthread_attr_destroy pthread_attr_destroy
  48. #define starpu_pthread_attr_setdetachstate pthread_attr_setdetachstate
  49. #endif /* STARPU_SIMGRID */
  50. /*
  51. * Encapsulation of the pthread_mutex_* functions.
  52. */
  53. #ifdef STARPU_SIMGRID
  54. typedef xbt_mutex_t starpu_pthread_mutex_t;
  55. typedef int starpu_pthread_mutexattr_t;
  56. #define STARPU_PTHREAD_MUTEX_INITIALIZER NULL
  57. int starpu_pthread_mutex_init(starpu_pthread_mutex_t *mutex, const starpu_pthread_mutexattr_t *mutexattr);
  58. int starpu_pthread_mutex_destroy(starpu_pthread_mutex_t *mutex);
  59. int starpu_pthread_mutex_lock(starpu_pthread_mutex_t *mutex);
  60. int starpu_pthread_mutex_unlock(starpu_pthread_mutex_t *mutex);
  61. int starpu_pthread_mutex_trylock(starpu_pthread_mutex_t *mutex);
  62. #else /* !STARPU_SIMGRID */
  63. typedef pthread_mutex_t starpu_pthread_mutex_t;
  64. typedef pthread_mutexattr_t starpu_pthread_mutexattr_t;
  65. #define starpu_pthread_mutex_init pthread_mutex_init
  66. #define starpu_pthread_mutex_destroy pthread_mutex_destroy
  67. #define starpu_pthread_mutex_lock pthread_mutex_lock
  68. #define starpu_pthread_mutex_unlock pthread_mutex_unlock
  69. #define starpu_pthread_mutex_trylock pthread_mutex_trylock
  70. #define STARPU_PTHREAD_MUTEX_INITIALIZER PTHREAD_MUTEX_INITIALIZER
  71. #endif /* STARPU_SIMGRID */
  72. /*
  73. * Encapsulation of the pthread_key_* functions.
  74. */
  75. #ifdef STARPU_SIMGRID
  76. typedef int starpu_pthread_key_t;
  77. int starpu_pthread_key_create(starpu_pthread_key_t *key, void (*destr_function) (void *));
  78. int starpu_pthread_key_delete(starpu_pthread_key_t key);
  79. int starpu_pthread_setspecific(starpu_pthread_key_t key, const void *pointer);
  80. void *starpu_pthread_getspecific(starpu_pthread_key_t key);
  81. #else /* STARPU_SIMGRID */
  82. typedef pthread_key_t starpu_pthread_key_t;
  83. #define starpu_pthread_key_create pthread_key_create
  84. #define starpu_pthread_key_delete pthread_key_delete
  85. #define starpu_pthread_setspecific pthread_setspecific
  86. #define starpu_pthread_getspecific pthread_getspecific
  87. #endif /* STARPU_SIMGRID */
  88. /*
  89. * Encapsulation of the pthread_cond_* functions.
  90. */
  91. #ifdef STARPU_SIMGRID
  92. typedef xbt_cond_t starpu_pthread_cond_t;
  93. typedef int starpu_pthread_condattr_t;
  94. #define STARPU_PTHREAD_COND_INITIALIZER NULL
  95. int starpu_pthread_cond_init(starpu_pthread_cond_t *cond, starpu_pthread_condattr_t *cond_attr);
  96. int starpu_pthread_cond_signal(starpu_pthread_cond_t *cond);
  97. int starpu_pthread_cond_broadcast(starpu_pthread_cond_t *cond);
  98. int starpu_pthread_cond_wait(starpu_pthread_cond_t *cond, starpu_pthread_mutex_t *mutex);
  99. int starpu_pthread_cond_timedwait(starpu_pthread_cond_t *cond, starpu_pthread_mutex_t *mutex, const struct timespec *abstime);
  100. int starpu_pthread_cond_destroy(starpu_pthread_cond_t *cond);
  101. #else /* STARPU_SIMGRID */
  102. typedef pthread_cond_t starpu_pthread_cond_t;
  103. typedef pthread_condattr_t starpu_pthread_condattr_t;
  104. #define STARPU_PTHREAD_COND_INITIALIZER PTHREAD_COND_INITIALIZER
  105. #define starpu_pthread_cond_init pthread_cond_init
  106. #define starpu_pthread_cond_signal pthread_cond_signal
  107. #define starpu_pthread_cond_broadcast pthread_cond_broadcast
  108. #define starpu_pthread_cond_wait pthread_cond_wait
  109. #define starpu_pthread_cond_timedwait pthread_cond_timedwait
  110. #define starpu_pthread_cond_destroy pthread_cond_destroy
  111. #endif /* STARPU_SIMGRID */
  112. /*
  113. * Encapsulation of the pthread_rwlock_* functions.
  114. */
  115. #ifdef STARPU_SIMGRID
  116. typedef xbt_mutex_t starpu_pthread_rwlock_t;
  117. typedef int starpu_pthread_rwlockattr_t;
  118. int starpu_pthread_rwlock_init(starpu_pthread_rwlock_t *rwlock, const starpu_pthread_rwlockattr_t *attr);
  119. int starpu_pthread_rwlock_destroy(starpu_pthread_rwlock_t *rwlock);
  120. int starpu_pthread_rwlock_rdlock(starpu_pthread_rwlock_t *rwlock);
  121. int starpu_pthread_rwlock_wrlock(starpu_pthread_rwlock_t *rwlock);
  122. int starpu_pthread_rwlock_unlock(starpu_pthread_rwlock_t *rwlock);
  123. #else /* STARPU_SIMGRID */
  124. typedef pthread_rwlock_t starpu_pthread_rwlock_t;
  125. typedef pthread_rwlockattr_t starpu_pthread_rwlockattr_t;
  126. #define starpu_pthread_rwlock_init pthread_rwlock_init
  127. #define starpu_pthread_rwlock_destroy pthread_rwlock_destroy
  128. #define starpu_pthread_rwlock_rdlock pthread_rwlock_rdlock
  129. #define starpu_pthread_rwlock_wrlock pthread_rwlock_wrlock
  130. #define starpu_pthread_rwlock_unlock pthread_rwlock_unlock
  131. #endif /* STARPU_SIMGRID */
  132. #ifdef __cplusplus
  133. }
  134. #endif
  135. #endif /* __STARPU_THREAD_H__ */