[compiler-rt] a7757f6 - [hwasan] Stress test for thread creation.

Evgenii Stepanov via llvm-commits llvm-commits at lists.llvm.org
Tue May 11 13:11:01 PDT 2021


Author: Evgenii Stepanov
Date: 2021-05-11T13:10:53-07:00
New Revision: a7757f6c22e45e84e56da79af67fe29dd1c224f5

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

LOG: [hwasan] Stress test for thread creation.

This test has two modes - testing reused threads with multiple loops of
batch create/join, and testing new threads with a single loop of
create/join per fork.

The non-reuse variant catches the problem that was fixed in D101881 with
a high probability.

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

Added: 
    compiler-rt/test/hwasan/TestCases/Linux/create-thread-stress.cpp

Modified: 
    

Removed: 
    


################################################################################
diff  --git a/compiler-rt/test/hwasan/TestCases/Linux/create-thread-stress.cpp b/compiler-rt/test/hwasan/TestCases/Linux/create-thread-stress.cpp
new file mode 100644
index 0000000000000..ac905a2411707
--- /dev/null
+++ b/compiler-rt/test/hwasan/TestCases/Linux/create-thread-stress.cpp
@@ -0,0 +1,61 @@
+// Stress test for https://reviews.llvm.org/D101881
+// RUN: %clangxx_hwasan -DREUSE=0 %s -pthread -O2 -o %t && %run %t 2>&1
+// RUN: %clangxx_hwasan -DREUSE=1 %s -pthread -O2 -o %t_reuse && %run %t_reuse 2>&1
+
+#include <thread>
+#include <vector>
+
+#include <sys/types.h>
+#include <sys/wait.h>
+#include <unistd.h>
+
+#include <stdio.h>
+
+constexpr int kTopThreads = 20;
+constexpr int kChildThreads = 30;
+constexpr int kChildIterations = REUSE ? 8 : 1;
+
+constexpr int kProcessIterations = 20;
+
+void Thread() {
+  for (int i = 0; i < kChildIterations; ++i) {
+    std::vector<std::thread> threads;
+    for (int i = 0; i < kChildThreads; ++i)
+      threads.emplace_back([]() {});
+    for (auto &t : threads)
+      t.join();
+  }
+}
+
+void run() {
+  std::vector<std::thread> threads;
+  for (int i = 0; i < kTopThreads; ++i)
+    threads.emplace_back(Thread);
+  for (auto &t : threads)
+    t.join();
+}
+
+int main() {
+#if REUSE
+  // Test thread reuse with multiple iterations of thread create / join in a single process.
+  run();
+#else
+  // Test new, non-reused thread creation by running a single iteration of create / join in a freshly started process.
+  for (int i = 0; i < kProcessIterations; ++i) {
+    int pid = fork();
+    if (pid) {
+      int wstatus;
+      do {
+        waitpid(pid, &wstatus, 0);
+      } while (!WIFEXITED(wstatus) && !WIFSIGNALED(wstatus));
+      if (!WIFEXITED(wstatus) || WEXITSTATUS(wstatus)) {
+        fprintf(stderr, "failed at iteration %d / %d\n", i, kProcessIterations);
+        return 1;
+      }
+    } else {
+      run();
+      return 0;
+    }
+  }
+#endif
+}


        


More information about the llvm-commits mailing list