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