LLVM OpenMP 20.0.0git
kmp_itt.cpp
Go to the documentation of this file.
1#include "kmp_config.h"
2
3#if USE_ITT_BUILD
4/*
5 * kmp_itt.cpp -- ITT Notify interface.
6 */
7
8//===----------------------------------------------------------------------===//
9//
10// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
11// See https://llvm.org/LICENSE.txt for license information.
12// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
13//
14//===----------------------------------------------------------------------===//
15
16#include "kmp_itt.h"
17
18#if KMP_DEBUG
19#include "kmp_itt.inl"
20#endif
21
22#if USE_ITT_NOTIFY
23
24#include "ittnotify_config.h"
25__itt_global __kmp_ittapi_clean_global;
26extern __itt_global __kmp_itt__ittapi_global;
27
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;
34
35#include "kmp_i18n.h"
36#include "kmp_str.h"
37#include "kmp_version.h"
38
39KMP_BUILD_ASSERT(sizeof(kmp_itt_mark_t) == sizeof(__itt_mark_type));
40
41/* Previously used warnings:
42
43 KMP_WARNING( IttAllNotifDisabled );
44 KMP_WARNING( IttObjNotifDisabled );
45 KMP_WARNING( IttMarkNotifDisabled );
46 KMP_WARNING( IttUnloadLibFailed, libittnotify );
47*/
48
49kmp_int32 __kmp_itt_prepare_delay = 0;
50kmp_bootstrap_lock_t __kmp_itt_debug_lock =
51 KMP_BOOTSTRAP_LOCK_INITIALIZER(__kmp_itt_debug_lock);
52
53#endif // USE_ITT_NOTIFY
54
55void __kmp_itt_reset() {
56#if USE_ITT_NOTIFY
57 __kmp_itt__ittapi_global = __kmp_ittapi_clean_global;
58#endif
59}
60
61void __kmp_itt_initialize() {
62
63 // ITTNotify library is loaded and initialized at first call to any ittnotify
64 // function, so we do not need to explicitly load it any more. Just report OMP
65 // RTL version to ITTNotify.
66
67#if USE_ITT_NOTIFY
68 // Backup a clean global state
69 __kmp_ittapi_clean_global = __kmp_itt__ittapi_global;
70
71 // Report OpenMP RTL version.
73 __itt_mark_type version;
75 __kmp_str_buf_print(&buf, "OMP RTL Version %d.%d.%d", __kmp_version_major,
77 if (__itt_api_version_ptr != NULL) {
78 __kmp_str_buf_print(&buf, ":%s", __itt_api_version());
79 }
80 version = __itt_mark_create(buf.str);
81 __itt_mark(version, NULL);
83#endif
84
85} // __kmp_itt_initialize
86
87void __kmp_itt_destroy() {
88#if USE_ITT_NOTIFY
90#endif
91} // __kmp_itt_destroy
92
93extern "C" void __itt_error_handler(__itt_error_code err, va_list args) {
94
95 switch (err) {
96 case __itt_error_no_module: {
97 char const *library = va_arg(args, char const *);
98#if KMP_OS_WINDOWS
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,
104 __kmp_str_free(&err_code.str);
105 }
106#else
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,
112 __kmp_str_free(&err_code.str);
113 }
114#endif
115 } break;
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);
120 } break;
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);
125 } break;
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);
132 } break;
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,
140 __kmp_str_free(&err_code.str);
141 }
142 } break;
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,
150 __kmp_str_free(&err_code.str);
151 }
152 } break;
153 default: {
154 KMP_WARNING(IttUnknownError, err);
155 }
156 }
157} // __itt_error_handler
158
159#endif /* USE_ITT_BUILD */
char buf[BUFFER_SIZE]
void const char const char int ITT_FORMAT __itt_group_sync x void const char ITT_FORMAT __itt_group_sync s void ITT_FORMAT __itt_group_sync p void ITT_FORMAT p void ITT_FORMAT p no args __itt_suppress_mode_t unsigned int void size_t ITT_FORMAT d void ITT_FORMAT p void ITT_FORMAT p __itt_model_site __itt_model_site_instance ITT_FORMAT p __itt_model_task __itt_model_task_instance ITT_FORMAT p void ITT_FORMAT p void ITT_FORMAT p void size_t ITT_FORMAT d void ITT_FORMAT p const wchar_t ITT_FORMAT s const char ITT_FORMAT s const char ITT_FORMAT s const char ITT_FORMAT s no args void ITT_FORMAT p size_t ITT_FORMAT d no args const wchar_t const wchar_t ITT_FORMAT s __itt_heap_function void size_t int ITT_FORMAT d __itt_heap_function void ITT_FORMAT p __itt_heap_function void void size_t int ITT_FORMAT d no args no args unsigned int ITT_FORMAT u const __itt_domain __itt_id ITT_FORMAT lu const __itt_domain __itt_id __itt_id __itt_string_handle ITT_FORMAT p const __itt_domain __itt_id ITT_FORMAT p const __itt_domain __itt_id __itt_timestamp __itt_timestamp ITT_FORMAT lu const __itt_domain __itt_id __itt_id __itt_string_handle ITT_FORMAT p const __itt_domain ITT_FORMAT p const __itt_domain __itt_string_handle unsigned long long ITT_FORMAT lu const __itt_domain __itt_string_handle unsigned long long ITT_FORMAT lu const __itt_domain __itt_id __itt_string_handle __itt_metadata_type size_t void ITT_FORMAT p const __itt_domain __itt_id __itt_string_handle const wchar_t size_t ITT_FORMAT lu const __itt_domain __itt_id __itt_relation __itt_id ITT_FORMAT p const wchar_t int ITT_FORMAT __itt_group_mark d __itt_event ITT_FORMAT __itt_group_mark d void const wchar_t const wchar_t int ITT_FORMAT __itt_group_sync __itt_group_fsync x void const wchar_t int const wchar_t int int ITT_FORMAT __itt_group_sync __itt_group_fsync x void ITT_FORMAT __itt_group_sync __itt_group_fsync p void ITT_FORMAT __itt_group_sync __itt_group_fsync p void size_t ITT_FORMAT lu no args __itt_obj_prop_t __itt_obj_state_t ITT_FORMAT d const char ITT_FORMAT s const char ITT_FORMAT s __itt_frame ITT_FORMAT p __itt_counter ITT_FORMAT p __itt_counter unsigned long long ITT_FORMAT lu __itt_counter unsigned long long ITT_FORMAT lu __itt_counter __itt_clock_domain unsigned long long void ITT_FORMAT p __itt_mark_type
int __kmp_generate_warnings
Definition: kmp_global.cpp:120
#define KMP_BUILD_ASSERT(expr)
Definition: kmp_debug.h:26
kmp_msg_t __kmp_msg_null
Definition: kmp_i18n.cpp:36
static void __kmp_msg(kmp_msg_severity_t severity, kmp_msg_t message, va_list ap)
Definition: kmp_i18n.cpp:789
#define KMP_WARNING(...)
Definition: kmp_i18n.h:144
#define KMP_SYSERRMESG(mesg)
Definition: kmp_i18n.h:124
#define KMP_MSG(...)
Definition: kmp_i18n.h:121
@ kmp_ms_warning
Definition: kmp_i18n.h:130
#define KMP_SYSERRCODE(code)
Definition: kmp_i18n.h:123
#define KMP_ERR
Definition: kmp_i18n.h:125
#define KMP_BOOTSTRAP_LOCK_INITIALIZER(lock)
Definition: kmp_lock.h:523
@ kmp_warnings_off
Definition: kmp_os.h:1239
void __kmp_itt_fini_ittlib()
void __kmp_str_buf_free(kmp_str_buf_t *buffer)
Definition: kmp_str.cpp:123
#define args
int __kmp_str_buf_print(kmp_str_buf_t *buffer, char const *format,...)
Definition: kmp_str.cpp:221
void __kmp_str_free(char **str)
Definition: kmp_str.cpp:494
#define __kmp_str_buf_init(b)
Definition: kmp_str.h:40
int const __kmp_version_build
Definition: kmp_version.cpp:96
int const __kmp_version_minor
Definition: kmp_version.cpp:95
int const __kmp_version_major
Definition: kmp_version.cpp:94
int32_t kmp_int32
void func(int *num_exec)
char * str
Definition: kmp_i18n.h:105
static int err
Definition: teams-no-par.c:16