[llvm-commits] [compiler-rt] r157584 - /compiler-rt/trunk/lib/tsan/rtl/tsan_rtl_thread.cc
Dmitry Vyukov
dvyukov at google.com
Mon May 28 10:32:50 PDT 2012
Author: dvyukov
Date: Mon May 28 12:32:50 2012
New Revision: 157584
URL: http://llvm.org/viewvc/llvm-project?rev=157584&view=rev
Log:
tsan: fix race during pthread_join/detach
Modified:
compiler-rt/trunk/lib/tsan/rtl/tsan_rtl_thread.cc
Modified: compiler-rt/trunk/lib/tsan/rtl/tsan_rtl_thread.cc
URL: http://llvm.org/viewvc/llvm-project/compiler-rt/trunk/lib/tsan/rtl/tsan_rtl_thread.cc?rev=157584&r1=157583&r2=157584&view=diff
==============================================================================
--- compiler-rt/trunk/lib/tsan/rtl/tsan_rtl_thread.cc (original)
+++ compiler-rt/trunk/lib/tsan/rtl/tsan_rtl_thread.cc Mon May 28 12:32:50 2012
@@ -226,15 +226,20 @@
int ThreadTid(ThreadState *thr, uptr pc, uptr uid) {
CHECK_GT(thr->in_rtl, 0);
- DPrintf("#%d: ThreadTid uid=%lu\n", thr->tid, uid);
- Lock l(&CTX()->thread_mtx);
+ Context *ctx = CTX();
+ Lock l(&ctx->thread_mtx);
+ int res = -1;
for (unsigned tid = 0; tid < kMaxTid; tid++) {
- if (CTX()->threads[tid] != 0
- && CTX()->threads[tid]->user_id == uid
- && CTX()->threads[tid]->status != ThreadStatusInvalid)
- return tid;
+ ThreadContext *tctx = ctx->threads[tid];
+ if (tctx != 0 && tctx->user_id == uid
+ && tctx->status != ThreadStatusInvalid) {
+ tctx->user_id = 0;
+ res = tid;
+ break;
+ }
}
- return -1;
+ DPrintf("#%d: ThreadTid uid=%lu tid=%d\n", thr->tid, uid, res);
+ return res;
}
void ThreadJoin(ThreadState *thr, uptr pc, int tid) {
More information about the llvm-commits
mailing list