xref: /freebsd/contrib/llvm-project/openmp/runtime/src/include/omp-tools.h.var (revision e1e636193db45630c7881246d25902e57c43d24e)
1/*
2 * include/omp-tools.h.var
3 */
4
5//===----------------------------------------------------------------------===//
6//
7// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
8// See https://llvm.org/LICENSE.txt for license information.
9// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
10//
11//===----------------------------------------------------------------------===//
12
13#ifndef __OMPT__
14#define __OMPT__
15
16/*****************************************************************************
17 * system include files
18 *****************************************************************************/
19
20#include <stdint.h>
21#include <stddef.h>
22
23#ifdef DEPRECATION_WARNINGS
24# ifdef __cplusplus
25# define DEPRECATED_51 [[deprecated("as of 5.1")]]
26# else
27# define DEPRECATED_51 __attribute__((deprecated("as of 5.1")))
28#endif
29#else
30#define DEPRECATED_51
31#endif
32
33/*****************************************************************************
34 * iteration macros
35 *****************************************************************************/
36
37#define FOREACH_OMPT_INQUIRY_FN(macro)      \
38    macro (ompt_enumerate_states)           \
39    macro (ompt_enumerate_mutex_impls)      \
40                                            \
41    macro (ompt_set_callback)               \
42    macro (ompt_get_callback)               \
43                                            \
44    macro (ompt_get_state)                  \
45                                            \
46    macro (ompt_get_parallel_info)          \
47    macro (ompt_get_task_info)              \
48    macro (ompt_get_task_memory)            \
49    macro (ompt_get_thread_data)            \
50    macro (ompt_get_unique_id)              \
51    macro (ompt_finalize_tool)              \
52                                            \
53    macro(ompt_get_num_procs)               \
54    macro(ompt_get_num_places)              \
55    macro(ompt_get_place_proc_ids)          \
56    macro(ompt_get_place_num)               \
57    macro(ompt_get_partition_place_nums)    \
58    macro(ompt_get_proc_id)                 \
59                                            \
60    macro(ompt_get_target_info)             \
61    macro(ompt_get_num_devices)
62
63#define FOREACH_OMPT_STATE(macro)                                                                \
64                                                                                                \
65    /* first available state */                                                                 \
66    macro (ompt_state_undefined, 0x102)      /* undefined thread state */                        \
67                                                                                                \
68    /* work states (0..15) */                                                                   \
69    macro (ompt_state_work_serial, 0x000)    /* working outside parallel */                      \
70    macro (ompt_state_work_parallel, 0x001)  /* working within parallel */                       \
71    macro (ompt_state_work_reduction, 0x002) /* performing a reduction */                        \
72                                                                                                \
73    /* barrier wait states (16..31) */                                                          \
74    macro (ompt_state_wait_barrier, 0x010)   /* waiting at a barrier */                          \
75    macro (ompt_state_wait_barrier_implicit_parallel, 0x011)                                     \
76                                            /* implicit barrier at the end of parallel region */\
77    macro (ompt_state_wait_barrier_implicit_workshare, 0x012)                                    \
78                                            /* implicit barrier at the end of worksharing */    \
79    macro (ompt_state_wait_barrier_implicit, 0x013)  /* implicit barrier */                      \
80    macro (ompt_state_wait_barrier_explicit, 0x014)  /* explicit barrier */                      \
81                                                                                                \
82    /* task wait states (32..63) */                                                             \
83    macro (ompt_state_wait_taskwait, 0x020)  /* waiting at a taskwait */                         \
84    macro (ompt_state_wait_taskgroup, 0x021) /* waiting at a taskgroup */                        \
85                                                                                                \
86    /* mutex wait states (64..127) */                                                           \
87    macro (ompt_state_wait_mutex, 0x040)                                                         \
88    macro (ompt_state_wait_lock, 0x041)      /* waiting for lock */                              \
89    macro (ompt_state_wait_critical, 0x042)  /* waiting for critical */                          \
90    macro (ompt_state_wait_atomic, 0x043)    /* waiting for atomic */                            \
91    macro (ompt_state_wait_ordered, 0x044)   /* waiting for ordered */                           \
92                                                                                                \
93    /* target wait states (128..255) */                                                         \
94    macro (ompt_state_wait_target, 0x080)        /* waiting for target region */                 \
95    macro (ompt_state_wait_target_map, 0x081)    /* waiting for target data mapping operation */ \
96    macro (ompt_state_wait_target_update, 0x082) /* waiting for target update operation */       \
97                                                                                                \
98    /* misc (256..511) */                                                                       \
99    macro (ompt_state_idle, 0x100)           /* waiting for work */                              \
100    macro (ompt_state_overhead, 0x101)       /* overhead excluding wait states */                \
101                                                                                                \
102    /* implementation-specific states (512..) */
103
104
105#define FOREACH_KMP_MUTEX_IMPL(macro)                                                \
106    macro (kmp_mutex_impl_none, 0)         /* unknown implementation */              \
107    macro (kmp_mutex_impl_spin, 1)         /* based on spin */                       \
108    macro (kmp_mutex_impl_queuing, 2)      /* based on some fair policy */           \
109    macro (kmp_mutex_impl_speculative, 3)  /* based on HW-supported speculation */
110
111#define FOREACH_OMPT_HOST_EVENT(macro)                                                                                   \
112                                                                                                                         \
113    /*--- Mandatory Events ---*/                                                                                         \
114    macro (ompt_callback_thread_begin,      ompt_callback_thread_begin_t,       1) /* thread begin                    */ \
115    macro (ompt_callback_thread_end,        ompt_callback_thread_end_t,         2) /* thread end                      */ \
116                                                                                                                         \
117    macro (ompt_callback_parallel_begin,    ompt_callback_parallel_begin_t,     3) /* parallel begin                  */ \
118    macro (ompt_callback_parallel_end,      ompt_callback_parallel_end_t,       4) /* parallel end                    */ \
119                                                                                                                         \
120    macro (ompt_callback_task_create,       ompt_callback_task_create_t,        5) /* task begin                      */ \
121    macro (ompt_callback_task_schedule,     ompt_callback_task_schedule_t,      6) /* task schedule                   */ \
122    macro (ompt_callback_implicit_task,     ompt_callback_implicit_task_t,      7) /* implicit task                   */ \
123                                                                                                                         \
124    macro (ompt_callback_control_tool,      ompt_callback_control_tool_t,      11) /* control tool                    */ \
125                                                                                                                         \
126    /* Optional Events */                                                                                                \
127    macro (ompt_callback_sync_region_wait,  ompt_callback_sync_region_t,       16) /* sync region wait begin or end   */ \
128                                                                                                                         \
129    macro (ompt_callback_mutex_released,    ompt_callback_mutex_t,             17) /* mutex released                  */ \
130                                                                                                                         \
131    macro (ompt_callback_dependences,       ompt_callback_dependences_t,       18) /* report task dependences         */ \
132    macro (ompt_callback_task_dependence,   ompt_callback_task_dependence_t,   19) /* report task dependence          */ \
133                                                                                                                         \
134    macro (ompt_callback_work,              ompt_callback_work_t,              20) /* task at work begin or end       */ \
135                                                                                                                         \
136    macro (ompt_callback_masked,            ompt_callback_masked_t,            21) /* task at masked begin or end     */ \
137                                                                                                                         \
138    macro (ompt_callback_sync_region,       ompt_callback_sync_region_t,       23) /* sync region begin or end        */ \
139                                                                                                                         \
140    macro (ompt_callback_lock_init,         ompt_callback_mutex_acquire_t,     24) /* lock init                       */ \
141    macro (ompt_callback_lock_destroy,      ompt_callback_mutex_t,             25) /* lock destroy                    */ \
142                                                                                                                         \
143    macro (ompt_callback_mutex_acquire,     ompt_callback_mutex_acquire_t,     26) /* mutex acquire                   */ \
144    macro (ompt_callback_mutex_acquired,    ompt_callback_mutex_t,             27) /* mutex acquired                  */ \
145                                                                                                                         \
146    macro (ompt_callback_nest_lock,         ompt_callback_nest_lock_t,         28) /* nest lock                       */ \
147                                                                                                                         \
148    macro (ompt_callback_flush,             ompt_callback_flush_t,             29) /* after executing flush           */ \
149                                                                                                                         \
150    macro (ompt_callback_cancel,            ompt_callback_cancel_t,            30) /* cancel innermost binding region */ \
151                                                                                                                         \
152    macro (ompt_callback_reduction,         ompt_callback_sync_region_t,       31) /* reduction                       */ \
153                                                                                                                         \
154    macro (ompt_callback_dispatch,          ompt_callback_dispatch_t,          32) /* dispatch of work                */ \
155    macro (ompt_callback_error,             ompt_callback_error_t,             37) /* error                           */
156
157#define FOREACH_OMPT_DEVICE_EVENT(macro)                                                                                 \
158    /*--- Mandatory Events ---*/                                                                                         \
159    macro (ompt_callback_device_initialize, ompt_callback_device_initialize_t, 12) /* device initialize               */ \
160    macro (ompt_callback_device_finalize,   ompt_callback_device_finalize_t,   13) /* device finalize                 */ \
161                                                                                                                         \
162    macro (ompt_callback_device_load,       ompt_callback_device_load_t,       14) /* device load                     */ \
163    macro (ompt_callback_device_unload,     ompt_callback_device_unload_t,     15) /* device unload                   */
164
165#define FOREACH_OMPT_NOEMI_EVENT(macro)                                                                                  \
166    /*--- Mandatory Events ---*/                                                                                         \
167    macro (ompt_callback_target,            ompt_callback_target_t,             8) /* target                          */ \
168    macro (ompt_callback_target_data_op,    ompt_callback_target_data_op_t,     9) /* target data op                  */ \
169    macro (ompt_callback_target_submit,     ompt_callback_target_submit_t,     10) /* target  submit                  */ \
170    /* Optional Events */                                                                                                \
171    macro (ompt_callback_target_map,        ompt_callback_target_map_t,        22) /* target map                      */
172
173#define FOREACH_OMPT_EMI_EVENT(macro)                                                                                    \
174    /*--- Mandatory Events ---*/                                                                                         \
175    macro (ompt_callback_target_emi,        ompt_callback_target_emi_t,        33) /* target                          */ \
176    macro (ompt_callback_target_data_op_emi,ompt_callback_target_data_op_emi_t,34) /* target data op                  */ \
177    macro (ompt_callback_target_submit_emi, ompt_callback_target_submit_emi_t, 35) /* target submit                   */ \
178    /* Optional Events */                                                                                                \
179    macro (ompt_callback_target_map_emi,    ompt_callback_target_map_emi_t,    36) /* target map                      */
180
181#define FOREACH_OMPT_50_TARGET_EVENT(macro)                                                                              \
182    FOREACH_OMPT_DEVICE_EVENT(macro)                                                                                     \
183    FOREACH_OMPT_NOEMI_EVENT(macro)
184
185#define FOREACH_OMPT_51_TARGET_EVENT(macro)                                                                              \
186    FOREACH_OMPT_DEVICE_EVENT(macro)                                                                                     \
187    FOREACH_OMPT_EMI_EVENT(macro)
188
189#define FOREACH_OMPT_EVENT(macro)                                                                                        \
190    FOREACH_OMPT_HOST_EVENT(macro)                                                                                       \
191    FOREACH_OMPT_DEVICE_EVENT(macro)                                                                                     \
192    FOREACH_OMPT_NOEMI_EVENT(macro)                                                                                      \
193    FOREACH_OMPT_EMI_EVENT(macro)
194
195#define FOREACH_OMPT_51_EVENT(macro)                                                                                     \
196    FOREACH_OMPT_HOST_EVENT(macro)                                                                                       \
197    FOREACH_OMPT_DEVICE_EVENT(macro)                                                                                     \
198    FOREACH_OMPT_EMI_EVENT(macro)
199
200/*****************************************************************************
201 * implementation specific types
202 *****************************************************************************/
203
204typedef enum kmp_mutex_impl_t {
205#define kmp_mutex_impl_macro(impl, code) impl = code,
206    FOREACH_KMP_MUTEX_IMPL(kmp_mutex_impl_macro)
207#undef kmp_mutex_impl_macro
208} kmp_mutex_impl_t;
209
210/*****************************************************************************
211 * definitions generated from spec
212 *****************************************************************************/
213
214typedef enum ompt_callbacks_t {
215  ompt_callback_thread_begin             = 1,
216  ompt_callback_thread_end               = 2,
217  ompt_callback_parallel_begin           = 3,
218  ompt_callback_parallel_end             = 4,
219  ompt_callback_task_create              = 5,
220  ompt_callback_task_schedule            = 6,
221  ompt_callback_implicit_task            = 7,
222  ompt_callback_target                   = 8,
223  ompt_callback_target_data_op           = 9,
224  ompt_callback_target_submit            = 10,
225  ompt_callback_control_tool             = 11,
226  ompt_callback_device_initialize        = 12,
227  ompt_callback_device_finalize          = 13,
228  ompt_callback_device_load              = 14,
229  ompt_callback_device_unload            = 15,
230  ompt_callback_sync_region_wait         = 16,
231  ompt_callback_mutex_released           = 17,
232  ompt_callback_dependences              = 18,
233  ompt_callback_task_dependence          = 19,
234  ompt_callback_work                     = 20,
235  ompt_callback_master     DEPRECATED_51 = 21,
236  ompt_callback_masked                   = 21,
237  ompt_callback_target_map               = 22,
238  ompt_callback_sync_region              = 23,
239  ompt_callback_lock_init                = 24,
240  ompt_callback_lock_destroy             = 25,
241  ompt_callback_mutex_acquire            = 26,
242  ompt_callback_mutex_acquired           = 27,
243  ompt_callback_nest_lock                = 28,
244  ompt_callback_flush                    = 29,
245  ompt_callback_cancel                   = 30,
246  ompt_callback_reduction                = 31,
247  ompt_callback_dispatch                 = 32,
248  ompt_callback_target_emi               = 33,
249  ompt_callback_target_data_op_emi       = 34,
250  ompt_callback_target_submit_emi        = 35,
251  ompt_callback_target_map_emi           = 36,
252  ompt_callback_error                    = 37
253} ompt_callbacks_t;
254
255typedef enum ompt_record_t {
256  ompt_record_ompt               = 1,
257  ompt_record_native             = 2,
258  ompt_record_invalid            = 3
259} ompt_record_t;
260
261typedef enum ompt_record_native_t {
262  ompt_record_native_info  = 1,
263  ompt_record_native_event = 2
264} ompt_record_native_t;
265
266typedef enum ompt_set_result_t {
267  ompt_set_error            = 0,
268  ompt_set_never            = 1,
269  ompt_set_impossible       = 2,
270  ompt_set_sometimes        = 3,
271  ompt_set_sometimes_paired = 4,
272  ompt_set_always           = 5
273} ompt_set_result_t;
274
275typedef uint64_t ompt_id_t;
276
277typedef uint64_t ompt_device_time_t;
278
279typedef uint64_t ompt_buffer_cursor_t;
280
281typedef enum ompt_thread_t {
282  ompt_thread_initial                 = 1,
283  ompt_thread_worker                  = 2,
284  ompt_thread_other                   = 3,
285  ompt_thread_unknown                 = 4
286} ompt_thread_t;
287
288typedef enum ompt_scope_endpoint_t {
289  ompt_scope_begin                    = 1,
290  ompt_scope_end                      = 2,
291  ompt_scope_beginend                 = 3
292} ompt_scope_endpoint_t;
293
294typedef enum ompt_dispatch_t {
295  ompt_dispatch_iteration             = 1,
296  ompt_dispatch_section               = 2,
297  ompt_dispatch_ws_loop_chunk         = 3,
298  ompt_dispatch_taskloop_chunk        = 4,
299  ompt_dispatch_distribute_chunk      = 5
300} ompt_dispatch_t;
301
302typedef enum ompt_sync_region_t {
303  ompt_sync_region_barrier                DEPRECATED_51 = 1,
304  ompt_sync_region_barrier_implicit       DEPRECATED_51 = 2,
305  ompt_sync_region_barrier_explicit       = 3,
306  ompt_sync_region_barrier_implementation = 4,
307  ompt_sync_region_taskwait               = 5,
308  ompt_sync_region_taskgroup              = 6,
309  ompt_sync_region_reduction              = 7,
310  ompt_sync_region_barrier_implicit_workshare = 8,
311  ompt_sync_region_barrier_implicit_parallel = 9,
312  ompt_sync_region_barrier_teams = 10
313} ompt_sync_region_t;
314
315typedef enum ompt_target_data_op_t {
316  ompt_target_data_alloc                      = 1,
317  ompt_target_data_transfer_to_device         = 2,
318  ompt_target_data_transfer_from_device       = 3,
319  ompt_target_data_delete                     = 4,
320  ompt_target_data_associate                  = 5,
321  ompt_target_data_disassociate               = 6,
322  ompt_target_data_alloc_async                = 17,
323  ompt_target_data_transfer_to_device_async   = 18,
324  ompt_target_data_transfer_from_device_async = 19,
325  ompt_target_data_delete_async               = 20
326} ompt_target_data_op_t;
327
328typedef enum ompt_work_t {
329  ompt_work_loop               = 1,
330  ompt_work_sections           = 2,
331  ompt_work_single_executor    = 3,
332  ompt_work_single_other       = 4,
333  ompt_work_workshare          = 5,
334  ompt_work_distribute         = 6,
335  ompt_work_taskloop           = 7,
336  ompt_work_scope              = 8,
337  ompt_work_loop_static        = 10,
338  ompt_work_loop_dynamic       = 11,
339  ompt_work_loop_guided        = 12,
340  ompt_work_loop_other         = 13
341} ompt_work_t;
342
343typedef enum ompt_mutex_t {
344  ompt_mutex_lock                     = 1,
345  ompt_mutex_test_lock                = 2,
346  ompt_mutex_nest_lock                = 3,
347  ompt_mutex_test_nest_lock           = 4,
348  ompt_mutex_critical                 = 5,
349  ompt_mutex_atomic                   = 6,
350  ompt_mutex_ordered                  = 7
351} ompt_mutex_t;
352
353typedef enum ompt_native_mon_flag_t {
354  ompt_native_data_motion_explicit    = 0x01,
355  ompt_native_data_motion_implicit    = 0x02,
356  ompt_native_kernel_invocation       = 0x04,
357  ompt_native_kernel_execution        = 0x08,
358  ompt_native_driver                  = 0x10,
359  ompt_native_runtime                 = 0x20,
360  ompt_native_overhead                = 0x40,
361  ompt_native_idleness                = 0x80
362} ompt_native_mon_flag_t;
363
364typedef enum ompt_task_flag_t {
365  ompt_task_initial                   = 0x00000001,
366  ompt_task_implicit                  = 0x00000002,
367  ompt_task_explicit                  = 0x00000004,
368  ompt_task_target                    = 0x00000008,
369  ompt_task_taskwait                  = 0x00000010,
370  ompt_task_undeferred                = 0x08000000,
371  ompt_task_untied                    = 0x10000000,
372  ompt_task_final                     = 0x20000000,
373  ompt_task_mergeable                 = 0x40000000,
374  ompt_task_merged                    = 0x80000000
375} ompt_task_flag_t;
376
377typedef enum ompt_task_status_t {
378  ompt_task_complete      = 1,
379  ompt_task_yield         = 2,
380  ompt_task_cancel        = 3,
381  ompt_task_detach        = 4,
382  ompt_task_early_fulfill = 5,
383  ompt_task_late_fulfill  = 6,
384  ompt_task_switch        = 7,
385  ompt_taskwait_complete  = 8
386} ompt_task_status_t;
387
388typedef enum ompt_target_t {
389  ompt_target                         = 1,
390  ompt_target_enter_data              = 2,
391  ompt_target_exit_data               = 3,
392  ompt_target_update                  = 4,
393  ompt_target_nowait                  = 9,
394  ompt_target_enter_data_nowait       = 10,
395  ompt_target_exit_data_nowait        = 11,
396  ompt_target_update_nowait           = 12
397} ompt_target_t;
398
399typedef enum ompt_parallel_flag_t {
400  ompt_parallel_invoker_program = 0x00000001,
401  ompt_parallel_invoker_runtime = 0x00000002,
402  ompt_parallel_league          = 0x40000000,
403  ompt_parallel_team            = 0x80000000
404} ompt_parallel_flag_t;
405
406typedef enum ompt_target_map_flag_t {
407  ompt_target_map_flag_to             = 0x01,
408  ompt_target_map_flag_from           = 0x02,
409  ompt_target_map_flag_alloc          = 0x04,
410  ompt_target_map_flag_release        = 0x08,
411  ompt_target_map_flag_delete         = 0x10,
412  ompt_target_map_flag_implicit       = 0x20
413} ompt_target_map_flag_t;
414
415typedef enum ompt_dependence_type_t {
416  ompt_dependence_type_in               = 1,
417  ompt_dependence_type_out              = 2,
418  ompt_dependence_type_inout            = 3,
419  ompt_dependence_type_mutexinoutset    = 4,
420  ompt_dependence_type_source           = 5,
421  ompt_dependence_type_sink             = 6,
422  ompt_dependence_type_inoutset         = 7,
423  ompt_dependence_type_out_all_memory   = 34,
424  ompt_dependence_type_inout_all_memory = 35
425} ompt_dependence_type_t;
426
427typedef enum ompt_severity_t {
428  ompt_warning                         = 1,
429  ompt_fatal                           = 2
430} ompt_severity_t;
431
432typedef enum ompt_cancel_flag_t {
433  ompt_cancel_parallel       = 0x01,
434  ompt_cancel_sections       = 0x02,
435  ompt_cancel_loop           = 0x04,
436  ompt_cancel_taskgroup      = 0x08,
437  ompt_cancel_activated      = 0x10,
438  ompt_cancel_detected       = 0x20,
439  ompt_cancel_discarded_task = 0x40
440} ompt_cancel_flag_t;
441
442typedef uint64_t ompt_hwid_t;
443
444typedef uint64_t ompt_wait_id_t;
445
446typedef enum ompt_frame_flag_t {
447  ompt_frame_runtime        = 0x00,
448  ompt_frame_application    = 0x01,
449  ompt_frame_cfa            = 0x10,
450  ompt_frame_framepointer   = 0x20,
451  ompt_frame_stackaddress   = 0x30
452} ompt_frame_flag_t;
453
454typedef enum ompt_state_t {
455  ompt_state_work_serial                      = 0x000,
456  ompt_state_work_parallel                    = 0x001,
457  ompt_state_work_reduction                   = 0x002,
458
459  ompt_state_wait_barrier                     DEPRECATED_51 = 0x010,
460  ompt_state_wait_barrier_implicit_parallel   = 0x011,
461  ompt_state_wait_barrier_implicit_workshare  = 0x012,
462  ompt_state_wait_barrier_implicit            DEPRECATED_51 = 0x013,
463  ompt_state_wait_barrier_explicit            = 0x014,
464  ompt_state_wait_barrier_implementation      = 0x015,
465  ompt_state_wait_barrier_teams               = 0x016,
466
467  ompt_state_wait_taskwait                    = 0x020,
468  ompt_state_wait_taskgroup                   = 0x021,
469
470  ompt_state_wait_mutex                       = 0x040,
471  ompt_state_wait_lock                        = 0x041,
472  ompt_state_wait_critical                    = 0x042,
473  ompt_state_wait_atomic                      = 0x043,
474  ompt_state_wait_ordered                     = 0x044,
475
476  ompt_state_wait_target                      = 0x080,
477  ompt_state_wait_target_map                  = 0x081,
478  ompt_state_wait_target_update               = 0x082,
479
480  ompt_state_idle                             = 0x100,
481  ompt_state_overhead                         = 0x101,
482  ompt_state_undefined                        = 0x102
483} ompt_state_t;
484
485typedef uint64_t (*ompt_get_unique_id_t) (void);
486
487typedef uint64_t ompd_size_t;
488
489typedef uint64_t ompd_wait_id_t;
490
491typedef uint64_t ompd_addr_t;
492typedef int64_t  ompd_word_t;
493typedef uint64_t ompd_seg_t;
494
495typedef uint64_t ompd_device_t;
496
497typedef uint64_t ompd_thread_id_t;
498
499typedef enum ompd_scope_t {
500  ompd_scope_global = 1,
501  ompd_scope_address_space = 2,
502  ompd_scope_thread = 3,
503  ompd_scope_parallel = 4,
504  ompd_scope_implicit_task = 5,
505  ompd_scope_task = 6
506} ompd_scope_t;
507
508typedef uint64_t ompd_icv_id_t;
509
510typedef enum ompd_rc_t {
511  ompd_rc_ok = 0,
512  ompd_rc_unavailable = 1,
513  ompd_rc_stale_handle = 2,
514  ompd_rc_bad_input = 3,
515  ompd_rc_error = 4,
516  ompd_rc_unsupported = 5,
517  ompd_rc_needs_state_tracking = 6,
518  ompd_rc_incompatible = 7,
519  ompd_rc_device_read_error = 8,
520  ompd_rc_device_write_error = 9,
521  ompd_rc_nomem = 10,
522  ompd_rc_incomplete = 11,
523  ompd_rc_callback_error = 12
524} ompd_rc_t;
525
526typedef void (*ompt_interface_fn_t) (void);
527
528typedef ompt_interface_fn_t (*ompt_function_lookup_t) (
529  const char *interface_function_name
530);
531
532typedef union ompt_data_t {
533  uint64_t value;
534  void *ptr;
535} ompt_data_t;
536
537typedef struct ompt_frame_t {
538  ompt_data_t exit_frame;
539  ompt_data_t enter_frame;
540  int exit_frame_flags;
541  int enter_frame_flags;
542} ompt_frame_t;
543
544typedef void (*ompt_callback_t) (void);
545
546typedef void ompt_device_t;
547
548typedef void ompt_buffer_t;
549
550typedef void (*ompt_callback_buffer_request_t) (
551  int device_num,
552  ompt_buffer_t **buffer,
553  size_t *bytes
554);
555
556typedef void (*ompt_callback_buffer_complete_t) (
557  int device_num,
558  ompt_buffer_t *buffer,
559  size_t bytes,
560  ompt_buffer_cursor_t begin,
561  int buffer_owned
562);
563
564typedef void (*ompt_finalize_t) (
565  ompt_data_t *tool_data
566);
567
568typedef int (*ompt_initialize_t) (
569  ompt_function_lookup_t lookup,
570  int initial_device_num,
571  ompt_data_t *tool_data
572);
573
574typedef struct ompt_start_tool_result_t {
575  ompt_initialize_t initialize;
576  ompt_finalize_t finalize;
577  ompt_data_t tool_data;
578} ompt_start_tool_result_t;
579
580typedef struct ompt_record_abstract_t {
581  ompt_record_native_t rclass;
582  const char *type;
583  ompt_device_time_t start_time;
584  ompt_device_time_t end_time;
585  ompt_hwid_t hwid;
586} ompt_record_abstract_t;
587
588typedef struct ompt_dependence_t {
589  ompt_data_t variable;
590  ompt_dependence_type_t dependence_type;
591} ompt_dependence_t;
592
593typedef struct ompt_dispatch_chunk_t {
594  uint64_t start;
595  uint64_t iterations;
596} ompt_dispatch_chunk_t;
597
598typedef int (*ompt_enumerate_states_t) (
599  int current_state,
600  int *next_state,
601  const char **next_state_name
602);
603
604typedef int (*ompt_enumerate_mutex_impls_t) (
605  int current_impl,
606  int *next_impl,
607  const char **next_impl_name
608);
609
610typedef ompt_set_result_t (*ompt_set_callback_t) (
611  ompt_callbacks_t event,
612  ompt_callback_t callback
613);
614
615typedef int (*ompt_get_callback_t) (
616  ompt_callbacks_t event,
617  ompt_callback_t *callback
618);
619
620typedef ompt_data_t *(*ompt_get_thread_data_t) (void);
621
622typedef int (*ompt_get_num_procs_t) (void);
623
624typedef int (*ompt_get_num_places_t) (void);
625
626typedef int (*ompt_get_place_proc_ids_t) (
627  int place_num,
628  int ids_size,
629  int *ids
630);
631
632typedef int (*ompt_get_place_num_t) (void);
633
634typedef int (*ompt_get_partition_place_nums_t) (
635  int place_nums_size,
636  int *place_nums
637);
638
639typedef int (*ompt_get_proc_id_t) (void);
640
641typedef int (*ompt_get_state_t) (
642  ompt_wait_id_t *wait_id
643);
644
645typedef int (*ompt_get_parallel_info_t) (
646  int ancestor_level,
647  ompt_data_t **parallel_data,
648  int *team_size
649);
650
651typedef int (*ompt_get_task_info_t) (
652  int ancestor_level,
653  int *flags,
654  ompt_data_t **task_data,
655  ompt_frame_t **task_frame,
656  ompt_data_t **parallel_data,
657  int *thread_num
658);
659
660typedef int (*ompt_get_task_memory_t)(
661  void **addr,
662  size_t *size,
663  int block
664);
665
666typedef int (*ompt_get_target_info_t) (
667  uint64_t *device_num,
668  ompt_id_t *target_id,
669  ompt_id_t *host_op_id
670);
671
672typedef int (*ompt_get_num_devices_t) (void);
673
674typedef void (*ompt_finalize_tool_t) (void);
675
676typedef int (*ompt_get_device_num_procs_t) (
677  ompt_device_t *device
678);
679
680typedef ompt_device_time_t (*ompt_get_device_time_t) (
681  ompt_device_t *device
682);
683
684typedef double (*ompt_translate_time_t) (
685  ompt_device_t *device,
686  ompt_device_time_t time
687);
688
689typedef ompt_set_result_t (*ompt_set_trace_ompt_t) (
690  ompt_device_t *device,
691  unsigned int enable,
692  unsigned int etype
693);
694
695typedef ompt_set_result_t (*ompt_set_trace_native_t) (
696  ompt_device_t *device,
697  int enable,
698  int flags
699);
700
701typedef int (*ompt_start_trace_t) (
702  ompt_device_t *device,
703  ompt_callback_buffer_request_t request,
704  ompt_callback_buffer_complete_t complete
705);
706
707typedef int (*ompt_pause_trace_t) (
708  ompt_device_t *device,
709  int begin_pause
710);
711
712typedef int (*ompt_flush_trace_t) (
713  ompt_device_t *device
714);
715
716typedef int (*ompt_stop_trace_t) (
717  ompt_device_t *device
718);
719
720typedef int (*ompt_advance_buffer_cursor_t) (
721  ompt_device_t *device,
722  ompt_buffer_t *buffer,
723  size_t size,
724  ompt_buffer_cursor_t current,
725  ompt_buffer_cursor_t *next
726);
727
728typedef ompt_record_t (*ompt_get_record_type_t) (
729  ompt_buffer_t *buffer,
730  ompt_buffer_cursor_t current
731);
732
733typedef void *(*ompt_get_record_native_t) (
734  ompt_buffer_t *buffer,
735  ompt_buffer_cursor_t current,
736  ompt_id_t *host_op_id
737);
738
739typedef ompt_record_abstract_t *
740(*ompt_get_record_abstract_t) (
741  void *native_record
742);
743
744typedef void (*ompt_callback_thread_begin_t) (
745  ompt_thread_t thread_type,
746  ompt_data_t *thread_data
747);
748
749typedef struct ompt_record_thread_begin_t {
750  ompt_thread_t thread_type;
751} ompt_record_thread_begin_t;
752
753typedef void (*ompt_callback_thread_end_t) (
754  ompt_data_t *thread_data
755);
756
757typedef void (*ompt_callback_parallel_begin_t) (
758  ompt_data_t *encountering_task_data,
759  const ompt_frame_t *encountering_task_frame,
760  ompt_data_t *parallel_data,
761  unsigned int requested_parallelism,
762  int flags,
763  const void *codeptr_ra
764);
765
766typedef struct ompt_record_parallel_begin_t {
767  ompt_id_t encountering_task_id;
768  ompt_id_t parallel_id;
769  unsigned int requested_parallelism;
770  int flags;
771  const void *codeptr_ra;
772} ompt_record_parallel_begin_t;
773
774typedef void (*ompt_callback_parallel_end_t) (
775  ompt_data_t *parallel_data,
776  ompt_data_t *encountering_task_data,
777  int flags,
778  const void *codeptr_ra
779);
780
781typedef struct ompt_record_parallel_end_t {
782  ompt_id_t parallel_id;
783  ompt_id_t encountering_task_id;
784  int flags;
785  const void *codeptr_ra;
786} ompt_record_parallel_end_t;
787
788typedef void (*ompt_callback_work_t) (
789  ompt_work_t work_type,
790  ompt_scope_endpoint_t endpoint,
791  ompt_data_t *parallel_data,
792  ompt_data_t *task_data,
793  uint64_t count,
794  const void *codeptr_ra
795);
796
797typedef struct ompt_record_work_t {
798  ompt_work_t work_type;
799  ompt_scope_endpoint_t endpoint;
800  ompt_id_t parallel_id;
801  ompt_id_t task_id;
802  uint64_t count;
803  const void *codeptr_ra;
804} ompt_record_work_t;
805
806typedef void (*ompt_callback_dispatch_t) (
807  ompt_data_t *parallel_data,
808  ompt_data_t *task_data,
809  ompt_dispatch_t kind,
810  ompt_data_t instance
811);
812
813typedef struct ompt_record_dispatch_t {
814  ompt_id_t parallel_id;
815  ompt_id_t task_id;
816  ompt_dispatch_t kind;
817  ompt_data_t instance;
818} ompt_record_dispatch_t;
819
820typedef void (*ompt_callback_task_create_t) (
821  ompt_data_t *encountering_task_data,
822  const ompt_frame_t *encountering_task_frame,
823  ompt_data_t *new_task_data,
824  int flags,
825  int has_dependences,
826  const void *codeptr_ra
827);
828
829typedef struct ompt_record_task_create_t {
830  ompt_id_t encountering_task_id;
831  ompt_id_t new_task_id;
832  int flags;
833  int has_dependences;
834  const void *codeptr_ra;
835} ompt_record_task_create_t;
836
837typedef void (*ompt_callback_dependences_t) (
838  ompt_data_t *task_data,
839  const ompt_dependence_t *deps,
840  int ndeps
841);
842
843typedef struct ompt_record_dependences_t {
844  ompt_id_t task_id;
845  ompt_dependence_t dep;
846  int ndeps;
847} ompt_record_dependences_t;
848
849typedef void (*ompt_callback_task_dependence_t) (
850  ompt_data_t *src_task_data,
851  ompt_data_t *sink_task_data
852);
853
854typedef struct ompt_record_task_dependence_t {
855  ompt_id_t src_task_id;
856  ompt_id_t sink_task_id;
857} ompt_record_task_dependence_t;
858
859typedef void (*ompt_callback_task_schedule_t) (
860  ompt_data_t *prior_task_data,
861  ompt_task_status_t prior_task_status,
862  ompt_data_t *next_task_data
863);
864
865typedef struct ompt_record_task_schedule_t {
866  ompt_id_t prior_task_id;
867  ompt_task_status_t prior_task_status;
868  ompt_id_t next_task_id;
869} ompt_record_task_schedule_t;
870
871typedef void (*ompt_callback_implicit_task_t) (
872  ompt_scope_endpoint_t endpoint,
873  ompt_data_t *parallel_data,
874  ompt_data_t *task_data,
875  unsigned int actual_parallelism,
876  unsigned int index,
877  int flags
878);
879
880typedef struct ompt_record_implicit_task_t {
881  ompt_scope_endpoint_t endpoint;
882  ompt_id_t parallel_id;
883  ompt_id_t task_id;
884  unsigned int actual_parallelism;
885  unsigned int index;
886  int flags;
887} ompt_record_implicit_task_t;
888
889typedef void (*ompt_callback_masked_t) (
890  ompt_scope_endpoint_t endpoint,
891  ompt_data_t *parallel_data,
892  ompt_data_t *task_data,
893  const void *codeptr_ra
894);
895
896typedef ompt_callback_masked_t ompt_callback_master_t DEPRECATED_51;
897
898typedef struct ompt_record_masked_t {
899  ompt_scope_endpoint_t endpoint;
900  ompt_id_t parallel_id;
901  ompt_id_t task_id;
902  const void *codeptr_ra;
903} ompt_record_masked_t;
904
905typedef void (*ompt_callback_sync_region_t) (
906  ompt_sync_region_t kind,
907  ompt_scope_endpoint_t endpoint,
908  ompt_data_t *parallel_data,
909  ompt_data_t *task_data,
910  const void *codeptr_ra
911);
912
913typedef struct ompt_record_sync_region_t {
914  ompt_sync_region_t kind;
915  ompt_scope_endpoint_t endpoint;
916  ompt_id_t parallel_id;
917  ompt_id_t task_id;
918  const void *codeptr_ra;
919} ompt_record_sync_region_t;
920
921typedef void (*ompt_callback_mutex_acquire_t) (
922  ompt_mutex_t kind,
923  unsigned int hint,
924  unsigned int impl,
925  ompt_wait_id_t wait_id,
926  const void *codeptr_ra
927);
928
929typedef struct ompt_record_mutex_acquire_t {
930  ompt_mutex_t kind;
931  unsigned int hint;
932  unsigned int impl;
933  ompt_wait_id_t wait_id;
934  const void *codeptr_ra;
935} ompt_record_mutex_acquire_t;
936
937typedef void (*ompt_callback_mutex_t) (
938  ompt_mutex_t kind,
939  ompt_wait_id_t wait_id,
940  const void *codeptr_ra
941);
942
943typedef struct ompt_record_mutex_t {
944  ompt_mutex_t kind;
945  ompt_wait_id_t wait_id;
946  const void *codeptr_ra;
947} ompt_record_mutex_t;
948
949typedef void (*ompt_callback_nest_lock_t) (
950  ompt_scope_endpoint_t endpoint,
951  ompt_wait_id_t wait_id,
952  const void *codeptr_ra
953);
954
955typedef struct ompt_record_nest_lock_t {
956  ompt_scope_endpoint_t endpoint;
957  ompt_wait_id_t wait_id;
958  const void *codeptr_ra;
959} ompt_record_nest_lock_t;
960
961typedef void (*ompt_callback_flush_t) (
962  ompt_data_t *thread_data,
963  const void *codeptr_ra
964);
965
966typedef struct ompt_record_flush_t {
967  const void *codeptr_ra;
968} ompt_record_flush_t;
969
970typedef void (*ompt_callback_cancel_t) (
971  ompt_data_t *task_data,
972  int flags,
973  const void *codeptr_ra
974);
975
976typedef struct ompt_record_cancel_t {
977  ompt_id_t task_id;
978  int flags;
979  const void *codeptr_ra;
980} ompt_record_cancel_t;
981
982typedef void (*ompt_callback_device_initialize_t) (
983  int device_num,
984  const char *type,
985  ompt_device_t *device,
986  ompt_function_lookup_t lookup,
987  const char *documentation
988);
989
990typedef void (*ompt_callback_device_finalize_t) (
991  int device_num
992);
993
994typedef void (*ompt_callback_device_load_t) (
995  int device_num,
996  const char *filename,
997  int64_t offset_in_file,
998  void *vma_in_file,
999  size_t bytes,
1000  void *host_addr,
1001  void *device_addr,
1002  uint64_t module_id
1003);
1004
1005typedef void (*ompt_callback_device_unload_t) (
1006  int device_num,
1007  uint64_t module_id
1008);
1009
1010typedef void (*ompt_callback_target_data_op_emi_t) (
1011  ompt_scope_endpoint_t endpoint,
1012  ompt_data_t *target_task_data,
1013  ompt_data_t *target_data,
1014  ompt_id_t *host_op_id,
1015  ompt_target_data_op_t optype,
1016  void *src_addr,
1017  int src_device_num,
1018  void *dest_addr,
1019  int dest_device_num,
1020  size_t bytes,
1021  const void *codeptr_ra
1022);
1023
1024typedef void (*ompt_callback_target_data_op_t) (
1025  ompt_id_t target_id,
1026  ompt_id_t host_op_id,
1027  ompt_target_data_op_t optype,
1028  void *src_addr,
1029  int src_device_num,
1030  void *dest_addr,
1031  int dest_device_num,
1032  size_t bytes,
1033  const void *codeptr_ra
1034);
1035
1036typedef struct ompt_record_target_data_op_t {
1037  ompt_id_t host_op_id;
1038  ompt_target_data_op_t optype;
1039  void *src_addr;
1040  int src_device_num;
1041  void *dest_addr;
1042  int dest_device_num;
1043  size_t bytes;
1044  ompt_device_time_t end_time;
1045  const void *codeptr_ra;
1046} ompt_record_target_data_op_t;
1047
1048typedef void (*ompt_callback_target_emi_t) (
1049  ompt_target_t kind,
1050  ompt_scope_endpoint_t endpoint,
1051  int device_num,
1052  ompt_data_t *task_data,
1053  ompt_data_t *target_task_data,
1054  ompt_data_t *target_data,
1055  const void *codeptr_ra
1056);
1057
1058typedef void (*ompt_callback_target_t) (
1059  ompt_target_t kind,
1060  ompt_scope_endpoint_t endpoint,
1061  int device_num,
1062  ompt_data_t *task_data,
1063  ompt_id_t target_id,
1064  const void *codeptr_ra
1065);
1066
1067typedef struct ompt_record_target_t {
1068  ompt_target_t kind;
1069  ompt_scope_endpoint_t endpoint;
1070  int device_num;
1071  ompt_id_t task_id;
1072  ompt_id_t target_id;
1073  const void *codeptr_ra;
1074} ompt_record_target_t;
1075
1076typedef void (*ompt_callback_target_map_emi_t) (
1077  ompt_data_t *target_data,
1078  unsigned int nitems,
1079  void **host_addr,
1080  void **device_addr,
1081  size_t *bytes,
1082  unsigned int *mapping_flags,
1083  const void *codeptr_ra
1084);
1085
1086typedef void (*ompt_callback_target_map_t) (
1087  ompt_id_t target_id,
1088  unsigned int nitems,
1089  void **host_addr,
1090  void **device_addr,
1091  size_t *bytes,
1092  unsigned int *mapping_flags,
1093  const void *codeptr_ra
1094);
1095
1096typedef struct ompt_record_target_map_t {
1097  ompt_id_t target_id;
1098  unsigned int nitems;
1099  void **host_addr;
1100  void **device_addr;
1101  size_t *bytes;
1102  unsigned int *mapping_flags;
1103  const void *codeptr_ra;
1104} ompt_record_target_map_t;
1105
1106typedef void (*ompt_callback_target_submit_emi_t) (
1107  ompt_scope_endpoint_t endpoint,
1108  ompt_data_t *target_data,
1109  ompt_id_t *host_op_id,
1110  unsigned int requested_num_teams
1111);
1112
1113typedef void (*ompt_callback_target_submit_t) (
1114  ompt_id_t target_id,
1115  ompt_id_t host_op_id,
1116  unsigned int requested_num_teams
1117);
1118
1119typedef struct ompt_record_target_kernel_t {
1120  ompt_id_t host_op_id;
1121  unsigned int requested_num_teams;
1122  unsigned int granted_num_teams;
1123  ompt_device_time_t end_time;
1124} ompt_record_target_kernel_t;
1125
1126typedef int (*ompt_callback_control_tool_t) (
1127  uint64_t command,
1128  uint64_t modifier,
1129  void *arg,
1130  const void *codeptr_ra
1131);
1132
1133typedef struct ompt_record_control_tool_t {
1134  uint64_t command;
1135  uint64_t modifier;
1136  const void *codeptr_ra;
1137} ompt_record_control_tool_t;
1138
1139typedef void (*ompt_callback_error_t) (
1140  ompt_severity_t severity,
1141  const char *message, size_t length,
1142  const void *codeptr_ra
1143);
1144
1145typedef struct ompt_record_error_t {
1146  ompt_severity_t severity;
1147  const char *message;
1148  size_t length;
1149  const void *codeptr_ra;
1150} ompt_record_error_t;
1151
1152typedef struct ompd_address_t {
1153  ompd_seg_t segment;
1154  ompd_addr_t address;
1155} ompd_address_t;
1156
1157typedef struct ompd_frame_info_t {
1158  ompd_address_t frame_address;
1159  ompd_word_t frame_flag;
1160} ompd_frame_info_t;
1161
1162typedef struct _ompd_aspace_handle ompd_address_space_handle_t;
1163typedef struct _ompd_thread_handle ompd_thread_handle_t;
1164typedef struct _ompd_parallel_handle ompd_parallel_handle_t;
1165typedef struct _ompd_task_handle ompd_task_handle_t;
1166
1167typedef struct _ompd_aspace_cont ompd_address_space_context_t;
1168typedef struct _ompd_thread_cont ompd_thread_context_t;
1169
1170typedef struct ompd_device_type_sizes_t {
1171  uint8_t sizeof_char;
1172  uint8_t sizeof_short;
1173  uint8_t sizeof_int;
1174  uint8_t sizeof_long;
1175  uint8_t sizeof_long_long;
1176  uint8_t sizeof_pointer;
1177} ompd_device_type_sizes_t;
1178
1179void ompd_dll_locations_valid(void);
1180
1181typedef ompd_rc_t (*ompd_callback_memory_alloc_fn_t)(ompd_size_t nbytes,
1182                                                     void **ptr);
1183
1184typedef ompd_rc_t (*ompd_callback_memory_free_fn_t)(void *ptr);
1185
1186typedef ompd_rc_t (*ompd_callback_get_thread_context_for_thread_id_fn_t)(
1187    ompd_address_space_context_t *address_space_context, ompd_thread_id_t kind,
1188    ompd_size_t sizeof_thread_id, const void *thread_id,
1189    ompd_thread_context_t **thread_context);
1190
1191typedef ompd_rc_t (*ompd_callback_sizeof_fn_t)(
1192    ompd_address_space_context_t *address_space_context,
1193    ompd_device_type_sizes_t *sizes);
1194
1195typedef ompd_rc_t (*ompd_callback_symbol_addr_fn_t)(
1196    ompd_address_space_context_t *address_space_context,
1197    ompd_thread_context_t *thread_context, const char *symbol_name,
1198    ompd_address_t *symbol_addr, const char *file_name);
1199
1200typedef ompd_rc_t (*ompd_callback_memory_read_fn_t)(
1201    ompd_address_space_context_t *address_space_context,
1202    ompd_thread_context_t *thread_context, const ompd_address_t *addr,
1203    ompd_size_t nbytes, void *buffer);
1204
1205typedef ompd_rc_t (*ompd_callback_memory_write_fn_t)(
1206    ompd_address_space_context_t *address_space_context,
1207    ompd_thread_context_t *thread_context, const ompd_address_t *addr,
1208    ompd_size_t nbytes, const void *buffer);
1209
1210typedef ompd_rc_t (*ompd_callback_device_host_fn_t)(
1211    ompd_address_space_context_t *address_space_context, const void *input,
1212    ompd_size_t unit_size, ompd_size_t count, void *output);
1213
1214typedef ompd_rc_t (*ompd_callback_print_string_fn_t)(const char *string,
1215                                                     int category);
1216
1217typedef struct ompd_callbacks_t {
1218  ompd_callback_memory_alloc_fn_t alloc_memory;
1219  ompd_callback_memory_free_fn_t free_memory;
1220  ompd_callback_print_string_fn_t print_string;
1221  ompd_callback_sizeof_fn_t sizeof_type;
1222  ompd_callback_symbol_addr_fn_t symbol_addr_lookup;
1223  ompd_callback_memory_read_fn_t read_memory;
1224  ompd_callback_memory_write_fn_t write_memory;
1225  ompd_callback_memory_read_fn_t read_string;
1226  ompd_callback_device_host_fn_t device_to_host;
1227  ompd_callback_device_host_fn_t host_to_device;
1228  ompd_callback_get_thread_context_for_thread_id_fn_t
1229      get_thread_context_for_thread_id;
1230} ompd_callbacks_t;
1231
1232void ompd_bp_parallel_begin(void);
1233
1234void ompd_bp_parallel_end(void);
1235
1236void ompd_bp_task_begin(void);
1237
1238void ompd_bp_task_end(void);
1239
1240void ompd_bp_thread_begin(void);
1241
1242void ompd_bp_thread_end(void);
1243
1244void ompd_bp_device_begin(void);
1245
1246void ompd_bp_device_end(void);
1247
1248ompd_rc_t ompd_initialize(ompd_word_t api_version,
1249                          const ompd_callbacks_t *callbacks);
1250
1251ompd_rc_t ompd_get_api_version(ompd_word_t *version);
1252
1253ompd_rc_t ompd_get_version_string(const char **string);
1254
1255ompd_rc_t ompd_finalize(void);
1256
1257ompd_rc_t ompd_process_initialize(ompd_address_space_context_t *context,
1258                                  ompd_address_space_handle_t **handle);
1259
1260ompd_rc_t ompd_device_initialize(ompd_address_space_handle_t *process_handle,
1261                                 ompd_address_space_context_t *device_context,
1262                                 ompd_device_t kind, ompd_size_t sizeof_id,
1263                                 void *id,
1264                                 ompd_address_space_handle_t **device_handle);
1265
1266ompd_rc_t ompd_rel_address_space_handle(ompd_address_space_handle_t *handle);
1267
1268ompd_rc_t ompd_get_omp_version(ompd_address_space_handle_t *address_space,
1269                               ompd_word_t *omp_version);
1270
1271ompd_rc_t
1272ompd_get_omp_version_string(ompd_address_space_handle_t *address_space,
1273                            const char **string);
1274
1275ompd_rc_t ompd_get_thread_in_parallel(ompd_parallel_handle_t *parallel_handle,
1276                                      int thread_num,
1277                                      ompd_thread_handle_t **thread_handle);
1278
1279ompd_rc_t ompd_get_thread_handle(ompd_address_space_handle_t *handle,
1280                                 ompd_thread_id_t kind,
1281                                 ompd_size_t sizeof_thread_id,
1282                                 const void *thread_id,
1283                                 ompd_thread_handle_t **thread_handle);
1284
1285ompd_rc_t ompd_rel_thread_handle(ompd_thread_handle_t *thread_handle);
1286
1287ompd_rc_t ompd_thread_handle_compare(ompd_thread_handle_t *thread_handle_1,
1288                                     ompd_thread_handle_t *thread_handle_2,
1289                                     int *cmp_value);
1290
1291ompd_rc_t ompd_get_thread_id(ompd_thread_handle_t *thread_handle,
1292                             ompd_thread_id_t kind,
1293                             ompd_size_t sizeof_thread_id, void *thread_id);
1294
1295ompd_rc_t
1296ompd_get_curr_parallel_handle(ompd_thread_handle_t *thread_handle,
1297                              ompd_parallel_handle_t **parallel_handle);
1298
1299ompd_rc_t ompd_get_enclosing_parallel_handle(
1300    ompd_parallel_handle_t *parallel_handle,
1301    ompd_parallel_handle_t **enclosing_parallel_handle);
1302
1303ompd_rc_t
1304ompd_get_task_parallel_handle(ompd_task_handle_t *task_handle,
1305                              ompd_parallel_handle_t **task_parallel_handle);
1306
1307ompd_rc_t ompd_rel_parallel_handle(ompd_parallel_handle_t *parallel_handle);
1308
1309ompd_rc_t
1310ompd_parallel_handle_compare(ompd_parallel_handle_t *parallel_handle_1,
1311                             ompd_parallel_handle_t *parallel_handle_2,
1312                             int *cmp_value);
1313
1314ompd_rc_t ompd_get_curr_task_handle(ompd_thread_handle_t *thread_handle,
1315                                    ompd_task_handle_t **task_handle);
1316
1317ompd_rc_t
1318ompd_get_generating_task_handle(ompd_task_handle_t *task_handle,
1319                                ompd_task_handle_t **generating_task_handle);
1320
1321ompd_rc_t
1322ompd_get_scheduling_task_handle(ompd_task_handle_t *task_handle,
1323                                ompd_task_handle_t **scheduling_task_handle);
1324
1325ompd_rc_t ompd_get_task_in_parallel(ompd_parallel_handle_t *parallel_handle,
1326                                    int thread_num,
1327                                    ompd_task_handle_t **task_handle);
1328
1329ompd_rc_t ompd_rel_task_handle(ompd_task_handle_t *task_handle);
1330
1331ompd_rc_t ompd_task_handle_compare(ompd_task_handle_t *task_handle_1,
1332                                   ompd_task_handle_t *task_handle_2,
1333                                   int *cmp_value);
1334
1335ompd_rc_t ompd_get_task_function(ompd_task_handle_t *task_handle,
1336                                 ompd_address_t *entry_point);
1337
1338ompd_rc_t ompd_get_task_frame(ompd_task_handle_t *task_handle,
1339                              ompd_frame_info_t *exit_frame,
1340                              ompd_frame_info_t *enter_frame);
1341
1342ompd_rc_t
1343ompd_enumerate_states(ompd_address_space_handle_t *address_space_handle,
1344                      ompd_word_t current_state, ompd_word_t *next_state,
1345                      const char **next_state_name, ompd_word_t *more_enums);
1346
1347ompd_rc_t ompd_get_state(ompd_thread_handle_t *thread_handle,
1348                         ompd_word_t *state, ompd_wait_id_t *wait_id);
1349
1350ompd_rc_t
1351ompd_get_display_control_vars(ompd_address_space_handle_t *address_space_handle,
1352                              const char *const **control_vars);
1353
1354ompd_rc_t ompd_rel_display_control_vars(const char *const **control_vars);
1355
1356ompd_rc_t ompd_enumerate_icvs(ompd_address_space_handle_t *handle,
1357                              ompd_icv_id_t current, ompd_icv_id_t *next_id,
1358                              const char **next_icv_name,
1359                              ompd_scope_t *next_scope, int *more);
1360
1361ompd_rc_t ompd_get_icv_from_scope(void *handle, ompd_scope_t scope,
1362                                  ompd_icv_id_t icv_id, ompd_word_t *icv_value);
1363
1364ompd_rc_t ompd_get_icv_string_from_scope(void *handle, ompd_scope_t scope,
1365                                         ompd_icv_id_t icv_id,
1366                                         const char **icv_string);
1367
1368ompd_rc_t ompd_get_tool_data(void *handle, ompd_scope_t scope,
1369                             ompd_word_t *value, ompd_address_t *ptr);
1370
1371typedef struct ompt_record_ompt_t {
1372  ompt_callbacks_t type;
1373  ompt_device_time_t time;
1374  ompt_id_t thread_id;
1375  ompt_id_t target_id;
1376  union {
1377    ompt_record_thread_begin_t thread_begin;
1378    ompt_record_parallel_begin_t parallel_begin;
1379    ompt_record_parallel_end_t parallel_end;
1380    ompt_record_work_t work;
1381    ompt_record_dispatch_t dispatch;
1382    ompt_record_task_create_t task_create;
1383    ompt_record_dependences_t dependences;
1384    ompt_record_task_dependence_t task_dependence;
1385    ompt_record_task_schedule_t task_schedule;
1386    ompt_record_implicit_task_t implicit_task;
1387    ompt_record_masked_t masked;
1388    ompt_record_sync_region_t sync_region;
1389    ompt_record_mutex_acquire_t mutex_acquire;
1390    ompt_record_mutex_t mutex;
1391    ompt_record_nest_lock_t nest_lock;
1392    ompt_record_flush_t flush;
1393    ompt_record_cancel_t cancel;
1394    ompt_record_target_t target;
1395    ompt_record_target_data_op_t target_data_op;
1396    ompt_record_target_map_t target_map;
1397    ompt_record_target_kernel_t target_kernel;
1398    ompt_record_control_tool_t control_tool;
1399  } record;
1400} ompt_record_ompt_t;
1401
1402typedef ompt_record_ompt_t *(*ompt_get_record_ompt_t) (
1403  ompt_buffer_t *buffer,
1404  ompt_buffer_cursor_t current
1405);
1406
1407#define ompt_id_none 0
1408#define ompt_data_none {0}
1409#define ompt_time_none 0
1410#define ompt_hwid_none 0
1411#define ompt_addr_none ~0
1412#define ompt_mutex_impl_none 0
1413#define ompt_wait_id_none 0
1414
1415#define ompd_segment_none 0
1416
1417#endif /* __OMPT__ */
1418