12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388 |
- /*
- * include/omp-tools.h.var
- */
- //===----------------------------------------------------------------------===//
- //
- // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
- // See https://llvm.org/LICENSE.txt for license information.
- // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
- //
- //===----------------------------------------------------------------------===//
- #ifndef __OMPT__
- #define __OMPT__
- /*****************************************************************************
- * system include files
- *****************************************************************************/
- #include <stdint.h>
- #include <stddef.h>
- #ifdef DEPRECATION_WARNINGS
- # ifdef __cplusplus
- # define DEPRECATED_51 [[deprecated("as of 5.1")]]
- # else
- # define DEPRECATED_51 __attribute__((deprecated("as of 5.1")))
- #endif
- #else
- #define DEPRECATED_51
- #endif
- /*****************************************************************************
- * iteration macros
- *****************************************************************************/
- #define FOREACH_OMPT_INQUIRY_FN(macro) \
- macro (ompt_enumerate_states) \
- macro (ompt_enumerate_mutex_impls) \
- \
- macro (ompt_set_callback) \
- macro (ompt_get_callback) \
- \
- macro (ompt_get_state) \
- \
- macro (ompt_get_parallel_info) \
- macro (ompt_get_task_info) \
- macro (ompt_get_task_memory) \
- macro (ompt_get_thread_data) \
- macro (ompt_get_unique_id) \
- macro (ompt_finalize_tool) \
- \
- macro(ompt_get_num_procs) \
- macro(ompt_get_num_places) \
- macro(ompt_get_place_proc_ids) \
- macro(ompt_get_place_num) \
- macro(ompt_get_partition_place_nums) \
- macro(ompt_get_proc_id) \
- \
- macro(ompt_get_target_info) \
- macro(ompt_get_num_devices)
- #define FOREACH_OMPT_STATE(macro) \
- \
- /* first available state */ \
- macro (ompt_state_undefined, 0x102) /* undefined thread state */ \
- \
- /* work states (0..15) */ \
- macro (ompt_state_work_serial, 0x000) /* working outside parallel */ \
- macro (ompt_state_work_parallel, 0x001) /* working within parallel */ \
- macro (ompt_state_work_reduction, 0x002) /* performing a reduction */ \
- \
- /* barrier wait states (16..31) */ \
- macro (ompt_state_wait_barrier, 0x010) /* waiting at a barrier */ \
- macro (ompt_state_wait_barrier_implicit_parallel, 0x011) \
- /* implicit barrier at the end of parallel region */\
- macro (ompt_state_wait_barrier_implicit_workshare, 0x012) \
- /* implicit barrier at the end of worksharing */ \
- macro (ompt_state_wait_barrier_implicit, 0x013) /* implicit barrier */ \
- macro (ompt_state_wait_barrier_explicit, 0x014) /* explicit barrier */ \
- \
- /* task wait states (32..63) */ \
- macro (ompt_state_wait_taskwait, 0x020) /* waiting at a taskwait */ \
- macro (ompt_state_wait_taskgroup, 0x021) /* waiting at a taskgroup */ \
- \
- /* mutex wait states (64..127) */ \
- macro (ompt_state_wait_mutex, 0x040) \
- macro (ompt_state_wait_lock, 0x041) /* waiting for lock */ \
- macro (ompt_state_wait_critical, 0x042) /* waiting for critical */ \
- macro (ompt_state_wait_atomic, 0x043) /* waiting for atomic */ \
- macro (ompt_state_wait_ordered, 0x044) /* waiting for ordered */ \
- \
- /* target wait states (128..255) */ \
- macro (ompt_state_wait_target, 0x080) /* waiting for target region */ \
- macro (ompt_state_wait_target_map, 0x081) /* waiting for target data mapping operation */ \
- macro (ompt_state_wait_target_update, 0x082) /* waiting for target update operation */ \
- \
- /* misc (256..511) */ \
- macro (ompt_state_idle, 0x100) /* waiting for work */ \
- macro (ompt_state_overhead, 0x101) /* overhead excluding wait states */ \
- \
- /* implementation-specific states (512..) */
- #define FOREACH_KMP_MUTEX_IMPL(macro) \
- macro (kmp_mutex_impl_none, 0) /* unknown implementation */ \
- macro (kmp_mutex_impl_spin, 1) /* based on spin */ \
- macro (kmp_mutex_impl_queuing, 2) /* based on some fair policy */ \
- macro (kmp_mutex_impl_speculative, 3) /* based on HW-supported speculation */
- #define FOREACH_OMPT_EVENT(macro) \
- \
- /*--- Mandatory Events ---*/ \
- macro (ompt_callback_thread_begin, ompt_callback_thread_begin_t, 1) /* thread begin */ \
- macro (ompt_callback_thread_end, ompt_callback_thread_end_t, 2) /* thread end */ \
- \
- macro (ompt_callback_parallel_begin, ompt_callback_parallel_begin_t, 3) /* parallel begin */ \
- macro (ompt_callback_parallel_end, ompt_callback_parallel_end_t, 4) /* parallel end */ \
- \
- macro (ompt_callback_task_create, ompt_callback_task_create_t, 5) /* task begin */ \
- macro (ompt_callback_task_schedule, ompt_callback_task_schedule_t, 6) /* task schedule */ \
- macro (ompt_callback_implicit_task, ompt_callback_implicit_task_t, 7) /* implicit task */ \
- \
- macro (ompt_callback_target, ompt_callback_target_t, 8) /* target */ \
- macro (ompt_callback_target_data_op, ompt_callback_target_data_op_t, 9) /* target data op */ \
- macro (ompt_callback_target_submit, ompt_callback_target_submit_t, 10) /* target submit */ \
- \
- macro (ompt_callback_control_tool, ompt_callback_control_tool_t, 11) /* control tool */ \
- \
- macro (ompt_callback_device_initialize, ompt_callback_device_initialize_t, 12) /* device initialize */ \
- macro (ompt_callback_device_finalize, ompt_callback_device_finalize_t, 13) /* device finalize */ \
- \
- macro (ompt_callback_device_load, ompt_callback_device_load_t, 14) /* device load */ \
- macro (ompt_callback_device_unload, ompt_callback_device_unload_t, 15) /* device unload */ \
- \
- /* Optional Events */ \
- macro (ompt_callback_sync_region_wait, ompt_callback_sync_region_t, 16) /* sync region wait begin or end */ \
- \
- macro (ompt_callback_mutex_released, ompt_callback_mutex_t, 17) /* mutex released */ \
- \
- macro (ompt_callback_dependences, ompt_callback_dependences_t, 18) /* report task dependences */ \
- macro (ompt_callback_task_dependence, ompt_callback_task_dependence_t, 19) /* report task dependence */ \
- \
- macro (ompt_callback_work, ompt_callback_work_t, 20) /* task at work begin or end */ \
- \
- macro (ompt_callback_masked, ompt_callback_masked_t, 21) /* task at masked begin or end */ \
- \
- macro (ompt_callback_target_map, ompt_callback_target_map_t, 22) /* target map */ \
- \
- macro (ompt_callback_sync_region, ompt_callback_sync_region_t, 23) /* sync region begin or end */ \
- \
- macro (ompt_callback_lock_init, ompt_callback_mutex_acquire_t, 24) /* lock init */ \
- macro (ompt_callback_lock_destroy, ompt_callback_mutex_t, 25) /* lock destroy */ \
- \
- macro (ompt_callback_mutex_acquire, ompt_callback_mutex_acquire_t, 26) /* mutex acquire */ \
- macro (ompt_callback_mutex_acquired, ompt_callback_mutex_t, 27) /* mutex acquired */ \
- \
- macro (ompt_callback_nest_lock, ompt_callback_nest_lock_t, 28) /* nest lock */ \
- \
- macro (ompt_callback_flush, ompt_callback_flush_t, 29) /* after executing flush */ \
- \
- macro (ompt_callback_cancel, ompt_callback_cancel_t, 30) /* cancel innermost binding region */ \
- \
- macro (ompt_callback_reduction, ompt_callback_sync_region_t, 31) /* reduction */ \
- \
- macro (ompt_callback_dispatch, ompt_callback_dispatch_t, 32) /* dispatch of work */ \
- macro (ompt_callback_target_emi, ompt_callback_target_emi_t, 33) /* target */ \
- macro (ompt_callback_target_data_op_emi,ompt_callback_target_data_op_emi_t,34) /* target data op */ \
- macro (ompt_callback_target_submit_emi, ompt_callback_target_submit_emi_t, 35) /* target submit */ \
- macro (ompt_callback_target_map_emi, ompt_callback_target_map_emi_t, 36) /* target map */ \
- macro (ompt_callback_error, ompt_callback_error_t, 37) /* error */
- /*****************************************************************************
- * implementation specific types
- *****************************************************************************/
- typedef enum kmp_mutex_impl_t {
- #define kmp_mutex_impl_macro(impl, code) impl = code,
- FOREACH_KMP_MUTEX_IMPL(kmp_mutex_impl_macro)
- #undef kmp_mutex_impl_macro
- } kmp_mutex_impl_t;
- /*****************************************************************************
- * definitions generated from spec
- *****************************************************************************/
- typedef enum ompt_callbacks_t {
- ompt_callback_thread_begin = 1,
- ompt_callback_thread_end = 2,
- ompt_callback_parallel_begin = 3,
- ompt_callback_parallel_end = 4,
- ompt_callback_task_create = 5,
- ompt_callback_task_schedule = 6,
- ompt_callback_implicit_task = 7,
- ompt_callback_target = 8,
- ompt_callback_target_data_op = 9,
- ompt_callback_target_submit = 10,
- ompt_callback_control_tool = 11,
- ompt_callback_device_initialize = 12,
- ompt_callback_device_finalize = 13,
- ompt_callback_device_load = 14,
- ompt_callback_device_unload = 15,
- ompt_callback_sync_region_wait = 16,
- ompt_callback_mutex_released = 17,
- ompt_callback_dependences = 18,
- ompt_callback_task_dependence = 19,
- ompt_callback_work = 20,
- ompt_callback_master DEPRECATED_51 = 21,
- ompt_callback_masked = 21,
- ompt_callback_target_map = 22,
- ompt_callback_sync_region = 23,
- ompt_callback_lock_init = 24,
- ompt_callback_lock_destroy = 25,
- ompt_callback_mutex_acquire = 26,
- ompt_callback_mutex_acquired = 27,
- ompt_callback_nest_lock = 28,
- ompt_callback_flush = 29,
- ompt_callback_cancel = 30,
- ompt_callback_reduction = 31,
- ompt_callback_dispatch = 32,
- ompt_callback_target_emi = 33,
- ompt_callback_target_data_op_emi = 34,
- ompt_callback_target_submit_emi = 35,
- ompt_callback_target_map_emi = 36,
- ompt_callback_error = 37
- } ompt_callbacks_t;
- typedef enum ompt_record_t {
- ompt_record_ompt = 1,
- ompt_record_native = 2,
- ompt_record_invalid = 3
- } ompt_record_t;
- typedef enum ompt_record_native_t {
- ompt_record_native_info = 1,
- ompt_record_native_event = 2
- } ompt_record_native_t;
- typedef enum ompt_set_result_t {
- ompt_set_error = 0,
- ompt_set_never = 1,
- ompt_set_impossible = 2,
- ompt_set_sometimes = 3,
- ompt_set_sometimes_paired = 4,
- ompt_set_always = 5
- } ompt_set_result_t;
- typedef uint64_t ompt_id_t;
- typedef uint64_t ompt_device_time_t;
- typedef uint64_t ompt_buffer_cursor_t;
- typedef enum ompt_thread_t {
- ompt_thread_initial = 1,
- ompt_thread_worker = 2,
- ompt_thread_other = 3,
- ompt_thread_unknown = 4
- } ompt_thread_t;
- typedef enum ompt_scope_endpoint_t {
- ompt_scope_begin = 1,
- ompt_scope_end = 2,
- ompt_scope_beginend = 3
- } ompt_scope_endpoint_t;
- typedef enum ompt_dispatch_t {
- ompt_dispatch_iteration = 1,
- ompt_dispatch_section = 2,
- ompt_dispatch_ws_loop_chunk = 3,
- ompt_dispatch_taskloop_chunk = 4,
- ompt_dispatch_distribute_chunk = 5
- } ompt_dispatch_t;
- typedef enum ompt_sync_region_t {
- ompt_sync_region_barrier DEPRECATED_51 = 1,
- ompt_sync_region_barrier_implicit DEPRECATED_51 = 2,
- ompt_sync_region_barrier_explicit = 3,
- ompt_sync_region_barrier_implementation = 4,
- ompt_sync_region_taskwait = 5,
- ompt_sync_region_taskgroup = 6,
- ompt_sync_region_reduction = 7,
- ompt_sync_region_barrier_implicit_workshare = 8,
- ompt_sync_region_barrier_implicit_parallel = 9,
- ompt_sync_region_barrier_teams = 10
- } ompt_sync_region_t;
- typedef enum ompt_target_data_op_t {
- ompt_target_data_alloc = 1,
- ompt_target_data_transfer_to_device = 2,
- ompt_target_data_transfer_from_device = 3,
- ompt_target_data_delete = 4,
- ompt_target_data_associate = 5,
- ompt_target_data_disassociate = 6,
- ompt_target_data_alloc_async = 17,
- ompt_target_data_transfer_to_device_async = 18,
- ompt_target_data_transfer_from_device_async = 19,
- ompt_target_data_delete_async = 20
- } ompt_target_data_op_t;
- typedef enum ompt_work_t {
- ompt_work_loop = 1,
- ompt_work_sections = 2,
- ompt_work_single_executor = 3,
- ompt_work_single_other = 4,
- ompt_work_workshare = 5,
- ompt_work_distribute = 6,
- ompt_work_taskloop = 7,
- ompt_work_scope = 8,
- ompt_work_loop_static = 10,
- ompt_work_loop_dynamic = 11,
- ompt_work_loop_guided = 12,
- ompt_work_loop_other = 13
- } ompt_work_t;
- typedef enum ompt_mutex_t {
- ompt_mutex_lock = 1,
- ompt_mutex_test_lock = 2,
- ompt_mutex_nest_lock = 3,
- ompt_mutex_test_nest_lock = 4,
- ompt_mutex_critical = 5,
- ompt_mutex_atomic = 6,
- ompt_mutex_ordered = 7
- } ompt_mutex_t;
- typedef enum ompt_native_mon_flag_t {
- ompt_native_data_motion_explicit = 0x01,
- ompt_native_data_motion_implicit = 0x02,
- ompt_native_kernel_invocation = 0x04,
- ompt_native_kernel_execution = 0x08,
- ompt_native_driver = 0x10,
- ompt_native_runtime = 0x20,
- ompt_native_overhead = 0x40,
- ompt_native_idleness = 0x80
- } ompt_native_mon_flag_t;
- typedef enum ompt_task_flag_t {
- ompt_task_initial = 0x00000001,
- ompt_task_implicit = 0x00000002,
- ompt_task_explicit = 0x00000004,
- ompt_task_target = 0x00000008,
- ompt_task_taskwait = 0x00000010,
- ompt_task_undeferred = 0x08000000,
- ompt_task_untied = 0x10000000,
- ompt_task_final = 0x20000000,
- ompt_task_mergeable = 0x40000000,
- ompt_task_merged = 0x80000000
- } ompt_task_flag_t;
- typedef enum ompt_task_status_t {
- ompt_task_complete = 1,
- ompt_task_yield = 2,
- ompt_task_cancel = 3,
- ompt_task_detach = 4,
- ompt_task_early_fulfill = 5,
- ompt_task_late_fulfill = 6,
- ompt_task_switch = 7,
- ompt_taskwait_complete = 8
- } ompt_task_status_t;
- typedef enum ompt_target_t {
- ompt_target = 1,
- ompt_target_enter_data = 2,
- ompt_target_exit_data = 3,
- ompt_target_update = 4,
- ompt_target_nowait = 9,
- ompt_target_enter_data_nowait = 10,
- ompt_target_exit_data_nowait = 11,
- ompt_target_update_nowait = 12
- } ompt_target_t;
- typedef enum ompt_parallel_flag_t {
- ompt_parallel_invoker_program = 0x00000001,
- ompt_parallel_invoker_runtime = 0x00000002,
- ompt_parallel_league = 0x40000000,
- ompt_parallel_team = 0x80000000
- } ompt_parallel_flag_t;
- typedef enum ompt_target_map_flag_t {
- ompt_target_map_flag_to = 0x01,
- ompt_target_map_flag_from = 0x02,
- ompt_target_map_flag_alloc = 0x04,
- ompt_target_map_flag_release = 0x08,
- ompt_target_map_flag_delete = 0x10,
- ompt_target_map_flag_implicit = 0x20
- } ompt_target_map_flag_t;
- typedef enum ompt_dependence_type_t {
- ompt_dependence_type_in = 1,
- ompt_dependence_type_out = 2,
- ompt_dependence_type_inout = 3,
- ompt_dependence_type_mutexinoutset = 4,
- ompt_dependence_type_source = 5,
- ompt_dependence_type_sink = 6,
- ompt_dependence_type_inoutset = 7
- } ompt_dependence_type_t;
- typedef enum ompt_severity_t {
- ompt_warning = 1,
- ompt_fatal = 2
- } ompt_severity_t;
- typedef enum ompt_cancel_flag_t {
- ompt_cancel_parallel = 0x01,
- ompt_cancel_sections = 0x02,
- ompt_cancel_loop = 0x04,
- ompt_cancel_taskgroup = 0x08,
- ompt_cancel_activated = 0x10,
- ompt_cancel_detected = 0x20,
- ompt_cancel_discarded_task = 0x40
- } ompt_cancel_flag_t;
- typedef uint64_t ompt_hwid_t;
- typedef uint64_t ompt_wait_id_t;
- typedef enum ompt_frame_flag_t {
- ompt_frame_runtime = 0x00,
- ompt_frame_application = 0x01,
- ompt_frame_cfa = 0x10,
- ompt_frame_framepointer = 0x20,
- ompt_frame_stackaddress = 0x30
- } ompt_frame_flag_t;
- typedef enum ompt_state_t {
- ompt_state_work_serial = 0x000,
- ompt_state_work_parallel = 0x001,
- ompt_state_work_reduction = 0x002,
- ompt_state_wait_barrier DEPRECATED_51 = 0x010,
- ompt_state_wait_barrier_implicit_parallel = 0x011,
- ompt_state_wait_barrier_implicit_workshare = 0x012,
- ompt_state_wait_barrier_implicit DEPRECATED_51 = 0x013,
- ompt_state_wait_barrier_explicit = 0x014,
- ompt_state_wait_barrier_implementation = 0x015,
- ompt_state_wait_barrier_teams = 0x016,
- ompt_state_wait_taskwait = 0x020,
- ompt_state_wait_taskgroup = 0x021,
- ompt_state_wait_mutex = 0x040,
- ompt_state_wait_lock = 0x041,
- ompt_state_wait_critical = 0x042,
- ompt_state_wait_atomic = 0x043,
- ompt_state_wait_ordered = 0x044,
- ompt_state_wait_target = 0x080,
- ompt_state_wait_target_map = 0x081,
- ompt_state_wait_target_update = 0x082,
- ompt_state_idle = 0x100,
- ompt_state_overhead = 0x101,
- ompt_state_undefined = 0x102
- } ompt_state_t;
- typedef uint64_t (*ompt_get_unique_id_t) (void);
- typedef uint64_t ompd_size_t;
- typedef uint64_t ompd_wait_id_t;
- typedef uint64_t ompd_addr_t;
- typedef int64_t ompd_word_t;
- typedef uint64_t ompd_seg_t;
- typedef uint64_t ompd_device_t;
- typedef uint64_t ompd_thread_id_t;
- typedef enum ompd_scope_t {
- ompd_scope_global = 1,
- ompd_scope_address_space = 2,
- ompd_scope_thread = 3,
- ompd_scope_parallel = 4,
- ompd_scope_implicit_task = 5,
- ompd_scope_task = 6
- } ompd_scope_t;
- typedef uint64_t ompd_icv_id_t;
- typedef enum ompd_rc_t {
- ompd_rc_ok = 0,
- ompd_rc_unavailable = 1,
- ompd_rc_stale_handle = 2,
- ompd_rc_bad_input = 3,
- ompd_rc_error = 4,
- ompd_rc_unsupported = 5,
- ompd_rc_needs_state_tracking = 6,
- ompd_rc_incompatible = 7,
- ompd_rc_device_read_error = 8,
- ompd_rc_device_write_error = 9,
- ompd_rc_nomem = 10,
- ompd_rc_incomplete = 11,
- ompd_rc_callback_error = 12
- } ompd_rc_t;
- typedef void (*ompt_interface_fn_t) (void);
- typedef ompt_interface_fn_t (*ompt_function_lookup_t) (
- const char *interface_function_name
- );
- typedef union ompt_data_t {
- uint64_t value;
- void *ptr;
- } ompt_data_t;
- typedef struct ompt_frame_t {
- ompt_data_t exit_frame;
- ompt_data_t enter_frame;
- int exit_frame_flags;
- int enter_frame_flags;
- } ompt_frame_t;
- typedef void (*ompt_callback_t) (void);
- typedef void ompt_device_t;
- typedef void ompt_buffer_t;
- typedef void (*ompt_callback_buffer_request_t) (
- int device_num,
- ompt_buffer_t **buffer,
- size_t *bytes
- );
- typedef void (*ompt_callback_buffer_complete_t) (
- int device_num,
- ompt_buffer_t *buffer,
- size_t bytes,
- ompt_buffer_cursor_t begin,
- int buffer_owned
- );
- typedef void (*ompt_finalize_t) (
- ompt_data_t *tool_data
- );
- typedef int (*ompt_initialize_t) (
- ompt_function_lookup_t lookup,
- int initial_device_num,
- ompt_data_t *tool_data
- );
- typedef struct ompt_start_tool_result_t {
- ompt_initialize_t initialize;
- ompt_finalize_t finalize;
- ompt_data_t tool_data;
- } ompt_start_tool_result_t;
- typedef struct ompt_record_abstract_t {
- ompt_record_native_t rclass;
- const char *type;
- ompt_device_time_t start_time;
- ompt_device_time_t end_time;
- ompt_hwid_t hwid;
- } ompt_record_abstract_t;
- typedef struct ompt_dependence_t {
- ompt_data_t variable;
- ompt_dependence_type_t dependence_type;
- } ompt_dependence_t;
- typedef struct ompt_dispatch_chunk_t {
- uint64_t start;
- uint64_t iterations;
- } ompt_dispatch_chunk_t;
- typedef int (*ompt_enumerate_states_t) (
- int current_state,
- int *next_state,
- const char **next_state_name
- );
- typedef int (*ompt_enumerate_mutex_impls_t) (
- int current_impl,
- int *next_impl,
- const char **next_impl_name
- );
- typedef ompt_set_result_t (*ompt_set_callback_t) (
- ompt_callbacks_t event,
- ompt_callback_t callback
- );
- typedef int (*ompt_get_callback_t) (
- ompt_callbacks_t event,
- ompt_callback_t *callback
- );
- typedef ompt_data_t *(*ompt_get_thread_data_t) (void);
- typedef int (*ompt_get_num_procs_t) (void);
- typedef int (*ompt_get_num_places_t) (void);
- typedef int (*ompt_get_place_proc_ids_t) (
- int place_num,
- int ids_size,
- int *ids
- );
- typedef int (*ompt_get_place_num_t) (void);
- typedef int (*ompt_get_partition_place_nums_t) (
- int place_nums_size,
- int *place_nums
- );
- typedef int (*ompt_get_proc_id_t) (void);
- typedef int (*ompt_get_state_t) (
- ompt_wait_id_t *wait_id
- );
- typedef int (*ompt_get_parallel_info_t) (
- int ancestor_level,
- ompt_data_t **parallel_data,
- int *team_size
- );
- typedef int (*ompt_get_task_info_t) (
- int ancestor_level,
- int *flags,
- ompt_data_t **task_data,
- ompt_frame_t **task_frame,
- ompt_data_t **parallel_data,
- int *thread_num
- );
- typedef int (*ompt_get_task_memory_t)(
- void **addr,
- size_t *size,
- int block
- );
- typedef int (*ompt_get_target_info_t) (
- uint64_t *device_num,
- ompt_id_t *target_id,
- ompt_id_t *host_op_id
- );
- typedef int (*ompt_get_num_devices_t) (void);
- typedef void (*ompt_finalize_tool_t) (void);
- typedef int (*ompt_get_device_num_procs_t) (
- ompt_device_t *device
- );
- typedef ompt_device_time_t (*ompt_get_device_time_t) (
- ompt_device_t *device
- );
- typedef double (*ompt_translate_time_t) (
- ompt_device_t *device,
- ompt_device_time_t time
- );
- typedef ompt_set_result_t (*ompt_set_trace_ompt_t) (
- ompt_device_t *device,
- unsigned int enable,
- unsigned int etype
- );
- typedef ompt_set_result_t (*ompt_set_trace_native_t) (
- ompt_device_t *device,
- int enable,
- int flags
- );
- typedef int (*ompt_start_trace_t) (
- ompt_device_t *device,
- ompt_callback_buffer_request_t request,
- ompt_callback_buffer_complete_t complete
- );
- typedef int (*ompt_pause_trace_t) (
- ompt_device_t *device,
- int begin_pause
- );
- typedef int (*ompt_flush_trace_t) (
- ompt_device_t *device
- );
- typedef int (*ompt_stop_trace_t) (
- ompt_device_t *device
- );
- typedef int (*ompt_advance_buffer_cursor_t) (
- ompt_device_t *device,
- ompt_buffer_t *buffer,
- size_t size,
- ompt_buffer_cursor_t current,
- ompt_buffer_cursor_t *next
- );
- typedef ompt_record_t (*ompt_get_record_type_t) (
- ompt_buffer_t *buffer,
- ompt_buffer_cursor_t current
- );
- typedef void *(*ompt_get_record_native_t) (
- ompt_buffer_t *buffer,
- ompt_buffer_cursor_t current,
- ompt_id_t *host_op_id
- );
- typedef ompt_record_abstract_t *
- (*ompt_get_record_abstract_t) (
- void *native_record
- );
- typedef void (*ompt_callback_thread_begin_t) (
- ompt_thread_t thread_type,
- ompt_data_t *thread_data
- );
- typedef struct ompt_record_thread_begin_t {
- ompt_thread_t thread_type;
- } ompt_record_thread_begin_t;
- typedef void (*ompt_callback_thread_end_t) (
- ompt_data_t *thread_data
- );
- typedef void (*ompt_callback_parallel_begin_t) (
- ompt_data_t *encountering_task_data,
- const ompt_frame_t *encountering_task_frame,
- ompt_data_t *parallel_data,
- unsigned int requested_parallelism,
- int flags,
- const void *codeptr_ra
- );
- typedef struct ompt_record_parallel_begin_t {
- ompt_id_t encountering_task_id;
- ompt_id_t parallel_id;
- unsigned int requested_parallelism;
- int flags;
- const void *codeptr_ra;
- } ompt_record_parallel_begin_t;
- typedef void (*ompt_callback_parallel_end_t) (
- ompt_data_t *parallel_data,
- ompt_data_t *encountering_task_data,
- int flags,
- const void *codeptr_ra
- );
- typedef struct ompt_record_parallel_end_t {
- ompt_id_t parallel_id;
- ompt_id_t encountering_task_id;
- int flags;
- const void *codeptr_ra;
- } ompt_record_parallel_end_t;
- typedef void (*ompt_callback_work_t) (
- ompt_work_t work_type,
- ompt_scope_endpoint_t endpoint,
- ompt_data_t *parallel_data,
- ompt_data_t *task_data,
- uint64_t count,
- const void *codeptr_ra
- );
- typedef struct ompt_record_work_t {
- ompt_work_t work_type;
- ompt_scope_endpoint_t endpoint;
- ompt_id_t parallel_id;
- ompt_id_t task_id;
- uint64_t count;
- const void *codeptr_ra;
- } ompt_record_work_t;
- typedef void (*ompt_callback_dispatch_t) (
- ompt_data_t *parallel_data,
- ompt_data_t *task_data,
- ompt_dispatch_t kind,
- ompt_data_t instance
- );
- typedef struct ompt_record_dispatch_t {
- ompt_id_t parallel_id;
- ompt_id_t task_id;
- ompt_dispatch_t kind;
- ompt_data_t instance;
- } ompt_record_dispatch_t;
- typedef void (*ompt_callback_task_create_t) (
- ompt_data_t *encountering_task_data,
- const ompt_frame_t *encountering_task_frame,
- ompt_data_t *new_task_data,
- int flags,
- int has_dependences,
- const void *codeptr_ra
- );
- typedef struct ompt_record_task_create_t {
- ompt_id_t encountering_task_id;
- ompt_id_t new_task_id;
- int flags;
- int has_dependences;
- const void *codeptr_ra;
- } ompt_record_task_create_t;
- typedef void (*ompt_callback_dependences_t) (
- ompt_data_t *task_data,
- const ompt_dependence_t *deps,
- int ndeps
- );
- typedef struct ompt_record_dependences_t {
- ompt_id_t task_id;
- ompt_dependence_t dep;
- int ndeps;
- } ompt_record_dependences_t;
- typedef void (*ompt_callback_task_dependence_t) (
- ompt_data_t *src_task_data,
- ompt_data_t *sink_task_data
- );
- typedef struct ompt_record_task_dependence_t {
- ompt_id_t src_task_id;
- ompt_id_t sink_task_id;
- } ompt_record_task_dependence_t;
- typedef void (*ompt_callback_task_schedule_t) (
- ompt_data_t *prior_task_data,
- ompt_task_status_t prior_task_status,
- ompt_data_t *next_task_data
- );
- typedef struct ompt_record_task_schedule_t {
- ompt_id_t prior_task_id;
- ompt_task_status_t prior_task_status;
- ompt_id_t next_task_id;
- } ompt_record_task_schedule_t;
- typedef void (*ompt_callback_implicit_task_t) (
- ompt_scope_endpoint_t endpoint,
- ompt_data_t *parallel_data,
- ompt_data_t *task_data,
- unsigned int actual_parallelism,
- unsigned int index,
- int flags
- );
- typedef struct ompt_record_implicit_task_t {
- ompt_scope_endpoint_t endpoint;
- ompt_id_t parallel_id;
- ompt_id_t task_id;
- unsigned int actual_parallelism;
- unsigned int index;
- int flags;
- } ompt_record_implicit_task_t;
- typedef void (*ompt_callback_masked_t) (
- ompt_scope_endpoint_t endpoint,
- ompt_data_t *parallel_data,
- ompt_data_t *task_data,
- const void *codeptr_ra
- );
- typedef ompt_callback_masked_t ompt_callback_master_t DEPRECATED_51;
- typedef struct ompt_record_masked_t {
- ompt_scope_endpoint_t endpoint;
- ompt_id_t parallel_id;
- ompt_id_t task_id;
- const void *codeptr_ra;
- } ompt_record_masked_t;
- typedef void (*ompt_callback_sync_region_t) (
- ompt_sync_region_t kind,
- ompt_scope_endpoint_t endpoint,
- ompt_data_t *parallel_data,
- ompt_data_t *task_data,
- const void *codeptr_ra
- );
- typedef struct ompt_record_sync_region_t {
- ompt_sync_region_t kind;
- ompt_scope_endpoint_t endpoint;
- ompt_id_t parallel_id;
- ompt_id_t task_id;
- const void *codeptr_ra;
- } ompt_record_sync_region_t;
- typedef void (*ompt_callback_mutex_acquire_t) (
- ompt_mutex_t kind,
- unsigned int hint,
- unsigned int impl,
- ompt_wait_id_t wait_id,
- const void *codeptr_ra
- );
- typedef struct ompt_record_mutex_acquire_t {
- ompt_mutex_t kind;
- unsigned int hint;
- unsigned int impl;
- ompt_wait_id_t wait_id;
- const void *codeptr_ra;
- } ompt_record_mutex_acquire_t;
- typedef void (*ompt_callback_mutex_t) (
- ompt_mutex_t kind,
- ompt_wait_id_t wait_id,
- const void *codeptr_ra
- );
- typedef struct ompt_record_mutex_t {
- ompt_mutex_t kind;
- ompt_wait_id_t wait_id;
- const void *codeptr_ra;
- } ompt_record_mutex_t;
- typedef void (*ompt_callback_nest_lock_t) (
- ompt_scope_endpoint_t endpoint,
- ompt_wait_id_t wait_id,
- const void *codeptr_ra
- );
- typedef struct ompt_record_nest_lock_t {
- ompt_scope_endpoint_t endpoint;
- ompt_wait_id_t wait_id;
- const void *codeptr_ra;
- } ompt_record_nest_lock_t;
- typedef void (*ompt_callback_flush_t) (
- ompt_data_t *thread_data,
- const void *codeptr_ra
- );
- typedef struct ompt_record_flush_t {
- const void *codeptr_ra;
- } ompt_record_flush_t;
- typedef void (*ompt_callback_cancel_t) (
- ompt_data_t *task_data,
- int flags,
- const void *codeptr_ra
- );
- typedef struct ompt_record_cancel_t {
- ompt_id_t task_id;
- int flags;
- const void *codeptr_ra;
- } ompt_record_cancel_t;
- typedef void (*ompt_callback_device_initialize_t) (
- int device_num,
- const char *type,
- ompt_device_t *device,
- ompt_function_lookup_t lookup,
- const char *documentation
- );
- typedef void (*ompt_callback_device_finalize_t) (
- int device_num
- );
- typedef void (*ompt_callback_device_load_t) (
- int device_num,
- const char *filename,
- int64_t offset_in_file,
- void *vma_in_file,
- size_t bytes,
- void *host_addr,
- void *device_addr,
- uint64_t module_id
- );
- typedef void (*ompt_callback_device_unload_t) (
- int device_num,
- uint64_t module_id
- );
- typedef void (*ompt_callback_target_data_op_emi_t) (
- ompt_scope_endpoint_t endpoint,
- ompt_data_t *target_task_data,
- ompt_data_t *target_data,
- ompt_id_t *host_op_id,
- ompt_target_data_op_t optype,
- void *src_addr,
- int src_device_num,
- void *dest_addr,
- int dest_device_num,
- size_t bytes,
- const void *codeptr_ra
- );
- typedef void (*ompt_callback_target_data_op_t) (
- ompt_id_t target_id,
- ompt_id_t host_op_id,
- ompt_target_data_op_t optype,
- void *src_addr,
- int src_device_num,
- void *dest_addr,
- int dest_device_num,
- size_t bytes,
- const void *codeptr_ra
- );
- typedef struct ompt_record_target_data_op_t {
- ompt_id_t host_op_id;
- ompt_target_data_op_t optype;
- void *src_addr;
- int src_device_num;
- void *dest_addr;
- int dest_device_num;
- size_t bytes;
- ompt_device_time_t end_time;
- const void *codeptr_ra;
- } ompt_record_target_data_op_t;
- typedef void (*ompt_callback_target_emi_t) (
- ompt_target_t kind,
- ompt_scope_endpoint_t endpoint,
- int device_num,
- ompt_data_t *task_data,
- ompt_data_t *target_task_data,
- ompt_data_t *target_data,
- const void *codeptr_ra
- );
- typedef void (*ompt_callback_target_t) (
- ompt_target_t kind,
- ompt_scope_endpoint_t endpoint,
- int device_num,
- ompt_data_t *task_data,
- ompt_id_t target_id,
- const void *codeptr_ra
- );
- typedef struct ompt_record_target_t {
- ompt_target_t kind;
- ompt_scope_endpoint_t endpoint;
- int device_num;
- ompt_id_t task_id;
- ompt_id_t target_id;
- const void *codeptr_ra;
- } ompt_record_target_t;
- typedef void (*ompt_callback_target_map_emi_t) (
- ompt_data_t *target_data,
- unsigned int nitems,
- void **host_addr,
- void **device_addr,
- size_t *bytes,
- unsigned int *mapping_flags,
- const void *codeptr_ra
- );
- typedef void (*ompt_callback_target_map_t) (
- ompt_id_t target_id,
- unsigned int nitems,
- void **host_addr,
- void **device_addr,
- size_t *bytes,
- unsigned int *mapping_flags,
- const void *codeptr_ra
- );
- typedef struct ompt_record_target_map_t {
- ompt_id_t target_id;
- unsigned int nitems;
- void **host_addr;
- void **device_addr;
- size_t *bytes;
- unsigned int *mapping_flags;
- const void *codeptr_ra;
- } ompt_record_target_map_t;
- typedef void (*ompt_callback_target_submit_emi_t) (
- ompt_scope_endpoint_t endpoint,
- ompt_data_t *target_data,
- ompt_id_t *host_op_id,
- unsigned int requested_num_teams
- );
- typedef void (*ompt_callback_target_submit_t) (
- ompt_id_t target_id,
- ompt_id_t host_op_id,
- unsigned int requested_num_teams
- );
- typedef struct ompt_record_target_kernel_t {
- ompt_id_t host_op_id;
- unsigned int requested_num_teams;
- unsigned int granted_num_teams;
- ompt_device_time_t end_time;
- } ompt_record_target_kernel_t;
- typedef int (*ompt_callback_control_tool_t) (
- uint64_t command,
- uint64_t modifier,
- void *arg,
- const void *codeptr_ra
- );
- typedef struct ompt_record_control_tool_t {
- uint64_t command;
- uint64_t modifier;
- const void *codeptr_ra;
- } ompt_record_control_tool_t;
- typedef void (*ompt_callback_error_t) (
- ompt_severity_t severity,
- const char *message, size_t length,
- const void *codeptr_ra
- );
- typedef struct ompt_record_error_t {
- ompt_severity_t severity;
- const char *message;
- size_t length;
- const void *codeptr_ra;
- } ompt_record_error_t;
- typedef struct ompd_address_t {
- ompd_seg_t segment;
- ompd_addr_t address;
- } ompd_address_t;
- typedef struct ompd_frame_info_t {
- ompd_address_t frame_address;
- ompd_word_t frame_flag;
- } ompd_frame_info_t;
- typedef struct _ompd_aspace_handle ompd_address_space_handle_t;
- typedef struct _ompd_thread_handle ompd_thread_handle_t;
- typedef struct _ompd_parallel_handle ompd_parallel_handle_t;
- typedef struct _ompd_task_handle ompd_task_handle_t;
- typedef struct _ompd_aspace_cont ompd_address_space_context_t;
- typedef struct _ompd_thread_cont ompd_thread_context_t;
- typedef struct ompd_device_type_sizes_t {
- uint8_t sizeof_char;
- uint8_t sizeof_short;
- uint8_t sizeof_int;
- uint8_t sizeof_long;
- uint8_t sizeof_long_long;
- uint8_t sizeof_pointer;
- } ompd_device_type_sizes_t;
- void ompd_dll_locations_valid(void);
- typedef ompd_rc_t (*ompd_callback_memory_alloc_fn_t)(ompd_size_t nbytes,
- void **ptr);
- typedef ompd_rc_t (*ompd_callback_memory_free_fn_t)(void *ptr);
- typedef ompd_rc_t (*ompd_callback_get_thread_context_for_thread_id_fn_t)(
- ompd_address_space_context_t *address_space_context, ompd_thread_id_t kind,
- ompd_size_t sizeof_thread_id, const void *thread_id,
- ompd_thread_context_t **thread_context);
- typedef ompd_rc_t (*ompd_callback_sizeof_fn_t)(
- ompd_address_space_context_t *address_space_context,
- ompd_device_type_sizes_t *sizes);
- typedef ompd_rc_t (*ompd_callback_symbol_addr_fn_t)(
- ompd_address_space_context_t *address_space_context,
- ompd_thread_context_t *thread_context, const char *symbol_name,
- ompd_address_t *symbol_addr, const char *file_name);
- typedef ompd_rc_t (*ompd_callback_memory_read_fn_t)(
- ompd_address_space_context_t *address_space_context,
- ompd_thread_context_t *thread_context, const ompd_address_t *addr,
- ompd_size_t nbytes, void *buffer);
- typedef ompd_rc_t (*ompd_callback_memory_write_fn_t)(
- ompd_address_space_context_t *address_space_context,
- ompd_thread_context_t *thread_context, const ompd_address_t *addr,
- ompd_size_t nbytes, const void *buffer);
- typedef ompd_rc_t (*ompd_callback_device_host_fn_t)(
- ompd_address_space_context_t *address_space_context, const void *input,
- ompd_size_t unit_size, ompd_size_t count, void *output);
- typedef ompd_rc_t (*ompd_callback_print_string_fn_t)(const char *string,
- int category);
- typedef struct ompd_callbacks_t {
- ompd_callback_memory_alloc_fn_t alloc_memory;
- ompd_callback_memory_free_fn_t free_memory;
- ompd_callback_print_string_fn_t print_string;
- ompd_callback_sizeof_fn_t sizeof_type;
- ompd_callback_symbol_addr_fn_t symbol_addr_lookup;
- ompd_callback_memory_read_fn_t read_memory;
- ompd_callback_memory_write_fn_t write_memory;
- ompd_callback_memory_read_fn_t read_string;
- ompd_callback_device_host_fn_t device_to_host;
- ompd_callback_device_host_fn_t host_to_device;
- ompd_callback_get_thread_context_for_thread_id_fn_t
- get_thread_context_for_thread_id;
- } ompd_callbacks_t;
- void ompd_bp_parallel_begin(void);
- void ompd_bp_parallel_end(void);
- void ompd_bp_task_begin(void);
- void ompd_bp_task_end(void);
- void ompd_bp_thread_begin(void);
- void ompd_bp_thread_end(void);
- void ompd_bp_device_begin(void);
- void ompd_bp_device_end(void);
- ompd_rc_t ompd_initialize(ompd_word_t api_version,
- const ompd_callbacks_t *callbacks);
- ompd_rc_t ompd_get_api_version(ompd_word_t *version);
- ompd_rc_t ompd_get_version_string(const char **string);
- ompd_rc_t ompd_finalize(void);
- ompd_rc_t ompd_process_initialize(ompd_address_space_context_t *context,
- ompd_address_space_handle_t **handle);
- ompd_rc_t ompd_device_initialize(ompd_address_space_handle_t *process_handle,
- ompd_address_space_context_t *device_context,
- ompd_device_t kind, ompd_size_t sizeof_id,
- void *id,
- ompd_address_space_handle_t **device_handle);
- ompd_rc_t ompd_rel_address_space_handle(ompd_address_space_handle_t *handle);
- ompd_rc_t ompd_get_omp_version(ompd_address_space_handle_t *address_space,
- ompd_word_t *omp_version);
- ompd_rc_t
- ompd_get_omp_version_string(ompd_address_space_handle_t *address_space,
- const char **string);
- ompd_rc_t ompd_get_thread_in_parallel(ompd_parallel_handle_t *parallel_handle,
- int thread_num,
- ompd_thread_handle_t **thread_handle);
- ompd_rc_t ompd_get_thread_handle(ompd_address_space_handle_t *handle,
- ompd_thread_id_t kind,
- ompd_size_t sizeof_thread_id,
- const void *thread_id,
- ompd_thread_handle_t **thread_handle);
- ompd_rc_t ompd_rel_thread_handle(ompd_thread_handle_t *thread_handle);
- ompd_rc_t ompd_thread_handle_compare(ompd_thread_handle_t *thread_handle_1,
- ompd_thread_handle_t *thread_handle_2,
- int *cmp_value);
- ompd_rc_t ompd_get_thread_id(ompd_thread_handle_t *thread_handle,
- ompd_thread_id_t kind,
- ompd_size_t sizeof_thread_id, void *thread_id);
- ompd_rc_t
- ompd_get_curr_parallel_handle(ompd_thread_handle_t *thread_handle,
- ompd_parallel_handle_t **parallel_handle);
- ompd_rc_t ompd_get_enclosing_parallel_handle(
- ompd_parallel_handle_t *parallel_handle,
- ompd_parallel_handle_t **enclosing_parallel_handle);
- ompd_rc_t
- ompd_get_task_parallel_handle(ompd_task_handle_t *task_handle,
- ompd_parallel_handle_t **task_parallel_handle);
- ompd_rc_t ompd_rel_parallel_handle(ompd_parallel_handle_t *parallel_handle);
- ompd_rc_t
- ompd_parallel_handle_compare(ompd_parallel_handle_t *parallel_handle_1,
- ompd_parallel_handle_t *parallel_handle_2,
- int *cmp_value);
- ompd_rc_t ompd_get_curr_task_handle(ompd_thread_handle_t *thread_handle,
- ompd_task_handle_t **task_handle);
- ompd_rc_t
- ompd_get_generating_task_handle(ompd_task_handle_t *task_handle,
- ompd_task_handle_t **generating_task_handle);
- ompd_rc_t
- ompd_get_scheduling_task_handle(ompd_task_handle_t *task_handle,
- ompd_task_handle_t **scheduling_task_handle);
- ompd_rc_t ompd_get_task_in_parallel(ompd_parallel_handle_t *parallel_handle,
- int thread_num,
- ompd_task_handle_t **task_handle);
- ompd_rc_t ompd_rel_task_handle(ompd_task_handle_t *task_handle);
- ompd_rc_t ompd_task_handle_compare(ompd_task_handle_t *task_handle_1,
- ompd_task_handle_t *task_handle_2,
- int *cmp_value);
- ompd_rc_t ompd_get_task_function(ompd_task_handle_t *task_handle,
- ompd_address_t *entry_point);
- ompd_rc_t ompd_get_task_frame(ompd_task_handle_t *task_handle,
- ompd_frame_info_t *exit_frame,
- ompd_frame_info_t *enter_frame);
- ompd_rc_t
- ompd_enumerate_states(ompd_address_space_handle_t *address_space_handle,
- ompd_word_t current_state, ompd_word_t *next_state,
- const char **next_state_name, ompd_word_t *more_enums);
- ompd_rc_t ompd_get_state(ompd_thread_handle_t *thread_handle,
- ompd_word_t *state, ompd_wait_id_t *wait_id);
- ompd_rc_t
- ompd_get_display_control_vars(ompd_address_space_handle_t *address_space_handle,
- const char *const **control_vars);
- ompd_rc_t ompd_rel_display_control_vars(const char *const **control_vars);
- ompd_rc_t ompd_enumerate_icvs(ompd_address_space_handle_t *handle,
- ompd_icv_id_t current, ompd_icv_id_t *next_id,
- const char **next_icv_name,
- ompd_scope_t *next_scope, int *more);
- ompd_rc_t ompd_get_icv_from_scope(void *handle, ompd_scope_t scope,
- ompd_icv_id_t icv_id, ompd_word_t *icv_value);
- ompd_rc_t ompd_get_icv_string_from_scope(void *handle, ompd_scope_t scope,
- ompd_icv_id_t icv_id,
- const char **icv_string);
- ompd_rc_t ompd_get_tool_data(void *handle, ompd_scope_t scope,
- ompd_word_t *value, ompd_address_t *ptr);
- typedef struct ompt_record_ompt_t {
- ompt_callbacks_t type;
- ompt_device_time_t time;
- ompt_id_t thread_id;
- ompt_id_t target_id;
- union {
- ompt_record_thread_begin_t thread_begin;
- ompt_record_parallel_begin_t parallel_begin;
- ompt_record_parallel_end_t parallel_end;
- ompt_record_work_t work;
- ompt_record_dispatch_t dispatch;
- ompt_record_task_create_t task_create;
- ompt_record_dependences_t dependences;
- ompt_record_task_dependence_t task_dependence;
- ompt_record_task_schedule_t task_schedule;
- ompt_record_implicit_task_t implicit_task;
- ompt_record_masked_t masked;
- ompt_record_sync_region_t sync_region;
- ompt_record_mutex_acquire_t mutex_acquire;
- ompt_record_mutex_t mutex;
- ompt_record_nest_lock_t nest_lock;
- ompt_record_flush_t flush;
- ompt_record_cancel_t cancel;
- ompt_record_target_t target;
- ompt_record_target_data_op_t target_data_op;
- ompt_record_target_map_t target_map;
- ompt_record_target_kernel_t target_kernel;
- ompt_record_control_tool_t control_tool;
- } record;
- } ompt_record_ompt_t;
- typedef ompt_record_ompt_t *(*ompt_get_record_ompt_t) (
- ompt_buffer_t *buffer,
- ompt_buffer_cursor_t current
- );
- #define ompt_id_none 0
- #define ompt_data_none {0}
- #define ompt_time_none 0
- #define ompt_hwid_none 0
- #define ompt_addr_none ~0
- #define ompt_mutex_impl_none 0
- #define ompt_wait_id_none 0
- #define ompd_segment_none 0
- #endif /* __OMPT__ */
|