24#include "ittnotify_config.h"
25__itt_global __kmp_ittapi_clean_global;
26extern __itt_global __kmp_itt__ittapi_global;
28kmp_itthash_t __kmp_itt_barrier_domains = {{0}, 0};
29kmp_itthash_t __kmp_itt_region_domains = {{0}, 0};
30__itt_domain *metadata_domain = NULL;
31__itt_string_handle *string_handle_imbl = NULL;
32__itt_string_handle *string_handle_loop = NULL;
33__itt_string_handle *string_handle_sngl = NULL;
37#include "kmp_version.h"
39KMP_BUILD_ASSERT(
sizeof(kmp_itt_mark_t) ==
sizeof(__itt_mark_type));
49kmp_int32 __kmp_itt_prepare_delay = 0;
50kmp_bootstrap_lock_t __kmp_itt_debug_lock =
51 KMP_BOOTSTRAP_LOCK_INITIALIZER(__kmp_itt_debug_lock);
55void __kmp_itt_reset() {
57 __kmp_itt__ittapi_global = __kmp_ittapi_clean_global;
61void __kmp_itt_initialize() {
69 __kmp_ittapi_clean_global = __kmp_itt__ittapi_global;
73 __itt_mark_type version;
74 __kmp_str_buf_init(&buf);
75 __kmp_str_buf_print(&buf,
"OMP RTL Version %d.%d.%d", __kmp_version_major,
76 __kmp_version_minor, __kmp_version_build);
77 if (__itt_api_version_ptr != NULL) {
78 __kmp_str_buf_print(&buf,
":%s", __itt_api_version());
80 version = __itt_mark_create(buf.str);
81 __itt_mark(version, NULL);
82 __kmp_str_buf_free(&buf);
87void __kmp_itt_destroy() {
89 __kmp_itt_fini_ittlib();
93extern "C" void __itt_error_handler(__itt_error_code err, va_list args) {
96 case __itt_error_no_module: {
97 char const *library = va_arg(args,
char const *);
99 int sys_err = va_arg(args,
int);
100 kmp_msg_t err_code = KMP_SYSERRCODE(sys_err);
101 __kmp_msg(kmp_ms_warning, KMP_MSG(IttLoadLibFailed, library), err_code,
103 if (__kmp_generate_warnings == kmp_warnings_off) {
104 __kmp_str_free(&err_code.str);
107 char const *sys_err = va_arg(args,
char const *);
108 kmp_msg_t err_code = KMP_SYSERRMESG(sys_err);
109 __kmp_msg(kmp_ms_warning, KMP_MSG(IttLoadLibFailed, library), err_code,
111 if (__kmp_generate_warnings == kmp_warnings_off) {
112 __kmp_str_free(&err_code.str);
116 case __itt_error_no_symbol: {
117 char const *library = va_arg(args,
char const *);
118 char const *symbol = va_arg(args,
char const *);
119 KMP_WARNING(IttLookupFailed, symbol, library);
121 case __itt_error_unknown_group: {
122 char const *var = va_arg(args,
char const *);
123 char const *group = va_arg(args,
char const *);
124 KMP_WARNING(IttUnknownGroup, var, group);
126 case __itt_error_env_too_long: {
127 char const *var = va_arg(args,
char const *);
128 size_t act_len = va_arg(args,
size_t);
129 size_t max_len = va_arg(args,
size_t);
130 KMP_WARNING(IttEnvVarTooLong, var, (
unsigned long)act_len,
131 (
unsigned long)max_len);
133 case __itt_error_cant_read_env: {
134 char const *var = va_arg(args,
char const *);
135 int sys_err = va_arg(args,
int);
136 kmp_msg_t err_code = KMP_ERR(sys_err);
137 __kmp_msg(kmp_ms_warning, KMP_MSG(CantGetEnvVar, var), err_code,
139 if (__kmp_generate_warnings == kmp_warnings_off) {
140 __kmp_str_free(&err_code.str);
143 case __itt_error_system: {
144 char const *func = va_arg(args,
char const *);
145 int sys_err = va_arg(args,
int);
146 kmp_msg_t err_code = KMP_SYSERRCODE(sys_err);
147 __kmp_msg(kmp_ms_warning, KMP_MSG(IttFunctionError, func), err_code,
149 if (__kmp_generate_warnings == kmp_warnings_off) {
150 __kmp_str_free(&err_code.str);
154 KMP_WARNING(IttUnknownError, err);