Path: blob/main/contrib/llvm-project/openmp/runtime/src/kmp_itt.cpp
35258 views
#include "kmp_config.h"12#if USE_ITT_BUILD3/*4* kmp_itt.cpp -- ITT Notify interface.5*/67//===----------------------------------------------------------------------===//8//9// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.10// See https://llvm.org/LICENSE.txt for license information.11// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception12//13//===----------------------------------------------------------------------===//1415#include "kmp_itt.h"1617#if KMP_DEBUG18#include "kmp_itt.inl"19#endif2021#if USE_ITT_NOTIFY2223#include "ittnotify_config.h"24__itt_global __kmp_ittapi_clean_global;25extern __itt_global __kmp_itt__ittapi_global;2627kmp_itthash_t __kmp_itt_barrier_domains = {{0}, 0};28kmp_itthash_t __kmp_itt_region_domains = {{0}, 0};29__itt_domain *metadata_domain = NULL;30__itt_string_handle *string_handle_imbl = NULL;31__itt_string_handle *string_handle_loop = NULL;32__itt_string_handle *string_handle_sngl = NULL;3334#include "kmp_i18n.h"35#include "kmp_str.h"36#include "kmp_version.h"3738KMP_BUILD_ASSERT(sizeof(kmp_itt_mark_t) == sizeof(__itt_mark_type));3940/* Previously used warnings:4142KMP_WARNING( IttAllNotifDisabled );43KMP_WARNING( IttObjNotifDisabled );44KMP_WARNING( IttMarkNotifDisabled );45KMP_WARNING( IttUnloadLibFailed, libittnotify );46*/4748kmp_int32 __kmp_itt_prepare_delay = 0;49kmp_bootstrap_lock_t __kmp_itt_debug_lock =50KMP_BOOTSTRAP_LOCK_INITIALIZER(__kmp_itt_debug_lock);5152#endif // USE_ITT_NOTIFY5354void __kmp_itt_reset() {55#if USE_ITT_NOTIFY56__kmp_itt__ittapi_global = __kmp_ittapi_clean_global;57#endif58}5960void __kmp_itt_initialize() {6162// ITTNotify library is loaded and initialized at first call to any ittnotify63// function, so we do not need to explicitly load it any more. Just report OMP64// RTL version to ITTNotify.6566#if USE_ITT_NOTIFY67// Backup a clean global state68__kmp_ittapi_clean_global = __kmp_itt__ittapi_global;6970// Report OpenMP RTL version.71kmp_str_buf_t buf;72__itt_mark_type version;73__kmp_str_buf_init(&buf);74__kmp_str_buf_print(&buf, "OMP RTL Version %d.%d.%d", __kmp_version_major,75__kmp_version_minor, __kmp_version_build);76if (__itt_api_version_ptr != NULL) {77__kmp_str_buf_print(&buf, ":%s", __itt_api_version());78}79version = __itt_mark_create(buf.str);80__itt_mark(version, NULL);81__kmp_str_buf_free(&buf);82#endif8384} // __kmp_itt_initialize8586void __kmp_itt_destroy() {87#if USE_ITT_NOTIFY88__kmp_itt_fini_ittlib();89#endif90} // __kmp_itt_destroy9192extern "C" void __itt_error_handler(__itt_error_code err, va_list args) {9394switch (err) {95case __itt_error_no_module: {96char const *library = va_arg(args, char const *);97#if KMP_OS_WINDOWS98int sys_err = va_arg(args, int);99kmp_msg_t err_code = KMP_SYSERRCODE(sys_err);100__kmp_msg(kmp_ms_warning, KMP_MSG(IttLoadLibFailed, library), err_code,101__kmp_msg_null);102if (__kmp_generate_warnings == kmp_warnings_off) {103__kmp_str_free(&err_code.str);104}105#else106char const *sys_err = va_arg(args, char const *);107kmp_msg_t err_code = KMP_SYSERRMESG(sys_err);108__kmp_msg(kmp_ms_warning, KMP_MSG(IttLoadLibFailed, library), err_code,109__kmp_msg_null);110if (__kmp_generate_warnings == kmp_warnings_off) {111__kmp_str_free(&err_code.str);112}113#endif114} break;115case __itt_error_no_symbol: {116char const *library = va_arg(args, char const *);117char const *symbol = va_arg(args, char const *);118KMP_WARNING(IttLookupFailed, symbol, library);119} break;120case __itt_error_unknown_group: {121char const *var = va_arg(args, char const *);122char const *group = va_arg(args, char const *);123KMP_WARNING(IttUnknownGroup, var, group);124} break;125case __itt_error_env_too_long: {126char const *var = va_arg(args, char const *);127size_t act_len = va_arg(args, size_t);128size_t max_len = va_arg(args, size_t);129KMP_WARNING(IttEnvVarTooLong, var, (unsigned long)act_len,130(unsigned long)max_len);131} break;132case __itt_error_cant_read_env: {133char const *var = va_arg(args, char const *);134int sys_err = va_arg(args, int);135kmp_msg_t err_code = KMP_ERR(sys_err);136__kmp_msg(kmp_ms_warning, KMP_MSG(CantGetEnvVar, var), err_code,137__kmp_msg_null);138if (__kmp_generate_warnings == kmp_warnings_off) {139__kmp_str_free(&err_code.str);140}141} break;142case __itt_error_system: {143char const *func = va_arg(args, char const *);144int sys_err = va_arg(args, int);145kmp_msg_t err_code = KMP_SYSERRCODE(sys_err);146__kmp_msg(kmp_ms_warning, KMP_MSG(IttFunctionError, func), err_code,147__kmp_msg_null);148if (__kmp_generate_warnings == kmp_warnings_off) {149__kmp_str_free(&err_code.str);150}151} break;152default: {153KMP_WARNING(IttUnknownError, err);154}155}156} // __itt_error_handler157158#endif /* USE_ITT_BUILD */159160161