xref: /xnu-8792.81.2/tests/pmap_bench.c (revision 19c3b8c28c31cb8130e034cfb5df6bf9ba342d90)
1*19c3b8c2SApple OSS Distributions #include <sys/sysctl.h>
2*19c3b8c2SApple OSS Distributions 
3*19c3b8c2SApple OSS Distributions #include <darwintest.h>
4*19c3b8c2SApple OSS Distributions #include <darwintest_perf.h>
5*19c3b8c2SApple OSS Distributions 
6*19c3b8c2SApple OSS Distributions T_GLOBAL_META(
7*19c3b8c2SApple OSS Distributions 	T_META_NAMESPACE("xnu.arm"),
8*19c3b8c2SApple OSS Distributions 	T_META_RADAR_COMPONENT_NAME("xnu"),
9*19c3b8c2SApple OSS Distributions 	T_META_RADAR_COMPONENT_VERSION("arm"),
10*19c3b8c2SApple OSS Distributions 	T_META_OWNER("jharmening")
11*19c3b8c2SApple OSS Distributions 	);
12*19c3b8c2SApple OSS Distributions 
13*19c3b8c2SApple OSS Distributions T_DECL(pmap_call_benchmark, "pmap call overhead benchmark")
14*19c3b8c2SApple OSS Distributions {
15*19c3b8c2SApple OSS Distributions 	int num_loops = 100000;
16*19c3b8c2SApple OSS Distributions 	dt_stat_time_t s = dt_stat_time_create("average pmap function call overhead for %d calls", num_loops);
17*19c3b8c2SApple OSS Distributions 	while (!dt_stat_stable(s)) {
18*19c3b8c2SApple OSS Distributions 		dt_stat_token start = dt_stat_time_begin(s);
19*19c3b8c2SApple OSS Distributions 		T_QUIET; T_ASSERT_POSIX_SUCCESS(sysctlbyname("kern.pmap_call_overhead_test", NULL, NULL,
20*19c3b8c2SApple OSS Distributions 		    &num_loops, sizeof(num_loops)), "invoke pmap call overhead test sysctl");
21*19c3b8c2SApple OSS Distributions 		dt_stat_time_end_batch(s, num_loops, start);
22*19c3b8c2SApple OSS Distributions 	}
23*19c3b8c2SApple OSS Distributions 	dt_stat_finalize(s);
24*19c3b8c2SApple OSS Distributions }
25*19c3b8c2SApple OSS Distributions 
26*19c3b8c2SApple OSS Distributions T_DECL(pmap_page_protect_benchmark, "pmap_page_protect() overhead benchmark")
27*19c3b8c2SApple OSS Distributions {
28*19c3b8c2SApple OSS Distributions 	struct {
29*19c3b8c2SApple OSS Distributions 		unsigned int num_loops;
30*19c3b8c2SApple OSS Distributions 		unsigned int num_aliases;
31*19c3b8c2SApple OSS Distributions 	} ppo_in;
32*19c3b8c2SApple OSS Distributions 	ppo_in.num_loops = 1000;
33*19c3b8c2SApple OSS Distributions 	uint64_t duration;
34*19c3b8c2SApple OSS Distributions 	size_t duration_size = sizeof(duration);
35*19c3b8c2SApple OSS Distributions 	for (ppo_in.num_aliases = 1; ppo_in.num_aliases <= 128; ppo_in.num_aliases <<= 1) {
36*19c3b8c2SApple OSS Distributions 		T_QUIET; T_ASSERT_POSIX_SUCCESS(sysctlbyname("kern.pmap_page_protect_overhead_test",
37*19c3b8c2SApple OSS Distributions 		    &duration, &duration_size, &ppo_in, sizeof(ppo_in)),
38*19c3b8c2SApple OSS Distributions 		    "invoke pmap_page_protect() overhead test sysctl");
39*19c3b8c2SApple OSS Distributions 		T_LOG("%u-loop duration (in ticks) for %u aliases: %llu", ppo_in.num_loops, ppo_in.num_aliases, duration);
40*19c3b8c2SApple OSS Distributions 	}
41*19c3b8c2SApple OSS Distributions }
42