blob: 14097ed12eabb75a9888e3d2edde38e5a857a787 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
|
/*
* File: condvar1.c
*
* Test Synopsis:
* - Test basic function of condition variable code.
*
* Test Method (Validation or Falsification):
* - Validation
*
* Requirements Tested:
* -
*
* Features Tested:
* -
*
* Cases Tested:
* -
*
* Description:
* -
*
* Environment:
* -
*
* Input:
* -
*
* Output:
* -
*
* Assumptions:
* -
*
* Pass Criteria:
* -
*
* Fail Criteria:
* -
*/
#include "test.h"
typedef struct cvthing_t_ cvthing_t;
struct cvthing_t_ {
pthread_cond_t notbusy;
pthread_mutex_t lock;
int busy;
int count;
};
static enum {
NUMTHREADS = 10
};
static pthread_key_t key;
static cvthing_t cvthing = {
PTHREAD_COND_INITIALIZER,
PTHREAD_MUTEX_INITIALIZER,
1,
0
};
void *
mythread(void * arg)
{
assert(pthread_mutex_lock(&cvthing.lock) == 0);
cvthing.count++;
while (cvthing.busy)
{
assert(pthread_cond_wait(&cvthing.notbusy, &cvthing.lock) == 0);
}
assert(cvthing.busy == 0);
cvthing.count--;
assert(pthread_mutex_unlock(&cvthing.lock) == 0);
return 0;
}
int
main()
{
pthread_t t[NUMTHREADS];
int result[NUMTHREADS];
assert((t[0] = pthread_self()) != NULL);
for (i = 1; i < NUMTHREADS; i++)
{
assert(pthread_create(&t[i], NULL, mythread, (void *) i) == 0);
}
while (cvthing.count < NUMTHREADS)
{}
assert(pthread_mutex_lock(&cvthing.lock) == 0);
cvthing.busy = 0;
assert(pthread_cond_signal(&cvthing.notbusy) == 0);
assert(pthread_mutex_unlock(&cvthing.lock) == 0);
for (i = 1; i < NUMTHREADS; i++)
{
assert(pthread_join(t[i], (void *) &result[i]) == 0);
}
assert(cvthing.count == 0);
return 0;
}
|