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
| | /*
* Copyright (C) 2012-2020 all contributors <cmogstored-public@yhbt.net>
* License: GPL-3.0+ <https://www.gnu.org/licenses/gpl-3.0.txt>
*/
/* ensure we can start and stop thread pools properly */
#include "check.h"
#include <sys/time.h>
static pthread_mutex_t lock = PTHREAD_MUTEX_INITIALIZER;
static pthread_cond_t cond = PTHREAD_COND_INITIALIZER;
static struct timeval tv;
void *fn(void *xarg)
{
const char *s = xarg;
assert(strcmp("whazzup", s) == 0 && "arg passed wrong");
for (;;) {
struct timespec t;
t.tv_nsec = tv.tv_usec * 1000;
t.tv_sec = tv.tv_sec + 1;
if (0 && t.tv_nsec >= 1000000000) {
t.tv_nsec -= 1000000000;
t.tv_sec++;
}
CHECK(int, 0, pthread_mutex_lock(&lock));
pthread_cond_timedwait(&cond, &lock, &t);
CHECK(int, 0, pthread_mutex_unlock(&lock));
mog_thr_test_quit();
}
assert(strcmp("whazzup", s) == 0 && "arg changed");
return NULL;
}
int main(void)
{
static struct mog_thrpool tp;
char *tmp = xstrdup("whazzup");
struct timespec t;
CHECK(int, 0, gettimeofday(&tv, NULL));
t.tv_nsec = tv.tv_usec * 1000;
t.tv_sec = tv.tv_sec + 1;
mog_thrpool_start(&tp, 6, fn, (void *)tmp);
CHECK(int, 0, pthread_mutex_lock(&lock));
CHECK(int, ETIMEDOUT, pthread_cond_timedwait(&cond, &lock, &t));
CHECK(int, 0, pthread_mutex_unlock(&lock));
mog_thrpool_quit(&tp, NULL);
free(tmp);
return 0;
}
|