[compiler-rt] [compiler-rt][TSan] fix crash caused by intercpting pthread_detach on Android (PR #161596)
Fei Peng via llvm-commits
llvm-commits at lists.llvm.org
Wed Oct 1 15:30:02 PDT 2025
https://github.com/airpfei updated https://github.com/llvm/llvm-project/pull/161596
>From 528c47b597377681d7165aeebd5911c1df27be28 Mon Sep 17 00:00:00 2001
From: Fei Peng <pengfei.02 at bytedance.com>
Date: Wed, 1 Oct 2025 15:16:36 -0700
Subject: [PATCH] [compiler-rt][TSan] fix crash caused by intercpting
pthread_detach on Android
---
.../lib/tsan/rtl/tsan_interceptors_posix.cpp | 14 ++++++++++++++
1 file changed, 14 insertions(+)
diff --git a/compiler-rt/lib/tsan/rtl/tsan_interceptors_posix.cpp b/compiler-rt/lib/tsan/rtl/tsan_interceptors_posix.cpp
index b46a81031258c..6a2af75cbaec9 100644
--- a/compiler-rt/lib/tsan/rtl/tsan_interceptors_posix.cpp
+++ b/compiler-rt/lib/tsan/rtl/tsan_interceptors_posix.cpp
@@ -1130,6 +1130,20 @@ TSAN_INTERCEPTOR(int, pthread_create,
TSAN_INTERCEPTOR(int, pthread_join, void *th, void **ret) {
SCOPED_INTERCEPTOR_RAW(pthread_join, th, ret);
+#if SANITIZER_ANDROID
+ {
+ // In Bionic, pthread_detach calls pthread_join, so the thread has already
+ // been consumed by the pthread_detach interceptor.
+ Tid tid = ctx->thread_registry.FindThread(
+ [](ThreadContextBase* tctx, void* arg) {
+ return tctx->user_id == (uptr)arg;
+ },
+ th);
+ if (tid == kInvalidTid) {
+ return REAL(pthread_join)(th, ret);
+ }
+ }
+#endif
Tid tid = ThreadConsumeTid(thr, pc, (uptr)th);
ThreadIgnoreBegin(thr, pc);
int res = BLOCK_REAL(pthread_join)(th, ret);
More information about the llvm-commits
mailing list