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