diff options
| author | Kuba Mracek <mracek@apple.com> | 2017-02-02 12:54:21 +0000 |
|---|---|---|
| committer | Kuba Mracek <mracek@apple.com> | 2017-02-02 12:54:21 +0000 |
| commit | bba1d405894ff41e283645386704e4eb04d3cf7c (patch) | |
| tree | 7cd07422523d42505ba647a766d7eb8645710010 /compiler-rt/lib/tsan/rtl/tsan_rtl_thread.cc | |
| parent | e396d8e2602e0b269d9c8145d0738a46ff89eb6d (diff) | |
| download | bcm5719-llvm-bba1d405894ff41e283645386704e4eb04d3cf7c.tar.gz bcm5719-llvm-bba1d405894ff41e283645386704e4eb04d3cf7c.zip | |
[tsan] Properly describe GCD worker threads in reports
When dealing with GCD worker threads, TSan currently prints weird things like "created by thread T-1" and "[failed to restore the stack]" in reports. This patch avoids that and instead prints "Thread T3 (...) is a GCD worker thread".
Differential Revision: https://reviews.llvm.org/D29103
llvm-svn: 293882
Diffstat (limited to 'compiler-rt/lib/tsan/rtl/tsan_rtl_thread.cc')
| -rw-r--r-- | compiler-rt/lib/tsan/rtl/tsan_rtl_thread.cc | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/compiler-rt/lib/tsan/rtl/tsan_rtl_thread.cc b/compiler-rt/lib/tsan/rtl/tsan_rtl_thread.cc index 5b17dc60bcb..7357d97a264 100644 --- a/compiler-rt/lib/tsan/rtl/tsan_rtl_thread.cc +++ b/compiler-rt/lib/tsan/rtl/tsan_rtl_thread.cc @@ -236,7 +236,7 @@ int ThreadCreate(ThreadState *thr, uptr pc, uptr uid, bool detached) { return tid; } -void ThreadStart(ThreadState *thr, int tid, uptr os_id) { +void ThreadStart(ThreadState *thr, int tid, uptr os_id, bool workerthread) { uptr stk_addr = 0; uptr stk_size = 0; uptr tls_addr = 0; @@ -266,7 +266,7 @@ void ThreadStart(ThreadState *thr, int tid, uptr os_id) { ThreadRegistry *tr = ctx->thread_registry; OnStartedArgs args = { thr, stk_addr, stk_size, tls_addr, tls_size }; - tr->StartThread(tid, os_id, &args); + tr->StartThread(tid, os_id, workerthread, &args); tr->Lock(); thr->tctx = (ThreadContext*)tr->GetThreadLocked(tid); |

