[compiler-rt] 2a73b7b - [NFC][LSAN] Limit the number of concurrent threads is the test

Vitaly Buka via llvm-commits llvm-commits at lists.llvm.org
Tue May 11 12:33:04 PDT 2021


Author: Vitaly Buka
Date: 2021-05-11T12:32:53-07:00
New Revision: 2a73b7bd8cf7620fc0e478ac838b07ee6649dd8a

URL: https://github.com/llvm/llvm-project/commit/2a73b7bd8cf7620fc0e478ac838b07ee6649dd8a
DIFF: https://github.com/llvm/llvm-project/commit/2a73b7bd8cf7620fc0e478ac838b07ee6649dd8a.diff

LOG: [NFC][LSAN] Limit the number of concurrent threads is the test

Test still fails with D88184 reverted.

The test was flaky on https://bugs.chromium.org/p/chromium/issues/detail?id=1206745 and
https://lab.llvm.org/buildbot/#/builders/sanitizer-x86_64-linux

Reviewed By: morehouse

Differential Revision: https://reviews.llvm.org/D102218

Added: 
    

Modified: 
    compiler-rt/test/lsan/TestCases/many_threads_detach.cpp

Removed: 
    


################################################################################
diff  --git a/compiler-rt/test/lsan/TestCases/many_threads_detach.cpp b/compiler-rt/test/lsan/TestCases/many_threads_detach.cpp
index 6909a483aa4ce..f1949d2e28929 100644
--- a/compiler-rt/test/lsan/TestCases/many_threads_detach.cpp
+++ b/compiler-rt/test/lsan/TestCases/many_threads_detach.cpp
@@ -3,6 +3,8 @@
 // Use `-pthread` so that its driver will DTRT (ie., ignore it).
 // RUN: %clangxx_lsan %s -o %t -pthread && %run %t
 
+#include <assert.h>
+#include <dirent.h>
 #include <pthread.h>
 #include <stdlib.h>
 #include <unistd.h>
@@ -12,15 +14,33 @@
 // reused.
 static const size_t kTestThreads = 10000;
 
+// Limit the number of simultaneous threads to avoid reaching the limit.
+static const size_t kTestThreadsBatch = 100;
+
 void *null_func(void *args) {
   return NULL;
 }
 
+int count_threads() {
+  DIR *d = opendir("/proc/self/task");
+  assert(d);
+  int count = 0;
+  while (readdir(d))
+    ++count;
+  closedir(d);
+  assert(count);
+  return count;
+}
+
 int main(void) {
-  for (size_t i = 0; i < kTestThreads; i++) {
-    pthread_t thread;
-    if (pthread_create(&thread, NULL, null_func, NULL) == 0)
+  for (size_t i = 0; i < kTestThreads; i += kTestThreadsBatch) {
+    for (size_t j = 0; j < kTestThreadsBatch; ++j) {
+      pthread_t thread;
+      assert(pthread_create(&thread, NULL, null_func, NULL) == 0);
       pthread_detach(thread);
+    }
+    while (count_threads() > 10)
+      sched_yield();
   }
   return 0;
 }


        


More information about the llvm-commits mailing list