1*2c2f96dcSApple OSS Distributions #include <darwintest.h>
2*2c2f96dcSApple OSS Distributions #include <pthread.h>
3*2c2f96dcSApple OSS Distributions #include <sys/syscall.h>
4*2c2f96dcSApple OSS Distributions #include <unistd.h>
5*2c2f96dcSApple OSS Distributions
6*2c2f96dcSApple OSS Distributions #include <mach/mach_init.h>
7*2c2f96dcSApple OSS Distributions #include <mach/mach_port.h>
8*2c2f96dcSApple OSS Distributions #include <mach/mk_timer.h>
9*2c2f96dcSApple OSS Distributions #include <mach/task.h>
10*2c2f96dcSApple OSS Distributions
11*2c2f96dcSApple OSS Distributions #define die(w) errx(1, (w))
12*2c2f96dcSApple OSS Distributions #define edie(w) err(1, (w))
13*2c2f96dcSApple OSS Distributions #define expect(e) if (-1 == (e)) edie(#e)
14*2c2f96dcSApple OSS Distributions
15*2c2f96dcSApple OSS Distributions static void *
racer(void * data)16*2c2f96dcSApple OSS Distributions racer(void *data)
17*2c2f96dcSApple OSS Distributions {
18*2c2f96dcSApple OSS Distributions for (;;) {
19*2c2f96dcSApple OSS Distributions mk_timer_destroy(*(mach_port_t *)data);
20*2c2f96dcSApple OSS Distributions }
21*2c2f96dcSApple OSS Distributions
22*2c2f96dcSApple OSS Distributions return NULL;
23*2c2f96dcSApple OSS Distributions }
24*2c2f96dcSApple OSS Distributions
25*2c2f96dcSApple OSS Distributions T_DECL(thread_call_race_71455282,
26*2c2f96dcSApple OSS Distributions "rdar://71455282",
27*2c2f96dcSApple OSS Distributions T_META_IGNORECRASHES(".*thread_call_race_71455282.*"))
28*2c2f96dcSApple OSS Distributions {
29*2c2f96dcSApple OSS Distributions mach_port_t timer = MACH_PORT_NULL;
30*2c2f96dcSApple OSS Distributions pthread_t t;
31*2c2f96dcSApple OSS Distributions size_t n;
32*2c2f96dcSApple OSS Distributions kern_return_t kr;
33*2c2f96dcSApple OSS Distributions
34*2c2f96dcSApple OSS Distributions /* ensure we pass can at least create and destroy a timer once */
35*2c2f96dcSApple OSS Distributions timer = mk_timer_create();
36*2c2f96dcSApple OSS Distributions kr = mk_timer_arm(timer, 1);
37*2c2f96dcSApple OSS Distributions T_ASSERT_MACH_SUCCESS(kr, "timer arm");
38*2c2f96dcSApple OSS Distributions kr = mk_timer_destroy(timer);
39*2c2f96dcSApple OSS Distributions T_ASSERT_MACH_SUCCESS(kr, "timer destroy");
40*2c2f96dcSApple OSS Distributions timer = MACH_PORT_NULL;
41*2c2f96dcSApple OSS Distributions
42*2c2f96dcSApple OSS Distributions /* we will violate mach rules so ignore crashes here */
43*2c2f96dcSApple OSS Distributions T_ASSERT_MACH_SUCCESS(task_set_exc_guard_behavior(mach_task_self(), 0),
44*2c2f96dcSApple OSS Distributions "task_set_exc_guard_behavior");
45*2c2f96dcSApple OSS Distributions
46*2c2f96dcSApple OSS Distributions for (n = 0; n < 4; ++n) {
47*2c2f96dcSApple OSS Distributions T_ASSERT_POSIX_SUCCESS(pthread_create(&t, NULL, racer, &timer),
48*2c2f96dcSApple OSS Distributions "pthread_create");
49*2c2f96dcSApple OSS Distributions }
50*2c2f96dcSApple OSS Distributions
51*2c2f96dcSApple OSS Distributions T_LOG("racing");
52*2c2f96dcSApple OSS Distributions for (size_t i = 0; i < 1000; i++) {
53*2c2f96dcSApple OSS Distributions timer = mk_timer_create();
54*2c2f96dcSApple OSS Distributions kr = mk_timer_arm(timer, 1);
55*2c2f96dcSApple OSS Distributions kr = mk_timer_destroy(timer);
56*2c2f96dcSApple OSS Distributions timer = MACH_PORT_NULL;
57*2c2f96dcSApple OSS Distributions }
58*2c2f96dcSApple OSS Distributions
59*2c2f96dcSApple OSS Distributions T_PASS("didn't panic");
60*2c2f96dcSApple OSS Distributions T_END;
61*2c2f96dcSApple OSS Distributions }
62