[PATCH] Task Team Synchronization Fix
Jonathan Peyton
jonathan.l.peyton at intel.com
Wed May 20 15:45:29 PDT 2015
Hi hfinkel,
The fix syncs up the new threads to have the same task_state and
task_team as the old threads. The master thread is skipped,
because it shouldn't at this point have the team's task_team value yet
-- it should still have parent_team's task_team. It gets pointed at
the new team's task_team later, after __kmp_allocate_team returns, and
the master has stored a memo of it's old task_state.
REPOSITORY
rL LLVM
http://reviews.llvm.org/D9897
Files:
runtime/src/kmp_runtime.c
Index: runtime/src/kmp_runtime.c
===================================================================
--- runtime/src/kmp_runtime.c
+++ runtime/src/kmp_runtime.c
@@ -5059,8 +5059,13 @@
int old_state = team->t.t_threads[0]->th.th_task_state;
for (f=0; f < team->t.t_nproc; ++f) {
__kmp_initialize_info( team->t.t_threads[ f ], team, f, __kmp_gtid_from_tid( f, team ) );
- team->t.t_threads[f]->th.th_task_state = old_state;
}
+ // Old threads (except for master) and new threads need task_state and task_team reinitialized.
+ // Master thread will make a memo of old task_state later, then it will update task_state and task_team
+ for( f = 1 ; f < new_nproc ; f++ ) {
+ team->t.t_threads[f]->th.th_task_state = old_state;
+ team->t.t_threads[f]->th.th_task_team = team->t.t_task_team[team->t.t_threads[f]->th.th_task_state];
+ }
}
#ifdef KMP_DEBUG
EMAIL PREFERENCES
http://reviews.llvm.org/settings/panel/emailpreferences/
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D9897.26188.patch
Type: text/x-patch
Size: 972 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20150520/506fa594/attachment.bin>
More information about the llvm-commits
mailing list