1*a1e26a70SApple OSS Distributions #include <sys/sysctl.h>
2*a1e26a70SApple OSS Distributions #include <signal.h>
3*a1e26a70SApple OSS Distributions #include <darwintest.h>
4*a1e26a70SApple OSS Distributions #include <darwintest_utils.h>
5*a1e26a70SApple OSS Distributions
6*a1e26a70SApple OSS Distributions T_GLOBAL_META(
7*a1e26a70SApple OSS Distributions T_META_NAMESPACE("xnu.vm"),
8*a1e26a70SApple OSS Distributions T_META_RADAR_COMPONENT_NAME("xnu"),
9*a1e26a70SApple OSS Distributions T_META_RADAR_COMPONENT_VERSION("zalloc"),
10*a1e26a70SApple OSS Distributions T_META_CHECK_LEAKS(false),
11*a1e26a70SApple OSS Distributions T_META_ASROOT(YES));
12*a1e26a70SApple OSS Distributions
13*a1e26a70SApple OSS Distributions static int64_t
run_sysctl_test(const char * t,int64_t value)14*a1e26a70SApple OSS Distributions run_sysctl_test(const char *t, int64_t value)
15*a1e26a70SApple OSS Distributions {
16*a1e26a70SApple OSS Distributions char name[1024];
17*a1e26a70SApple OSS Distributions int64_t result = 0;
18*a1e26a70SApple OSS Distributions size_t s = sizeof(value);
19*a1e26a70SApple OSS Distributions int rc;
20*a1e26a70SApple OSS Distributions
21*a1e26a70SApple OSS Distributions snprintf(name, sizeof(name), "debug.test.%s", t);
22*a1e26a70SApple OSS Distributions rc = sysctlbyname(name, &result, &s, &value, s);
23*a1e26a70SApple OSS Distributions T_ASSERT_POSIX_SUCCESS(rc, "sysctlbyname(%s)", t);
24*a1e26a70SApple OSS Distributions return result;
25*a1e26a70SApple OSS Distributions }
26*a1e26a70SApple OSS Distributions
27*a1e26a70SApple OSS Distributions T_DECL(basic_zone_test, "General zalloc test", T_META_TAG_VM_PREFERRED)
28*a1e26a70SApple OSS Distributions {
29*a1e26a70SApple OSS Distributions T_EXPECT_EQ(1ull, run_sysctl_test("zone_basic_test", 0), "zone_basic_test");
30*a1e26a70SApple OSS Distributions }
31*a1e26a70SApple OSS Distributions
32*a1e26a70SApple OSS Distributions T_DECL(read_only_zone_test, "Read-only zalloc test", T_META_TAG_VM_PREFERRED)
33*a1e26a70SApple OSS Distributions {
34*a1e26a70SApple OSS Distributions T_EXPECT_EQ(1ull, run_sysctl_test("zone_ro_basic_test", 0), "zone_ro_basic_test");
35*a1e26a70SApple OSS Distributions }
36*a1e26a70SApple OSS Distributions
37*a1e26a70SApple OSS Distributions T_DECL(zone_stress_test, "Zone stress test of edge cases", T_META_TAG_VM_PREFERRED)
38*a1e26a70SApple OSS Distributions {
39*a1e26a70SApple OSS Distributions T_EXPECT_EQ(1ull, run_sysctl_test("zone_stress_test", 0), "zone_stress_test");
40*a1e26a70SApple OSS Distributions }
41*a1e26a70SApple OSS Distributions
42*a1e26a70SApple OSS Distributions T_DECL(zone_gc_stress_test, "stress test for zone_gc", T_META_TAG_VM_PREFERRED)
43*a1e26a70SApple OSS Distributions {
44*a1e26a70SApple OSS Distributions T_EXPECT_EQ(1ull, run_sysctl_test("zone_gc_stress_test", 10), "zone_gc_stress_test");
45*a1e26a70SApple OSS Distributions }
46*a1e26a70SApple OSS Distributions
47*a1e26a70SApple OSS Distributions #define ZLOG_ZONE "data.kalloc.128"
48*a1e26a70SApple OSS Distributions
49*a1e26a70SApple OSS Distributions T_DECL(zlog_smoke_test, "check that zlog functions at all",
50*a1e26a70SApple OSS Distributions T_META_REQUIRES_SYSCTL_NE("kern.kasan.available", 1),
51*a1e26a70SApple OSS Distributions T_META_BOOTARGS_SET("zlog1=" ZLOG_ZONE), T_META_TAG_VM_PREFERRED)
52*a1e26a70SApple OSS Distributions {
53*a1e26a70SApple OSS Distributions char *cmd[] = { "/usr/local/bin/zlog", "-l", "-z", ZLOG_ZONE, NULL };
54*a1e26a70SApple OSS Distributions dispatch_semaphore_t sema = dispatch_semaphore_create(0);
55*a1e26a70SApple OSS Distributions int status = 0;
56*a1e26a70SApple OSS Distributions pid_t pid;
57*a1e26a70SApple OSS Distributions
58*a1e26a70SApple OSS Distributions pid = dt_launch_tool_pipe(cmd, false, NULL,
59*a1e26a70SApple OSS Distributions ^bool (char *d, size_t s, dt_pipe_data_handler_context_t *ctx) {
60*a1e26a70SApple OSS Distributions (void)ctx;
61*a1e26a70SApple OSS Distributions if (strstr(d, "active refs") && strstr(d, "operation type: ")) {
62*a1e26a70SApple OSS Distributions T_PASS("found line [%.*s]", (int)(s - 1), d);
63*a1e26a70SApple OSS Distributions dispatch_semaphore_signal(sema);
64*a1e26a70SApple OSS Distributions }
65*a1e26a70SApple OSS Distributions return false;
66*a1e26a70SApple OSS Distributions }, ^bool (char *d, size_t s, dt_pipe_data_handler_context_t *ctx) {
67*a1e26a70SApple OSS Distributions /* Forward errors to stderror for debugging */
68*a1e26a70SApple OSS Distributions (void)ctx;
69*a1e26a70SApple OSS Distributions fwrite(d, 1, s, stderr);
70*a1e26a70SApple OSS Distributions return false;
71*a1e26a70SApple OSS Distributions }, BUFFER_PATTERN_LINE, NULL);
72*a1e26a70SApple OSS Distributions
73*a1e26a70SApple OSS Distributions dt_waitpid(pid, &status, NULL, 0);
74*a1e26a70SApple OSS Distributions if (WIFEXITED(status)) {
75*a1e26a70SApple OSS Distributions T_LOG("waitpid for %d returned with status %d",
76*a1e26a70SApple OSS Distributions pid, WEXITSTATUS(status));
77*a1e26a70SApple OSS Distributions } else {
78*a1e26a70SApple OSS Distributions int sig = WTERMSIG(status);
79*a1e26a70SApple OSS Distributions T_LOG("waitpid for %d killed by signal %d/%s",
80*a1e26a70SApple OSS Distributions pid, sig, sys_signame[sig]);
81*a1e26a70SApple OSS Distributions }
82*a1e26a70SApple OSS Distributions T_ASSERT_TRUE(WIFEXITED(status) && WEXITSTATUS(status) == 0,
83*a1e26a70SApple OSS Distributions "zlog exited cleanly");
84*a1e26a70SApple OSS Distributions
85*a1e26a70SApple OSS Distributions /* work around rdar://84948713 */
86*a1e26a70SApple OSS Distributions T_ASSERT_EQ(dispatch_semaphore_wait(sema,
87*a1e26a70SApple OSS Distributions dispatch_time(DISPATCH_TIME_NOW, NSEC_PER_SEC)), 0L,
88*a1e26a70SApple OSS Distributions "found the line we wanted");
89*a1e26a70SApple OSS Distributions dispatch_release(sema);
90*a1e26a70SApple OSS Distributions }
91