aboutsummaryrefslogtreecommitdiffstats
path: root/gcc-4.8.1/boehm-gc/testsuite/boehm-gc.c/thread_leak_test.c
diff options
context:
space:
mode:
authorDan Albert <danalbert@google.com>2016-02-04 18:51:25 +0000
committerGerrit Code Review <noreply-gerritcodereview@google.com>2016-02-04 18:51:25 +0000
commitedbbe53c4ffa154a5f9ae3f89ba8105993d8800e (patch)
tree4cedb380a14027d9c4d1e531c2340c43cbd79175 /gcc-4.8.1/boehm-gc/testsuite/boehm-gc.c/thread_leak_test.c
parenta4ca82cac69c3147143d7b4b4d7cdeb5e02f20ef (diff)
parent3186be22b6598fbd467b126347d1c7f48ccb7f71 (diff)
downloadtoolchain_gcc-edbbe53c4ffa154a5f9ae3f89ba8105993d8800e.tar.gz
toolchain_gcc-edbbe53c4ffa154a5f9ae3f89ba8105993d8800e.tar.bz2
toolchain_gcc-edbbe53c4ffa154a5f9ae3f89ba8105993d8800e.zip
Merge "Check in a pristine copy of GCC 4.8.1."
Diffstat (limited to 'gcc-4.8.1/boehm-gc/testsuite/boehm-gc.c/thread_leak_test.c')
-rw-r--r--gcc-4.8.1/boehm-gc/testsuite/boehm-gc.c/thread_leak_test.c74
1 files changed, 74 insertions, 0 deletions
diff --git a/gcc-4.8.1/boehm-gc/testsuite/boehm-gc.c/thread_leak_test.c b/gcc-4.8.1/boehm-gc/testsuite/boehm-gc.c/thread_leak_test.c
new file mode 100644
index 000000000..890146512
--- /dev/null
+++ b/gcc-4.8.1/boehm-gc/testsuite/boehm-gc.c/thread_leak_test.c
@@ -0,0 +1,74 @@
+#ifndef GC_THREADS
+# define GC_THREADS
+#endif
+#include "leak_detector.h"
+#ifdef GC_PTHREADS
+# include <pthread.h>
+#else
+# include <windows.h>
+#endif
+#include <stdio.h>
+
+#ifdef GC_PTHREADS
+ void * test(void * arg)
+#else
+ DWORD WINAPI test(LPVOID arg)
+#endif
+{
+ int *p[10];
+ int i;
+ for (i = 0; i < 10; ++i) {
+ p[i] = malloc(sizeof(int)+i);
+ }
+ CHECK_LEAKS();
+ for (i = 1; i < 10; ++i) {
+ free(p[i]);
+ }
+#ifdef GC_PTHREADS
+ return arg;
+#else
+ return (DWORD)(GC_word)arg;
+#endif
+}
+
+#define NTHREADS 5
+
+int main(void) {
+ int i;
+#ifdef GC_PTHREADS
+ pthread_t t[NTHREADS];
+#else
+ HANDLE t[NTHREADS];
+ DWORD thread_id;
+#endif
+ int code;
+
+ GC_find_leak = 1; /* for new collect versions not compiled */
+ GC_INIT();
+ for (i = 0; i < NTHREADS; ++i) {
+#ifdef GC_PTHREADS
+ code = pthread_create(t + i, 0, test, 0);
+#else
+ t[i] = CreateThread(NULL, 0, test, 0, 0, &thread_id);
+ code = t[i] != NULL ? 0 : (int)GetLastError();
+#endif
+ if (code != 0) {
+ printf("Thread creation failed %d\n", code);
+ }
+ }
+ for (i = 0; i < NTHREADS; ++i) {
+#ifdef GC_PTHREADS
+ code = pthread_join(t[i], 0);
+#else
+ code = WaitForSingleObject(t[i], INFINITE) == WAIT_OBJECT_0 ? 0 :
+ (int)GetLastError();
+#endif
+ if (code != 0) {
+ printf("Thread join failed %d\n", code);
+ }
+ }
+ CHECK_LEAKS();
+ CHECK_LEAKS();
+ CHECK_LEAKS();
+ return 0;
+}