|  | #include "kmp_config.h" | 
|  |  | 
|  | #if USE_ITT_BUILD | 
|  | /* | 
|  | * kmp_itt.cpp -- ITT Notify interface. | 
|  | */ | 
|  |  | 
|  | //===----------------------------------------------------------------------===// | 
|  | // | 
|  | // 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 | 
|  | // | 
|  | //===----------------------------------------------------------------------===// | 
|  |  | 
|  | #include "kmp_itt.h" | 
|  |  | 
|  | #if KMP_DEBUG | 
|  | #include "kmp_itt.inl" | 
|  | #endif | 
|  |  | 
|  | #if USE_ITT_NOTIFY | 
|  |  | 
|  | #include "ittnotify_config.h" | 
|  | __itt_global __kmp_ittapi_clean_global; | 
|  | extern __itt_global __kmp_itt__ittapi_global; | 
|  |  | 
|  | kmp_itthash_t __kmp_itt_barrier_domains = {{0}, 0}; | 
|  | kmp_itthash_t __kmp_itt_region_domains = {{0}, 0}; | 
|  | __itt_domain *metadata_domain = NULL; | 
|  | __itt_string_handle *string_handle_imbl = NULL; | 
|  | __itt_string_handle *string_handle_loop = NULL; | 
|  | __itt_string_handle *string_handle_sngl = NULL; | 
|  |  | 
|  | #include "kmp_i18n.h" | 
|  | #include "kmp_str.h" | 
|  | #include "kmp_version.h" | 
|  |  | 
|  | KMP_BUILD_ASSERT(sizeof(kmp_itt_mark_t) == sizeof(__itt_mark_type)); | 
|  |  | 
|  | /* Previously used warnings: | 
|  |  | 
|  | KMP_WARNING( IttAllNotifDisabled ); | 
|  | KMP_WARNING( IttObjNotifDisabled ); | 
|  | KMP_WARNING( IttMarkNotifDisabled ); | 
|  | KMP_WARNING( IttUnloadLibFailed, libittnotify ); | 
|  | */ | 
|  |  | 
|  | kmp_int32 __kmp_itt_prepare_delay = 0; | 
|  | kmp_bootstrap_lock_t __kmp_itt_debug_lock = | 
|  | KMP_BOOTSTRAP_LOCK_INITIALIZER(__kmp_itt_debug_lock); | 
|  |  | 
|  | #endif // USE_ITT_NOTIFY | 
|  |  | 
|  | void __kmp_itt_reset() { | 
|  | #if USE_ITT_NOTIFY | 
|  | __kmp_itt__ittapi_global = __kmp_ittapi_clean_global; | 
|  | #endif | 
|  | } | 
|  |  | 
|  | void __kmp_itt_initialize() { | 
|  |  | 
|  | // ITTNotify library is loaded and initialized at first call to any ittnotify | 
|  | // function, so we do not need to explicitly load it any more. Just report OMP | 
|  | // RTL version to ITTNotify. | 
|  |  | 
|  | #if USE_ITT_NOTIFY | 
|  | // Backup a clean global state | 
|  | __kmp_ittapi_clean_global = __kmp_itt__ittapi_global; | 
|  |  | 
|  | // Report OpenMP RTL version. | 
|  | kmp_str_buf_t buf; | 
|  | __itt_mark_type version; | 
|  | __kmp_str_buf_init(&buf); | 
|  | __kmp_str_buf_print(&buf, "OMP RTL Version %d.%d.%d", __kmp_version_major, | 
|  | __kmp_version_minor, __kmp_version_build); | 
|  | if (__itt_api_version_ptr != NULL) { | 
|  | __kmp_str_buf_print(&buf, ":%s", __itt_api_version()); | 
|  | } | 
|  | version = __itt_mark_create(buf.str); | 
|  | __itt_mark(version, NULL); | 
|  | __kmp_str_buf_free(&buf); | 
|  | #endif | 
|  |  | 
|  | } // __kmp_itt_initialize | 
|  |  | 
|  | void __kmp_itt_destroy() { | 
|  | #if USE_ITT_NOTIFY | 
|  | __kmp_itt_fini_ittlib(); | 
|  | #endif | 
|  | } // __kmp_itt_destroy | 
|  |  | 
|  | extern "C" void __itt_error_handler(__itt_error_code err, va_list args) { | 
|  |  | 
|  | switch (err) { | 
|  | case __itt_error_no_module: { | 
|  | char const *library = va_arg(args, char const *); | 
|  | #if KMP_OS_WINDOWS | 
|  | int sys_err = va_arg(args, int); | 
|  | kmp_msg_t err_code = KMP_SYSERRCODE(sys_err); | 
|  | __kmp_msg(kmp_ms_warning, KMP_MSG(IttLoadLibFailed, library), err_code, | 
|  | __kmp_msg_null); | 
|  | if (__kmp_generate_warnings == kmp_warnings_off) { | 
|  | __kmp_str_free(&err_code.str); | 
|  | } | 
|  | #else | 
|  | char const *sys_err = va_arg(args, char const *); | 
|  | kmp_msg_t err_code = KMP_SYSERRMESG(sys_err); | 
|  | __kmp_msg(kmp_ms_warning, KMP_MSG(IttLoadLibFailed, library), err_code, | 
|  | __kmp_msg_null); | 
|  | if (__kmp_generate_warnings == kmp_warnings_off) { | 
|  | __kmp_str_free(&err_code.str); | 
|  | } | 
|  | #endif | 
|  | } break; | 
|  | case __itt_error_no_symbol: { | 
|  | char const *library = va_arg(args, char const *); | 
|  | char const *symbol = va_arg(args, char const *); | 
|  | KMP_WARNING(IttLookupFailed, symbol, library); | 
|  | } break; | 
|  | case __itt_error_unknown_group: { | 
|  | char const *var = va_arg(args, char const *); | 
|  | char const *group = va_arg(args, char const *); | 
|  | KMP_WARNING(IttUnknownGroup, var, group); | 
|  | } break; | 
|  | case __itt_error_env_too_long: { | 
|  | char const *var = va_arg(args, char const *); | 
|  | size_t act_len = va_arg(args, size_t); | 
|  | size_t max_len = va_arg(args, size_t); | 
|  | KMP_WARNING(IttEnvVarTooLong, var, (unsigned long)act_len, | 
|  | (unsigned long)max_len); | 
|  | } break; | 
|  | case __itt_error_cant_read_env: { | 
|  | char const *var = va_arg(args, char const *); | 
|  | int sys_err = va_arg(args, int); | 
|  | kmp_msg_t err_code = KMP_ERR(sys_err); | 
|  | __kmp_msg(kmp_ms_warning, KMP_MSG(CantGetEnvVar, var), err_code, | 
|  | __kmp_msg_null); | 
|  | if (__kmp_generate_warnings == kmp_warnings_off) { | 
|  | __kmp_str_free(&err_code.str); | 
|  | } | 
|  | } break; | 
|  | case __itt_error_system: { | 
|  | char const *func = va_arg(args, char const *); | 
|  | int sys_err = va_arg(args, int); | 
|  | kmp_msg_t err_code = KMP_SYSERRCODE(sys_err); | 
|  | __kmp_msg(kmp_ms_warning, KMP_MSG(IttFunctionError, func), err_code, | 
|  | __kmp_msg_null); | 
|  | if (__kmp_generate_warnings == kmp_warnings_off) { | 
|  | __kmp_str_free(&err_code.str); | 
|  | } | 
|  | } break; | 
|  | default: { | 
|  | KMP_WARNING(IttUnknownError, err); | 
|  | } | 
|  | } | 
|  | } // __itt_error_handler | 
|  |  | 
|  | #endif /* USE_ITT_BUILD */ |