1*19c3b8c2SApple OSS Distributions #include <darwintest.h>
2*19c3b8c2SApple OSS Distributions #include <ktrace.h>
3*19c3b8c2SApple OSS Distributions #include <sys/kdebug.h>
4*19c3b8c2SApple OSS Distributions
5*19c3b8c2SApple OSS Distributions T_GLOBAL_META(T_META_RUN_CONCURRENTLY(true));
6*19c3b8c2SApple OSS Distributions
7*19c3b8c2SApple OSS Distributions #define TEST_EVENTID (0xfedcbb00)
8*19c3b8c2SApple OSS Distributions
9*19c3b8c2SApple OSS Distributions static void*
newthread(void * arg)10*19c3b8c2SApple OSS Distributions newthread(void *arg)
11*19c3b8c2SApple OSS Distributions {
12*19c3b8c2SApple OSS Distributions #pragma unused(arg)
13*19c3b8c2SApple OSS Distributions while (1) {
14*19c3b8c2SApple OSS Distributions kdebug_trace(TEST_EVENTID, 0, 0, 0, 0);
15*19c3b8c2SApple OSS Distributions sleep(1);
16*19c3b8c2SApple OSS Distributions }
17*19c3b8c2SApple OSS Distributions }
18*19c3b8c2SApple OSS Distributions
19*19c3b8c2SApple OSS Distributions #define TEST_TIMEOUT (15 * NSEC_PER_SEC)
20*19c3b8c2SApple OSS Distributions
21*19c3b8c2SApple OSS Distributions T_DECL(thread_group_set, "Checks that new threads get a THREAD_GROUP_SET tracepoint with a non-zero tid",
22*19c3b8c2SApple OSS Distributions T_META_ASROOT(true)) {
23*19c3b8c2SApple OSS Distributions pthread_t thread;
24*19c3b8c2SApple OSS Distributions __block int seen_new_thread = 0, __block seen_thread_group_set = 0;
25*19c3b8c2SApple OSS Distributions
26*19c3b8c2SApple OSS Distributions ktrace_machine_t machine = ktrace_machine_create_current();
27*19c3b8c2SApple OSS Distributions T_WITH_ERRNO; T_ASSERT_NOTNULL(machine, "ktrace_get_machine");
28*19c3b8c2SApple OSS Distributions
29*19c3b8c2SApple OSS Distributions bool has_tg = false;
30*19c3b8c2SApple OSS Distributions if (ktrace_machine_has_thread_groups(machine, &has_tg) || !has_tg) {
31*19c3b8c2SApple OSS Distributions T_SKIP("thread groups not supported on this system");
32*19c3b8c2SApple OSS Distributions }
33*19c3b8c2SApple OSS Distributions ktrace_machine_destroy(machine);
34*19c3b8c2SApple OSS Distributions
35*19c3b8c2SApple OSS Distributions ktrace_session_t session = ktrace_session_create();
36*19c3b8c2SApple OSS Distributions T_WITH_ERRNO; T_ASSERT_NOTNULL(session, "ktrace_session_create");
37*19c3b8c2SApple OSS Distributions
38*19c3b8c2SApple OSS Distributions ktrace_set_interactive(session);
39*19c3b8c2SApple OSS Distributions
40*19c3b8c2SApple OSS Distributions ktrace_set_completion_handler(session, ^{
41*19c3b8c2SApple OSS Distributions ktrace_session_destroy(session);
42*19c3b8c2SApple OSS Distributions T_ASSERT_TRUE(seen_new_thread, "seen new thread tracepoint");
43*19c3b8c2SApple OSS Distributions T_END;
44*19c3b8c2SApple OSS Distributions });
45*19c3b8c2SApple OSS Distributions
46*19c3b8c2SApple OSS Distributions ktrace_events_single(session, TEST_EVENTID, ^(__unused ktrace_event_t e) {
47*19c3b8c2SApple OSS Distributions T_EXPECT_TRUE(seen_thread_group_set, "seen THREAD_GROUP_SET tracepoint");
48*19c3b8c2SApple OSS Distributions seen_new_thread = 1;
49*19c3b8c2SApple OSS Distributions ktrace_end(session, 1);
50*19c3b8c2SApple OSS Distributions });
51*19c3b8c2SApple OSS Distributions
52*19c3b8c2SApple OSS Distributions ktrace_events_single(session, MACHDBG_CODE(DBG_MACH_THREAD_GROUP, MACH_THREAD_GROUP_SET), ^(ktrace_event_t e) {
53*19c3b8c2SApple OSS Distributions T_EXPECT_GT(e->arg3, (uintptr_t)0, "tid on THREAD_GROUP_SET");
54*19c3b8c2SApple OSS Distributions seen_thread_group_set = 1;
55*19c3b8c2SApple OSS Distributions });
56*19c3b8c2SApple OSS Distributions
57*19c3b8c2SApple OSS Distributions dispatch_after(dispatch_time(DISPATCH_TIME_NOW, TEST_TIMEOUT), dispatch_get_main_queue(), ^{
58*19c3b8c2SApple OSS Distributions ktrace_end(session, 0);
59*19c3b8c2SApple OSS Distributions });
60*19c3b8c2SApple OSS Distributions
61*19c3b8c2SApple OSS Distributions T_ASSERT_POSIX_SUCCESS(ktrace_start(session, dispatch_get_main_queue()), "ktrace_start");
62*19c3b8c2SApple OSS Distributions
63*19c3b8c2SApple OSS Distributions T_EXPECT_POSIX_SUCCESS(pthread_create(&thread, NULL, newthread, NULL), "pthread_create");
64*19c3b8c2SApple OSS Distributions T_EXPECT_POSIX_SUCCESS(pthread_detach(thread), "pthread_detach");
65*19c3b8c2SApple OSS Distributions
66*19c3b8c2SApple OSS Distributions dispatch_main();
67*19c3b8c2SApple OSS Distributions }
68