mirror of
https://github.com/jart/cosmopolitan.git
synced 2025-01-31 11:37:35 +00:00
159 lines
4.8 KiB
C++
159 lines
4.8 KiB
C++
#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.inc"
|
|
#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 */
|