debug.h 9.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314
  1. /* StarPU --- Runtime system for heterogeneous multicore architectures.
  2. *
  3. * Copyright (C) 2009-2020 Université de Bordeaux, CNRS (LaBRI UMR 5800), Inria
  4. *
  5. * StarPU is free software; you can redistribute it and/or modify
  6. * it under the terms of the GNU Lesser General Public License as published by
  7. * the Free Software Foundation; either version 2.1 of the License, or (at
  8. * your option) any later version.
  9. *
  10. * StarPU is distributed in the hope that it will be useful, but
  11. * WITHOUT ANY WARRANTY; without even the implied warranty of
  12. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
  13. *
  14. * See the GNU Lesser General Public License in COPYING.LGPL for more details.
  15. */
  16. #ifndef __DEBUG_H__
  17. #define __DEBUG_H__
  18. /** @file */
  19. #include <stdio.h>
  20. #include <stdlib.h>
  21. #include <stdarg.h>
  22. #include <common/config.h>
  23. #include <core/workers.h>
  24. #if defined(STARPU_USE_AYUDAME1)
  25. /* Ayudame 1 API */
  26. # include <Ayudame.h>
  27. # ifndef AYU_RT_STARPU
  28. # define AYU_RT_STARPU 4
  29. # endif
  30. # define STARPU_AYU_EVENT AYU_event
  31. # define STARPU_AYU_PREINIT() \
  32. if (AYU_event) \
  33. { \
  34. enum ayu_runtime_t ayu_rt = AYU_RT_STARPU; \
  35. AYU_event(AYU_PREINIT, 0, (void*) &ayu_rt); \
  36. }
  37. # define STARPU_AYU_INIT() \
  38. if (AYU_event) \
  39. { \
  40. AYU_event(AYU_INIT, 0, NULL); \
  41. }
  42. # define STARPU_AYU_FINISH() \
  43. if (AYU_event) \
  44. { \
  45. AYU_event(AYU_FINISH, 0, NULL); \
  46. }
  47. # define STARPU_AYU_ADDDEPENDENCY(previous, handle, job_id) \
  48. if (AYU_event) \
  49. { \
  50. uintptr_t __AYU_data[3] = { (previous), (uintptr_t) (handle), (uintptr_t) (handle) }; \
  51. AYU_event(AYU_ADDDEPENDENCY, (job_id), __AYU_data); \
  52. }
  53. # define STARPU_AYU_REMOVETASK(job_id) \
  54. if (AYU_event) \
  55. { \
  56. AYU_event(AYU_REMOVETASK, (job_id), NULL); \
  57. }
  58. # define STARPU_AYU_ADDTASK(job_id, task) \
  59. if (AYU_event) \
  60. { \
  61. int64_t __AYU_data[2] = { \
  62. ((struct starpu_task *)(task))!=NULL?_starpu_ayudame_get_func_id(((struct starpu_task *)(task))->cl):0, \
  63. ((struct starpu_task *)(task))!=NULL?((struct starpu_task *)(task))->priority-STARPU_MIN_PRIO:0 \
  64. }; \
  65. AYU_event(AYU_ADDTASK, (job_id), __AYU_data); \
  66. }
  67. # define STARPU_AYU_PRERUNTASK(job_id, workerid) \
  68. if (AYU_event) \
  69. { \
  70. intptr_t __id = (workerid); \
  71. AYU_event(AYU_PRERUNTASK, (job_id), &__id); \
  72. }
  73. # define STARPU_AYU_RUNTASK(job_id) \
  74. if (AYU_event) \
  75. { \
  76. AYU_event(AYU_RUNTASK, (job_id), NULL); \
  77. }
  78. # define STARPU_AYU_POSTRUNTASK(job_id) \
  79. if (AYU_event) \
  80. { \
  81. AYU_event(AYU_POSTRUNTASK, (job_id), NULL); \
  82. }
  83. # define STARPU_AYU_ADDTOTASKQUEUE(job_id, worker_id) \
  84. if (AYU_event) \
  85. { \
  86. intptr_t __id = (worker_id); \
  87. AYU_event(AYU_ADDTASKTOQUEUE, (job_id), &__id); \
  88. }
  89. # define STARPU_AYU_BARRIER() \
  90. if (AYU_event) \
  91. { \
  92. AYU_event(AYU_BARRIER, 0, NULL); \
  93. }
  94. #elif defined(STARPU_USE_AYUDAME2)
  95. /* Ayudame 2 API */
  96. # include <ayudame.h>
  97. # define STARPU_AYU_EVENT ayu_event
  98. # define STARPU_AYU_PREINIT()
  99. # define STARPU_AYU_INIT()
  100. # define STARPU_AYU_FINISH() \
  101. if (ayu_event){ \
  102. ayu_client_id_t __cli_id = get_client_id(AYU_CLIENT_STARPU); \
  103. ayu_event_data_t __data; \
  104. __data.common.client_id = __cli_id; \
  105. ayu_event(AYU_FINISH, __data); \
  106. }
  107. # define STARPU_AYU_ADDDEPENDENCY(previous, handle, job_id) \
  108. if (ayu_event) \
  109. { \
  110. ayu_client_id_t __cli_id = get_client_id(AYU_CLIENT_STARPU); \
  111. ayu_event_data_t __data; \
  112. uint64_t __dep_id=0; \
  113. __dep_id |= (previous) << 0; \
  114. __dep_id |= (job_id) << 24; \
  115. __dep_id |= (uintptr_t) (handle) << 48; \
  116. __data.common.client_id = __cli_id; \
  117. __data.add_dependency.dependency_id = __dep_id; \
  118. __data.add_dependency.from_id=(previous); \
  119. __data.add_dependency.to_id=(job_id); \
  120. __data.add_dependency.dependency_label = "dep"; \
  121. ayu_event(AYU_ADDDEPENDENCY, __data); \
  122. ayu_wipe_data(&__data); \
  123. \
  124. char __buf[32]; \
  125. snprintf(__buf, sizeof(__buf), "%llu", (unsigned long long)(uintptr_t) (handle)); \
  126. __data.common.client_id = __cli_id; \
  127. __data.set_property.property_owner_id = __dep_id; \
  128. __data.set_property.key = "dep_address_value"; \
  129. __data.set_property.value = __buf; \
  130. ayu_event(AYU_SETPROPERTY, __data); \
  131. ayu_wipe_data(&__data); \
  132. }
  133. # define STARPU_AYU_REMOVETASK(job_id) \
  134. if (ayu_event) \
  135. { \
  136. ayu_client_id_t __cli_id = get_client_id(AYU_CLIENT_STARPU); \
  137. ayu_event_data_t __data; \
  138. __data.common.client_id = __cli_id; \
  139. __data.set_property.property_owner_id = (job_id); \
  140. __data.set_property.key = "state"; \
  141. __data.set_property.value = "finished"; \
  142. ayu_event(AYU_SETPROPERTY, __data); \
  143. ayu_wipe_data(&__data); \
  144. }
  145. # define STARPU_AYU_ADDTASK(job_id, task) \
  146. if (ayu_event) \
  147. { \
  148. ayu_client_id_t __cli_id = get_client_id(AYU_CLIENT_STARPU); \
  149. ayu_event_data_t __data; \
  150. __data.common.client_id = __cli_id; \
  151. __data.add_task.task_id = (job_id); \
  152. __data.add_task.scope_id = 0; \
  153. __data.add_task.task_label = "task"; \
  154. ayu_event(AYU_ADDTASK, __data); \
  155. ayu_wipe_data(&__data); \
  156. \
  157. if ((task) != NULL) \
  158. { \
  159. char __buf[32]; \
  160. snprintf(__buf, sizeof(__buf), "%d", ((struct starpu_task *)(task))->priority); \
  161. __data.common.client_id = __cli_id; \
  162. __data.set_property.property_owner_id = (job_id); \
  163. __data.set_property.key = "priority"; \
  164. __data.set_property.value = __buf; \
  165. ayu_event(AYU_SETPROPERTY, __data); \
  166. ayu_wipe_data(&__data); \
  167. \
  168. const char *__name = ((struct starpu_task *)(task))->name != NULL?((struct starpu_task *)(task))->name: \
  169. ((struct starpu_task *)(task))->cl->name != NULL?((struct starpu_task *)(task))->cl->name:"<no_name>"; \
  170. __data.common.client_id = __cli_id; \
  171. __data.set_property.property_owner_id = (job_id); \
  172. __data.set_property.key = "function_name"; \
  173. __data.set_property.value = __name; \
  174. ayu_event(AYU_SETPROPERTY, __data); \
  175. ayu_wipe_data(&__data); \
  176. } \
  177. }
  178. # define STARPU_AYU_PRERUNTASK(job_id, workerid) \
  179. if (ayu_event) \
  180. { \
  181. ayu_client_id_t __cli_id = get_client_id(AYU_CLIENT_STARPU); \
  182. ayu_event_data_t __data; \
  183. __data.common.client_id = __cli_id; \
  184. __data.set_property.property_owner_id = (job_id); \
  185. __data.set_property.key = "state"; \
  186. __data.set_property.value = "running"; \
  187. ayu_event(AYU_SETPROPERTY, __data); \
  188. ayu_wipe_data(&__data); \
  189. \
  190. char __buf[32]; \
  191. snprintf(__buf, sizeof(__buf), "%d", (workerid)); \
  192. __data.common.client_id = __cli_id; \
  193. __data.set_property.property_owner_id = (job_id); \
  194. __data.set_property.key = "worker"; \
  195. __data.set_property.value = __buf; \
  196. ayu_event(AYU_SETPROPERTY, __data); \
  197. ayu_wipe_data(&__data); \
  198. }
  199. # define STARPU_AYU_RUNTASK(job_id) \
  200. if (ayu_event) { \
  201. ayu_client_id_t __cli_id = get_client_id(AYU_CLIENT_STARPU); \
  202. ayu_event_data_t __data; \
  203. __data.common.client_id = __cli_id; \
  204. __data.set_property.property_owner_id = (job_id); \
  205. __data.set_property.key = "state"; \
  206. __data.set_property.value = "running"; \
  207. ayu_event(AYU_SETPROPERTY, __data); \
  208. ayu_wipe_data(&__data); \
  209. }
  210. # define STARPU_AYU_POSTRUNTASK(job_id) \
  211. if (ayu_event) \
  212. { \
  213. /* TODO ADD thread id core id etc */ \
  214. ayu_client_id_t __cli_id = get_client_id(AYU_CLIENT_STARPU); \
  215. ayu_event_data_t __data; \
  216. __data.common.client_id = __cli_id; \
  217. __data.set_property.property_owner_id = (job_id); \
  218. __data.set_property.key = "state"; \
  219. __data.set_property.value = "finished"; \
  220. ayu_event(AYU_SETPROPERTY, __data); \
  221. ayu_wipe_data(&__data); \
  222. }
  223. # define STARPU_AYU_ADDTOTASKQUEUE(job_id, worker_id) \
  224. if (ayu_event) \
  225. { \
  226. ayu_client_id_t __cli_id = get_client_id(AYU_CLIENT_STARPU); \
  227. ayu_event_data_t __data; \
  228. __data.common.client_id = __cli_id; \
  229. __data.set_property.property_owner_id = (job_id); \
  230. __data.set_property.key = "state"; \
  231. __data.set_property.value = "queued"; \
  232. ayu_event(AYU_SETPROPERTY, __data); \
  233. ayu_wipe_data(&__data); \
  234. \
  235. char __buf[32]; \
  236. snprintf(__buf, sizeof(__buf), "%d", (int)(worker_id)); \
  237. __data.common.client_id = __cli_id; \
  238. __data.set_property.property_owner_id = (job_id); \
  239. __data.set_property.key = "worker"; \
  240. __data.set_property.value = __buf; \
  241. ayu_event(AYU_SETPROPERTY, __data); \
  242. ayu_wipe_data(&__data); \
  243. }
  244. # define STARPU_AYU_BARRIER() \
  245. if (ayu_event) \
  246. { \
  247. /* How to generate a barrier event with Ayudame 2? */ \
  248. }
  249. #else
  250. # define STARPU_AYU_EVENT (0)
  251. # define STARPU_AYU_PREINIT()
  252. # define STARPU_AYU_INIT()
  253. # define STARPU_AYU_FINISH()
  254. # define STARPU_AYU_ADDDEPENDENCY(previous, handle, next_job)
  255. # define STARPU_AYU_REMOVETASK(job_id)
  256. # define STARPU_AYU_ADDTASK(job_id, task)
  257. # define STARPU_AYU_PRERUNTASK(job_id, workerid)
  258. # define STARPU_AYU_RUNTASK(job_id)
  259. # define STARPU_AYU_POSTRUNTASK(job_id)
  260. # define STARPU_AYU_ADDTOTASKQUEUE(job_id, worker_id)
  261. # define STARPU_AYU_BARRIER()
  262. #endif
  263. /** Create a file that will contain StarPU's log */
  264. void _starpu_open_debug_logfile(void);
  265. /** Close StarPU's log file */
  266. void _starpu_close_debug_logfile(void);
  267. /** Write into StarPU's log file */
  268. void _starpu_print_to_logfile(const char *format, ...) STARPU_ATTRIBUTE_FORMAT(printf, 1, 2);
  269. /** Tell gdb whether FXT is compiled in or not */
  270. extern int _starpu_use_fxt;
  271. #if defined(STARPU_USE_AYUDAME1)
  272. /** Get an Ayudame id for CL */
  273. int64_t _starpu_ayudame_get_func_id(struct starpu_codelet *cl);
  274. #endif
  275. void _starpu_watchdog_init(void);
  276. void _starpu_watchdog_shutdown(void);
  277. #endif // __DEBUG_H__