diff options
author | rpj <rpj> | 2005-04-06 02:29:15 +0000 |
---|---|---|
committer | rpj <rpj> | 2005-04-06 02:29:15 +0000 |
commit | 13bd1e4d017a1c306e465219df9e245a4201726e (patch) | |
tree | d6d788a55449bd7ea1c5ea05f5af9bc0bbf9b2c7 /tests/cleanup2.c | |
parent | f19dd198df0106b07245d80d150a3d569b6cdf4d (diff) |
''
Diffstat (limited to 'tests/cleanup2.c')
-rw-r--r-- | tests/cleanup2.c | 19 |
1 files changed, 15 insertions, 4 deletions
diff --git a/tests/cleanup2.c b/tests/cleanup2.c index 50672fd..4c63918 100644 --- a/tests/cleanup2.c +++ b/tests/cleanup2.c @@ -92,14 +92,21 @@ struct bag_t_ { static bag_t threadbag[NUMTHREADS + 1]; -static int pop_count = 0; +typedef struct { + int i; + CRITICAL_SECTION cs; +} sharedInt_t; + +static sharedInt_t pop_count = {0, {0}}; static void increment_pop_count(void * arg) { - int * c = (int *) arg; + sharedInt_t * sI = (sharedInt_t *) arg; - (*c)++; + EnterCriticalSection(&sI->cs); + sI->i++; + LeaveCriticalSection(&sI->cs); } void * @@ -134,6 +141,8 @@ main() int i; pthread_t t[NUMTHREADS + 1]; + InitializeCriticalSection(&pop_count.cs); + assert((t[0] = pthread_self()).p != NULL); for (i = 1; i <= NUMTHREADS; i++) @@ -187,7 +196,9 @@ main() assert(!failed); - assert(pop_count == NUMTHREADS); + assert(pop_count.i == NUMTHREADS); + + DeleteCriticalSection(&pop_count.cs); /* * Success. |