[PATCH] [Tsan] Fix the signal_recursive.cc test to pass on systems with high loads
Phabricator
reviews at reviews.llvm.org
Thu Dec 11 09:43:16 PST 2014
REPOSITORY
rL LLVM
http://reviews.llvm.org/D6504
Files:
compiler-rt/trunk/test/tsan/process_sleep.h
compiler-rt/trunk/test/tsan/signal_recursive.cc
Index: compiler-rt/trunk/test/tsan/signal_recursive.cc
===================================================================
--- compiler-rt/trunk/test/tsan/signal_recursive.cc
+++ compiler-rt/trunk/test/tsan/signal_recursive.cc
@@ -11,6 +11,8 @@
#include <stdlib.h>
#include <stdio.h>
+#include "process_sleep.h"
+
static const int kSigSuspend = SIGUSR1;
static const int kSigRestart = SIGUSR2;
static sigset_t g_suspend_handler_mask;
@@ -59,33 +61,30 @@
}
static void StopWorld(pthread_t thread) {
- int result = pthread_kill(thread, kSigSuspend);
- if (result != 0)
+ if (pthread_kill(thread, kSigSuspend) != 0)
fail("pthread_kill failed");
- while ((result = sem_wait(&g_thread_suspend_ack_sem)) != 0) {
- if (result != EINTR) {
+ while (sem_wait(&g_thread_suspend_ack_sem) != 0) {
+ if (errno != EINTR)
fail("sem_wait failed");
- }
}
}
static void StartWorld(pthread_t thread) {
- int result = pthread_kill(thread, kSigRestart);
- if (result != 0)
+ if (pthread_kill(thread, kSigRestart) != 0)
fail("pthread_kill failed");
- while ((result = sem_wait(&g_thread_suspend_ack_sem)) != 0) {
- if (result != EINTR) {
+ while (sem_wait(&g_thread_suspend_ack_sem) != 0) {
+ if (errno != EINTR)
fail("sem_wait failed");
- }
}
}
static void CollectGarbage(pthread_t thread) {
StopWorld(thread);
// Walk stacks
- StartWorld(thread);
+ process_sleep(1);
+ StartWorld(thread);
}
static void Init() {
@@ -118,9 +117,11 @@
int main(int argc, const char *argv[]) {
Init();
pthread_t busy_thread;
- pthread_create(&busy_thread, NULL, &BusyThread, NULL);
+ if (pthread_create(&busy_thread, NULL, &BusyThread, NULL) != 0)
+ fail("pthread_create failed");
CollectGarbage(busy_thread);
- pthread_join(busy_thread, 0);
+ if (pthread_join(busy_thread, 0) != 0)
+ fail("pthread_join failed");
fprintf(stderr, "DONE\n");
return 0;
}
Index: compiler-rt/trunk/test/tsan/process_sleep.h
===================================================================
--- compiler-rt/trunk/test/tsan/process_sleep.h
+++ compiler-rt/trunk/test/tsan/process_sleep.h
@@ -0,0 +1,7 @@
+#include <time.h>
+
+static void process_sleep(int sec) {
+ clock_t beg = clock();
+ while((clock() - beg) / CLOCKS_PER_SEC < sec)
+ usleep(100);
+}
EMAIL PREFERENCES
http://reviews.llvm.org/settings/panel/emailpreferences/
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D6504.17178.patch
Type: text/x-patch
Size: 2321 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20141211/0b636856/attachment.bin>
More information about the llvm-commits
mailing list