1*f6217f89SApple OSS Distributions #include <dispatch/dispatch.h>
2*f6217f89SApple OSS Distributions #include <mach-o/dyld.h>
3*f6217f89SApple OSS Distributions #include <signal.h>
4*f6217f89SApple OSS Distributions #include <sys/kern_sysctl.h>
5*f6217f89SApple OSS Distributions #include <sys/sysctl.h>
6*f6217f89SApple OSS Distributions #include <sys/kern_memorystatus.h>
7*f6217f89SApple OSS Distributions
8*f6217f89SApple OSS Distributions #include <darwintest.h>
9*f6217f89SApple OSS Distributions #include <darwintest_utils.h>
10*f6217f89SApple OSS Distributions
11*f6217f89SApple OSS Distributions #include "test_utils.h"
12*f6217f89SApple OSS Distributions
13*f6217f89SApple OSS Distributions bool
is_development_kernel(void)14*f6217f89SApple OSS Distributions is_development_kernel(void)
15*f6217f89SApple OSS Distributions {
16*f6217f89SApple OSS Distributions static dispatch_once_t is_development_once;
17*f6217f89SApple OSS Distributions static bool is_development;
18*f6217f89SApple OSS Distributions
19*f6217f89SApple OSS Distributions dispatch_once(&is_development_once, ^{
20*f6217f89SApple OSS Distributions int dev;
21*f6217f89SApple OSS Distributions size_t dev_size = sizeof(dev);
22*f6217f89SApple OSS Distributions
23*f6217f89SApple OSS Distributions T_QUIET;
24*f6217f89SApple OSS Distributions T_ASSERT_POSIX_SUCCESS(sysctlbyname("kern.development", &dev,
25*f6217f89SApple OSS Distributions &dev_size, NULL, 0), NULL);
26*f6217f89SApple OSS Distributions is_development = (dev != 0);
27*f6217f89SApple OSS Distributions });
28*f6217f89SApple OSS Distributions
29*f6217f89SApple OSS Distributions return is_development;
30*f6217f89SApple OSS Distributions }
31*f6217f89SApple OSS Distributions
32*f6217f89SApple OSS Distributions
33*f6217f89SApple OSS Distributions bool
process_is_translated()34*f6217f89SApple OSS Distributions process_is_translated()
35*f6217f89SApple OSS Distributions {
36*f6217f89SApple OSS Distributions static dispatch_once_t is_translated_once;
37*f6217f89SApple OSS Distributions static bool is_translated;
38*f6217f89SApple OSS Distributions
39*f6217f89SApple OSS Distributions dispatch_once(&is_translated_once, ^{
40*f6217f89SApple OSS Distributions int out_value = 0;
41*f6217f89SApple OSS Distributions size_t inout_size = sizeof(out_value);
42*f6217f89SApple OSS Distributions if (sysctlbyname("sysctl.proc_translated", &out_value, &inout_size, NULL, 0) != 0) {
43*f6217f89SApple OSS Distributions /*
44*f6217f89SApple OSS Distributions * ENOENT means the sysctl is not present and therefore
45*f6217f89SApple OSS Distributions * this process is not translated. Any other error is bad.
46*f6217f89SApple OSS Distributions */
47*f6217f89SApple OSS Distributions T_QUIET; T_ASSERT_POSIX_ERROR(errno, ENOENT, "sysctlbyname(sysctl.proc_translated)");
48*f6217f89SApple OSS Distributions is_translated = false;
49*f6217f89SApple OSS Distributions } else {
50*f6217f89SApple OSS Distributions T_QUIET; T_ASSERT_GE(inout_size, sizeof(out_value), "sysctlbyname(sysctl.proc_translated)");
51*f6217f89SApple OSS Distributions is_translated = (bool)out_value;
52*f6217f89SApple OSS Distributions }
53*f6217f89SApple OSS Distributions });
54*f6217f89SApple OSS Distributions return is_translated;
55*f6217f89SApple OSS Distributions }
56*f6217f89SApple OSS Distributions
57*f6217f89SApple OSS Distributions
58*f6217f89SApple OSS Distributions pid_t
launch_background_helper(const char * variant,bool start_suspended,bool memorystatus_managed)59*f6217f89SApple OSS Distributions launch_background_helper(
60*f6217f89SApple OSS Distributions const char* variant,
61*f6217f89SApple OSS Distributions bool start_suspended,
62*f6217f89SApple OSS Distributions bool memorystatus_managed)
63*f6217f89SApple OSS Distributions {
64*f6217f89SApple OSS Distributions pid_t pid;
65*f6217f89SApple OSS Distributions char **launch_tool_args;
66*f6217f89SApple OSS Distributions char testpath[PATH_MAX];
67*f6217f89SApple OSS Distributions char *variant_cpy = strdup(variant);
68*f6217f89SApple OSS Distributions uint32_t testpath_buf_size;
69*f6217f89SApple OSS Distributions int ret;
70*f6217f89SApple OSS Distributions
71*f6217f89SApple OSS Distributions testpath_buf_size = sizeof(testpath);
72*f6217f89SApple OSS Distributions ret = _NSGetExecutablePath(testpath, &testpath_buf_size);
73*f6217f89SApple OSS Distributions launch_tool_args = (char *[]){
74*f6217f89SApple OSS Distributions testpath,
75*f6217f89SApple OSS Distributions "-n",
76*f6217f89SApple OSS Distributions variant_cpy,
77*f6217f89SApple OSS Distributions NULL
78*f6217f89SApple OSS Distributions };
79*f6217f89SApple OSS Distributions ret = dt_launch_tool(&pid, launch_tool_args, start_suspended, NULL, NULL);
80*f6217f89SApple OSS Distributions if (ret != 0) {
81*f6217f89SApple OSS Distributions T_LOG("dt_launch tool returned %d with error code %d", ret, errno);
82*f6217f89SApple OSS Distributions }
83*f6217f89SApple OSS Distributions T_QUIET; T_ASSERT_POSIX_SUCCESS(ret, "dt_launch_tool");
84*f6217f89SApple OSS Distributions if (memorystatus_managed) {
85*f6217f89SApple OSS Distributions set_process_memorystatus_managed(pid);
86*f6217f89SApple OSS Distributions }
87*f6217f89SApple OSS Distributions free(variant_cpy);
88*f6217f89SApple OSS Distributions return pid;
89*f6217f89SApple OSS Distributions }
90*f6217f89SApple OSS Distributions
91*f6217f89SApple OSS Distributions void
set_process_memorystatus_managed(pid_t pid)92*f6217f89SApple OSS Distributions set_process_memorystatus_managed(pid_t pid)
93*f6217f89SApple OSS Distributions {
94*f6217f89SApple OSS Distributions kern_return_t ret = memorystatus_control(MEMORYSTATUS_CMD_SET_PROCESS_IS_MANAGED, pid, 1, NULL, 0);
95*f6217f89SApple OSS Distributions T_QUIET; T_ASSERT_POSIX_SUCCESS(ret, "memorystatus_control");
96*f6217f89SApple OSS Distributions }
97