[Openmp-commits] [PATCH] D84024: [OpenMP] libomp: added itt notifications for teams construct on host.
Andrey Churbanov via Phabricator via Openmp-commits
openmp-commits at lists.llvm.org
Fri Jul 17 06:53:41 PDT 2020
AndreyChurbanov created this revision.
AndreyChurbanov added reviewers: hbae, tlwilmar.
AndreyChurbanov added a project: OpenMP.
Herald added subscribers: openmp-commits, aaron.ballman, sstefan1, guansong, yaxunl.
Herald added a reviewer: jdoerfert.
Added barrier/regions notification for parallels inside teams construct when
number of teams equal to 1, as VTune only shows outer level regions for simplicity.
Repository:
rG LLVM Github Monorepo
https://reviews.llvm.org/D84024
Files:
openmp/runtime/src/kmp_barrier.cpp
openmp/runtime/src/kmp_runtime.cpp
Index: openmp/runtime/src/kmp_runtime.cpp
===================================================================
--- openmp/runtime/src/kmp_runtime.cpp
+++ openmp/runtime/src/kmp_runtime.cpp
@@ -1625,6 +1625,22 @@
}
#endif
+#if USE_ITT_BUILD
+ if (((__itt_frame_submit_v3_ptr && __itt_get_timestamp_ptr) ||
+ KMP_ITT_DEBUG) &&
+ __kmp_forkjoin_frames_mode == 3 &&
+ parent_team->t.t_active_level == 1 // only report frames at level 1
+ && master_th->th.th_teams_size.nteams == 1) {
+ kmp_uint64 tmp_time = __itt_get_timestamp();
+ master_th->th.th_frame_time = tmp_time;
+ parent_team->t.t_region_time = tmp_time;
+ }
+ if (__itt_stack_caller_create_ptr) {
+ // create new stack stitching id before entering fork barrier
+ parent_team->t.t_stack_id = __kmp_itt_stack_caller_create();
+ }
+#endif /* USE_ITT_BUILD */
+
KF_TRACE(10, ("__kmp_fork_call: before internal fork: root=%p, team=%p, "
"master_th=%p, gtid=%d\n",
root, parent_team, master_th, gtid));
@@ -2367,14 +2383,13 @@
#if USE_ITT_BUILD
if (__itt_stack_caller_create_ptr) {
- __kmp_itt_stack_caller_destroy(
- (__itt_caller)team->t
- .t_stack_id); // destroy the stack stitching id after join barrier
+ // destroy the stack stitching id after join barrier
+ __kmp_itt_stack_caller_destroy((__itt_caller)team->t.t_stack_id);
}
-
// Mark end of "parallel" region for Intel(R) VTune(TM) analyzer.
if (team->t.t_active_level == 1 &&
- !master_th->th.th_teams_microtask) { /* not in teams construct */
+ (!master_th->th.th_teams_microtask || /* not in teams construct */
+ master_th->th.th_teams_size.nteams == 1)) {
master_th->th.th_ident = loc;
// only one notification scheme (either "submit" or "forking/joined", not
// both)
Index: openmp/runtime/src/kmp_barrier.cpp
===================================================================
--- openmp/runtime/src/kmp_barrier.cpp
+++ openmp/runtime/src/kmp_barrier.cpp
@@ -1453,7 +1453,8 @@
// Barrier - report frame end (only if active_level == 1)
if ((__itt_frame_submit_v3_ptr || KMP_ITT_DEBUG) &&
__kmp_forkjoin_frames_mode &&
- this_thr->th.th_teams_microtask == NULL &&
+ (this_thr->th.th_teams_microtask == NULL || // either not in teams
+ this_thr->th.th_teams_size.nteams == 1) && // or inside single team
team->t.t_active_level == 1) {
ident_t *loc = __kmp_threads[gtid]->th.th_ident;
kmp_uint64 cur_time = __itt_get_timestamp();
@@ -1839,7 +1840,9 @@
#if USE_ITT_BUILD && USE_ITT_NOTIFY
// Join barrier - report frame end
if ((__itt_frame_submit_v3_ptr || KMP_ITT_DEBUG) &&
- __kmp_forkjoin_frames_mode && this_thr->th.th_teams_microtask == NULL &&
+ __kmp_forkjoin_frames_mode &&
+ (this_thr->th.th_teams_microtask == NULL || // either not in teams
+ this_thr->th.th_teams_size.nteams == 1) && // or inside single team
team->t.t_active_level == 1) {
kmp_uint64 cur_time = __itt_get_timestamp();
ident_t *loc = team->t.t_ident;
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D84024.278757.patch
Type: text/x-patch
Size: 3211 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/openmp-commits/attachments/20200717/cc660c00/attachment.bin>
More information about the Openmp-commits
mailing list