diff options
Diffstat (limited to 'boehm-gc/tests/thread_leak_test.c')
-rw-r--r-- | boehm-gc/tests/thread_leak_test.c | 72 |
1 files changed, 60 insertions, 12 deletions
diff --git a/boehm-gc/tests/thread_leak_test.c b/boehm-gc/tests/thread_leak_test.c index 1174705e45e..845de00ecd9 100644 --- a/boehm-gc/tests/thread_leak_test.c +++ b/boehm-gc/tests/thread_leak_test.c @@ -1,13 +1,30 @@ -#define GC_LINUX_THREADS + +#ifdef HAVE_CONFIG_H +# include "config.h" +#endif + +#ifndef GC_THREADS +# define GC_THREADS +#endif + #include "leak_detector.h" -#include <pthread.h> + +#ifdef GC_PTHREADS +# include <pthread.h> +#else +# include <windows.h> +#endif + #include <stdio.h> -void * test(void * arg) { +#ifdef GC_PTHREADS + void * test(void * arg) +#else + DWORD WINAPI test(LPVOID arg) +#endif +{ int *p[10]; int i; - GC_find_leak = 1; /* for new collect versions not compiled */ - /* with -DFIND_LEAK. */ for (i = 0; i < 10; ++i) { p[i] = malloc(sizeof(int)+i); } @@ -15,26 +32,57 @@ void * test(void * arg) { for (i = 1; i < 10; ++i) { free(p[i]); } -} +# ifdef GC_PTHREADS + return arg; +# else + return (DWORD)(GC_word)arg; +# endif +} #define NTHREADS 5 -main() { +int main(void) { int i; - pthread_t t[NTHREADS]; +# ifdef GC_PTHREADS + pthread_t t[NTHREADS]; +# else + HANDLE t[NTHREADS]; + DWORD thread_id; +# endif int code; + GC_set_find_leak(1); /* for new collect versions not compiled */ + /* with -DFIND_LEAK. */ + GC_INIT(); + for (i = 0; i < NTHREADS; ++i) { - if ((code = pthread_create(t + i, 0, test, 0)) != 0) { - printf("Thread creation failed %d\n", code); +# 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) { + fprintf(stderr, "Thread creation failed %d\n", code); + exit(2); } } + for (i = 0; i < NTHREADS; ++i) { - if ((code = pthread_join(t[i], 0)) != 0) { - printf("Thread join failed %lu\n", code); +# 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) { + fprintf(stderr, "Thread join failed %d\n", code); + exit(2); } } + CHECK_LEAKS(); CHECK_LEAKS(); CHECK_LEAKS(); + return 0; } |