1*5e3eaea3SApple OSS Distributions #include <darwintest.h>
2*5e3eaea3SApple OSS Distributions
3*5e3eaea3SApple OSS Distributions #include <mach/host_priv.h>
4*5e3eaea3SApple OSS Distributions #include <mach/mach.h>
5*5e3eaea3SApple OSS Distributions #include <mach/mach_types.h>
6*5e3eaea3SApple OSS Distributions #include <mach/mach_vm.h>
7*5e3eaea3SApple OSS Distributions #include <mach_debug/ipc_info.h>
8*5e3eaea3SApple OSS Distributions #include <mach/processor_set.h>
9*5e3eaea3SApple OSS Distributions #include <mach/task.h>
10*5e3eaea3SApple OSS Distributions #include <signal.h>
11*5e3eaea3SApple OSS Distributions #include <sys/wait.h>
12*5e3eaea3SApple OSS Distributions #include <sys/proc.h>
13*5e3eaea3SApple OSS Distributions #include <sys/sysctl.h>
14*5e3eaea3SApple OSS Distributions #include <unistd.h>
15*5e3eaea3SApple OSS Distributions #include <TargetConditionals.h>
16*5e3eaea3SApple OSS Distributions
17*5e3eaea3SApple OSS Distributions #define IKOT_THREAD_CONTROL 1
18*5e3eaea3SApple OSS Distributions #define IKOT_THREAD_READ 47
19*5e3eaea3SApple OSS Distributions #define IKOT_THREAD_INSPECT 46
20*5e3eaea3SApple OSS Distributions
21*5e3eaea3SApple OSS Distributions #define IKOT_TASK_CONTROL 2
22*5e3eaea3SApple OSS Distributions #define IKOT_TASK_READ 45
23*5e3eaea3SApple OSS Distributions #define IKOT_TASK_INSPECT 44
24*5e3eaea3SApple OSS Distributions #define IKOT_TASK_NAME 20
25*5e3eaea3SApple OSS Distributions
26*5e3eaea3SApple OSS Distributions
27*5e3eaea3SApple OSS Distributions /*
28*5e3eaea3SApple OSS Distributions * This test verifies various security properties for task and thread
29*5e3eaea3SApple OSS Distributions * read/inspect interfaces. Specifically, it checks and makes sure:
30*5e3eaea3SApple OSS Distributions *
31*5e3eaea3SApple OSS Distributions * 1. Task/thread can't get higher priv'ed ports from lower ones through
32*5e3eaea3SApple OSS Distributions * {task, thread}_get_special_port()
33*5e3eaea3SApple OSS Distributions * 2. Correct level of thread ports are returned from task_threads() with
34*5e3eaea3SApple OSS Distributions * a given task port flavor
35*5e3eaea3SApple OSS Distributions * 3. Correct level of task ports are returned from processor_set_tasks()
36*5e3eaea3SApple OSS Distributions * 4. MIG intrans conversion and enforcement for task/thread port does not break.
37*5e3eaea3SApple OSS Distributions * 5. task_{, read, inspect, name}_for_pid() works for self and other process
38*5e3eaea3SApple OSS Distributions * 6. The new mach_vm_remap_new interface behaves correctly
39*5e3eaea3SApple OSS Distributions */
40*5e3eaea3SApple OSS Distributions
41*5e3eaea3SApple OSS Distributions T_GLOBAL_META(
42*5e3eaea3SApple OSS Distributions T_META_NAMESPACE("xnu.ipc"),
43*5e3eaea3SApple OSS Distributions T_META_RADAR_COMPONENT_NAME("xnu"),
44*5e3eaea3SApple OSS Distributions T_META_RADAR_COMPONENT_VERSION("IPC"),
45*5e3eaea3SApple OSS Distributions T_META_RUN_CONCURRENTLY(TRUE));
46*5e3eaea3SApple OSS Distributions
47*5e3eaea3SApple OSS Distributions static void
RESULT_CHECK(kern_return_t kr,unsigned int flavor,unsigned int required,char * f_name)48*5e3eaea3SApple OSS Distributions RESULT_CHECK(
49*5e3eaea3SApple OSS Distributions kern_return_t kr,
50*5e3eaea3SApple OSS Distributions unsigned int flavor, /* task_flavor_t or thread_flavor_t */
51*5e3eaea3SApple OSS Distributions unsigned int required, /* task_flavor_t or thread_flavor_t */
52*5e3eaea3SApple OSS Distributions char *f_name)
53*5e3eaea3SApple OSS Distributions {
54*5e3eaea3SApple OSS Distributions if (flavor <= required) {
55*5e3eaea3SApple OSS Distributions T_EXPECT_EQ(kr, KERN_SUCCESS, "%s should succeed with task/thread flavor %d, kr: 0x%x", f_name, flavor, kr);
56*5e3eaea3SApple OSS Distributions } else {
57*5e3eaea3SApple OSS Distributions T_EXPECT_NE(kr, KERN_SUCCESS, "%s should fail with task/thread flavor %d, kr: 0x%x", f_name, flavor, kr);
58*5e3eaea3SApple OSS Distributions }
59*5e3eaea3SApple OSS Distributions }
60*5e3eaea3SApple OSS Distributions
61*5e3eaea3SApple OSS Distributions static void
test_task_get_special_port(task_t tport,task_flavor_t flavor)62*5e3eaea3SApple OSS Distributions test_task_get_special_port(
63*5e3eaea3SApple OSS Distributions task_t tport,
64*5e3eaea3SApple OSS Distributions task_flavor_t flavor)
65*5e3eaea3SApple OSS Distributions {
66*5e3eaea3SApple OSS Distributions kern_return_t kr;
67*5e3eaea3SApple OSS Distributions mach_port_t special_port = MACH_PORT_NULL;
68*5e3eaea3SApple OSS Distributions mach_port_t tfp_port = MACH_PORT_NULL;
69*5e3eaea3SApple OSS Distributions
70*5e3eaea3SApple OSS Distributions T_LOG("Testing task_get_special_port() with task flavor %d", flavor);
71*5e3eaea3SApple OSS Distributions /* gettable with at least control port */
72*5e3eaea3SApple OSS Distributions kr = task_get_special_port(tport, TASK_KERNEL_PORT, &special_port);
73*5e3eaea3SApple OSS Distributions RESULT_CHECK(kr, flavor, TASK_FLAVOR_CONTROL, "task_get_special_port(TASK_KERNEL_PORT)");
74*5e3eaea3SApple OSS Distributions mach_port_deallocate(mach_task_self(), special_port);
75*5e3eaea3SApple OSS Distributions special_port = MACH_PORT_NULL;
76*5e3eaea3SApple OSS Distributions
77*5e3eaea3SApple OSS Distributions kr = task_get_special_port(tport, TASK_BOOTSTRAP_PORT, &special_port);
78*5e3eaea3SApple OSS Distributions RESULT_CHECK(kr, flavor, TASK_FLAVOR_CONTROL, "task_get_special_port(TASK_BOOTSTRAP_PORT)");
79*5e3eaea3SApple OSS Distributions mach_port_deallocate(mach_task_self(), special_port);
80*5e3eaea3SApple OSS Distributions special_port = MACH_PORT_NULL;
81*5e3eaea3SApple OSS Distributions
82*5e3eaea3SApple OSS Distributions kr = task_get_special_port(tport, TASK_HOST_PORT, &special_port);
83*5e3eaea3SApple OSS Distributions RESULT_CHECK(kr, flavor, TASK_FLAVOR_CONTROL, "task_get_special_port(TASK_HOST_PORT)");
84*5e3eaea3SApple OSS Distributions mach_port_deallocate(mach_task_self(), special_port);
85*5e3eaea3SApple OSS Distributions special_port = MACH_PORT_NULL;
86*5e3eaea3SApple OSS Distributions
87*5e3eaea3SApple OSS Distributions /* gettable with at least read port */
88*5e3eaea3SApple OSS Distributions kr = task_get_special_port(tport, TASK_READ_PORT, &special_port);
89*5e3eaea3SApple OSS Distributions RESULT_CHECK(kr, flavor, TASK_FLAVOR_READ, "task_get_special_port(TASK_READ_PORT)");
90*5e3eaea3SApple OSS Distributions if (KERN_SUCCESS == kr) {
91*5e3eaea3SApple OSS Distributions kr = task_read_for_pid(mach_task_self(), getpid(), &tfp_port);
92*5e3eaea3SApple OSS Distributions T_QUIET; T_ASSERT_MACH_SUCCESS(kr, "task_read_for_pid()");
93*5e3eaea3SApple OSS Distributions T_QUIET; T_EXPECT_EQ(tfp_port, special_port, "task_read_for_pid() should match TASK_READ_PORT");
94*5e3eaea3SApple OSS Distributions mach_port_deallocate(mach_task_self(), tfp_port);
95*5e3eaea3SApple OSS Distributions }
96*5e3eaea3SApple OSS Distributions mach_port_deallocate(mach_task_self(), special_port);
97*5e3eaea3SApple OSS Distributions special_port = MACH_PORT_NULL;
98*5e3eaea3SApple OSS Distributions
99*5e3eaea3SApple OSS Distributions /* gettable with at least inspect port */
100*5e3eaea3SApple OSS Distributions kr = task_get_special_port(tport, TASK_INSPECT_PORT, &special_port);
101*5e3eaea3SApple OSS Distributions RESULT_CHECK(kr, flavor, TASK_FLAVOR_INSPECT, "task_get_special_port(TASK_INSPECT_PORT)");
102*5e3eaea3SApple OSS Distributions if (KERN_SUCCESS == kr) {
103*5e3eaea3SApple OSS Distributions kr = task_inspect_for_pid(mach_task_self(), getpid(), &tfp_port);
104*5e3eaea3SApple OSS Distributions T_QUIET; T_ASSERT_MACH_SUCCESS(kr, "task_inspect_for_pid()");
105*5e3eaea3SApple OSS Distributions T_QUIET; T_EXPECT_EQ(tfp_port, special_port, "task_inspect_for_pid() should match TASK_INSPECT_PORT");
106*5e3eaea3SApple OSS Distributions mach_port_deallocate(mach_task_self(), tfp_port);
107*5e3eaea3SApple OSS Distributions }
108*5e3eaea3SApple OSS Distributions mach_port_deallocate(mach_task_self(), special_port);
109*5e3eaea3SApple OSS Distributions special_port = MACH_PORT_NULL;
110*5e3eaea3SApple OSS Distributions
111*5e3eaea3SApple OSS Distributions /* gettable with at least name port */
112*5e3eaea3SApple OSS Distributions kr = task_get_special_port(tport, TASK_NAME_PORT, &special_port);
113*5e3eaea3SApple OSS Distributions RESULT_CHECK(kr, flavor, TASK_FLAVOR_INSPECT, "task_get_special_port(TASK_NAME_PORT)");
114*5e3eaea3SApple OSS Distributions if (KERN_SUCCESS == kr) {
115*5e3eaea3SApple OSS Distributions kr = task_name_for_pid(mach_task_self(), getpid(), &tfp_port);
116*5e3eaea3SApple OSS Distributions T_QUIET; T_ASSERT_MACH_SUCCESS(kr, "task_name_for_pid()");
117*5e3eaea3SApple OSS Distributions T_QUIET; T_EXPECT_EQ(tfp_port, special_port, "task_name_for_pid() should match TASK_NAME_PORT");
118*5e3eaea3SApple OSS Distributions mach_port_deallocate(mach_task_self(), tfp_port);
119*5e3eaea3SApple OSS Distributions }
120*5e3eaea3SApple OSS Distributions mach_port_deallocate(mach_task_self(), special_port);
121*5e3eaea3SApple OSS Distributions special_port = MACH_PORT_NULL;
122*5e3eaea3SApple OSS Distributions }
123*5e3eaea3SApple OSS Distributions
124*5e3eaea3SApple OSS Distributions static void
test_thread_get_special_port(thread_t tport,thread_flavor_t flavor)125*5e3eaea3SApple OSS Distributions test_thread_get_special_port(
126*5e3eaea3SApple OSS Distributions thread_t tport,
127*5e3eaea3SApple OSS Distributions thread_flavor_t flavor)
128*5e3eaea3SApple OSS Distributions {
129*5e3eaea3SApple OSS Distributions kern_return_t kr;
130*5e3eaea3SApple OSS Distributions mach_port_t special_port = MACH_PORT_NULL;
131*5e3eaea3SApple OSS Distributions
132*5e3eaea3SApple OSS Distributions T_LOG("Testing thread_get_special_port() with thread flavor %d", flavor);
133*5e3eaea3SApple OSS Distributions /* gettable with at least control port */
134*5e3eaea3SApple OSS Distributions kr = thread_get_special_port(tport, THREAD_KERNEL_PORT, &special_port);
135*5e3eaea3SApple OSS Distributions RESULT_CHECK(kr, flavor, THREAD_FLAVOR_CONTROL, "thread_get_special_port(THREAD_KERNEL_PORT)");
136*5e3eaea3SApple OSS Distributions mach_port_deallocate(mach_task_self(), special_port);
137*5e3eaea3SApple OSS Distributions special_port = MACH_PORT_NULL;
138*5e3eaea3SApple OSS Distributions
139*5e3eaea3SApple OSS Distributions /* gettable with at least read port */
140*5e3eaea3SApple OSS Distributions kr = thread_get_special_port(tport, THREAD_READ_PORT, &special_port);
141*5e3eaea3SApple OSS Distributions RESULT_CHECK(kr, flavor, THREAD_FLAVOR_READ, "thread_get_special_port(THREAD_READ_PORT)");
142*5e3eaea3SApple OSS Distributions mach_port_deallocate(mach_task_self(), special_port);
143*5e3eaea3SApple OSS Distributions special_port = MACH_PORT_NULL;
144*5e3eaea3SApple OSS Distributions
145*5e3eaea3SApple OSS Distributions /* gettable with at least inspect port */
146*5e3eaea3SApple OSS Distributions kr = thread_get_special_port(tport, THREAD_INSPECT_PORT, &special_port);
147*5e3eaea3SApple OSS Distributions RESULT_CHECK(kr, flavor, THREAD_FLAVOR_INSPECT, "thread_get_special_port(THREAD_INSPECT_PORT)");
148*5e3eaea3SApple OSS Distributions mach_port_deallocate(mach_task_self(), special_port);
149*5e3eaea3SApple OSS Distributions special_port = MACH_PORT_NULL;
150*5e3eaea3SApple OSS Distributions }
151*5e3eaea3SApple OSS Distributions
152*5e3eaea3SApple OSS Distributions static void
test_task_threads(task_t tport,task_flavor_t flavor)153*5e3eaea3SApple OSS Distributions test_task_threads(
154*5e3eaea3SApple OSS Distributions task_t tport,
155*5e3eaea3SApple OSS Distributions task_flavor_t flavor)
156*5e3eaea3SApple OSS Distributions {
157*5e3eaea3SApple OSS Distributions kern_return_t kr;
158*5e3eaea3SApple OSS Distributions thread_array_t threadList;
159*5e3eaea3SApple OSS Distributions mach_msg_type_number_t threadCount = 0;
160*5e3eaea3SApple OSS Distributions
161*5e3eaea3SApple OSS Distributions unsigned int kotype;
162*5e3eaea3SApple OSS Distributions unsigned int kaddr;
163*5e3eaea3SApple OSS Distributions
164*5e3eaea3SApple OSS Distributions T_LOG("Testing task_threads() with task flavor %d", flavor);
165*5e3eaea3SApple OSS Distributions
166*5e3eaea3SApple OSS Distributions kr = task_threads(tport, &threadList, &threadCount);
167*5e3eaea3SApple OSS Distributions RESULT_CHECK(kr, flavor, TASK_FLAVOR_INSPECT, "task_threads");
168*5e3eaea3SApple OSS Distributions
169*5e3eaea3SApple OSS Distributions if (kr) {
170*5e3eaea3SApple OSS Distributions T_LOG("task_threads failed, skipping test_task_threads()");
171*5e3eaea3SApple OSS Distributions return;
172*5e3eaea3SApple OSS Distributions }
173*5e3eaea3SApple OSS Distributions
174*5e3eaea3SApple OSS Distributions T_QUIET; T_ASSERT_GE(threadCount, 1, "threadCount should be at least 1");
175*5e3eaea3SApple OSS Distributions
176*5e3eaea3SApple OSS Distributions /*
177*5e3eaea3SApple OSS Distributions * TASK_FLAVOR_CONTROL -> THREAD_FLAVOR_CONTROL
178*5e3eaea3SApple OSS Distributions * TASK_FLAVOR_READ -> THREAD_FLAVOR_READ
179*5e3eaea3SApple OSS Distributions * TASK_FLAVOR_INSPECT -> THREAD_FLAVOR_INSPECT
180*5e3eaea3SApple OSS Distributions * TASK_FLAOVR_NAME -> KERN_FAILURE
181*5e3eaea3SApple OSS Distributions */
182*5e3eaea3SApple OSS Distributions for (size_t i = 0; i < threadCount; i++) {
183*5e3eaea3SApple OSS Distributions kr = mach_port_kernel_object(mach_task_self(), threadList[i], &kotype, &kaddr);
184*5e3eaea3SApple OSS Distributions if (kr == KERN_INVALID_RIGHT || kr == KERN_INVALID_NAME) {
185*5e3eaea3SApple OSS Distributions /* thread port is inactive */
186*5e3eaea3SApple OSS Distributions T_LOG("thread port name 0x%x is inactive", threadList[i]);
187*5e3eaea3SApple OSS Distributions continue;
188*5e3eaea3SApple OSS Distributions } else if (kr) {
189*5e3eaea3SApple OSS Distributions T_FAIL("mach_port_kernel_object() failed with kr: 0x%x", kr);
190*5e3eaea3SApple OSS Distributions }
191*5e3eaea3SApple OSS Distributions switch (flavor) {
192*5e3eaea3SApple OSS Distributions case TASK_FLAVOR_CONTROL:
193*5e3eaea3SApple OSS Distributions T_QUIET; T_EXPECT_EQ(kotype, IKOT_THREAD_CONTROL, "Task control port should yield thread control port");
194*5e3eaea3SApple OSS Distributions break;
195*5e3eaea3SApple OSS Distributions case TASK_FLAVOR_READ:
196*5e3eaea3SApple OSS Distributions T_QUIET; T_EXPECT_EQ(kotype, IKOT_THREAD_READ, "Task read port should yield thread read port");
197*5e3eaea3SApple OSS Distributions break;
198*5e3eaea3SApple OSS Distributions case TASK_FLAVOR_INSPECT:
199*5e3eaea3SApple OSS Distributions T_QUIET; T_EXPECT_EQ(kotype, IKOT_THREAD_INSPECT, "Task inspect port should yield thread inspect port");
200*5e3eaea3SApple OSS Distributions break;
201*5e3eaea3SApple OSS Distributions default:
202*5e3eaea3SApple OSS Distributions T_FAIL("task_threads() returned thread ports with task name port??");
203*5e3eaea3SApple OSS Distributions break;
204*5e3eaea3SApple OSS Distributions }
205*5e3eaea3SApple OSS Distributions }
206*5e3eaea3SApple OSS Distributions
207*5e3eaea3SApple OSS Distributions for (size_t i = 0; i < threadCount; i++) {
208*5e3eaea3SApple OSS Distributions mach_port_deallocate(mach_task_self(), threadList[i]);
209*5e3eaea3SApple OSS Distributions }
210*5e3eaea3SApple OSS Distributions vm_deallocate(mach_task_self(), (vm_address_t)threadList,
211*5e3eaea3SApple OSS Distributions sizeof(threadList[0]) * threadCount);
212*5e3eaea3SApple OSS Distributions }
213*5e3eaea3SApple OSS Distributions
214*5e3eaea3SApple OSS Distributions static void
test_processor_set_tasks(task_flavor_t flavor)215*5e3eaea3SApple OSS Distributions test_processor_set_tasks(
216*5e3eaea3SApple OSS Distributions task_flavor_t flavor)
217*5e3eaea3SApple OSS Distributions {
218*5e3eaea3SApple OSS Distributions kern_return_t kr;
219*5e3eaea3SApple OSS Distributions processor_set_name_array_t psets;
220*5e3eaea3SApple OSS Distributions processor_set_t pset_priv;
221*5e3eaea3SApple OSS Distributions task_array_t taskList;
222*5e3eaea3SApple OSS Distributions mach_msg_type_number_t pcnt = 0, tcnt = 0;
223*5e3eaea3SApple OSS Distributions mach_port_t host = mach_host_self();
224*5e3eaea3SApple OSS Distributions
225*5e3eaea3SApple OSS Distributions unsigned int kotype;
226*5e3eaea3SApple OSS Distributions unsigned int kaddr;
227*5e3eaea3SApple OSS Distributions
228*5e3eaea3SApple OSS Distributions T_LOG("Testing processor_set_tasks() with task flavor %d", flavor);
229*5e3eaea3SApple OSS Distributions
230*5e3eaea3SApple OSS Distributions kr = host_processor_sets(host, &psets, &pcnt);
231*5e3eaea3SApple OSS Distributions T_QUIET; T_ASSERT_MACH_SUCCESS(kr, "host_processor_sets");
232*5e3eaea3SApple OSS Distributions T_QUIET; T_ASSERT_GE(pcnt, 1, "should have at least 1 processor set");
233*5e3eaea3SApple OSS Distributions
234*5e3eaea3SApple OSS Distributions kr = host_processor_set_priv(host, psets[0], &pset_priv);
235*5e3eaea3SApple OSS Distributions T_QUIET; T_ASSERT_MACH_SUCCESS(kr, "host_processor_set_priv");
236*5e3eaea3SApple OSS Distributions for (size_t i = 0; i < pcnt; i++) {
237*5e3eaea3SApple OSS Distributions mach_port_deallocate(mach_task_self(), psets[i]);
238*5e3eaea3SApple OSS Distributions }
239*5e3eaea3SApple OSS Distributions mach_port_deallocate(mach_task_self(), host);
240*5e3eaea3SApple OSS Distributions
241*5e3eaea3SApple OSS Distributions kr = processor_set_tasks_with_flavor(pset_priv, flavor, &taskList, &tcnt);
242*5e3eaea3SApple OSS Distributions T_QUIET; T_ASSERT_MACH_SUCCESS(kr, "processor_set_tasks_with_flavor");
243*5e3eaea3SApple OSS Distributions T_QUIET; T_ASSERT_GE(tcnt, 1, "should have at least 1 task");
244*5e3eaea3SApple OSS Distributions mach_port_deallocate(mach_task_self(), pset_priv);
245*5e3eaea3SApple OSS Distributions
246*5e3eaea3SApple OSS Distributions for (size_t i = 0; i < tcnt; i++) {
247*5e3eaea3SApple OSS Distributions kr = mach_port_kernel_object(mach_task_self(), taskList[i], &kotype, &kaddr);
248*5e3eaea3SApple OSS Distributions if (kr == KERN_INVALID_RIGHT || kr == KERN_INVALID_NAME) {
249*5e3eaea3SApple OSS Distributions /* task port is inactive */
250*5e3eaea3SApple OSS Distributions T_LOG("task port name 0x%x is inactive", taskList[i]);
251*5e3eaea3SApple OSS Distributions continue;
252*5e3eaea3SApple OSS Distributions } else if (kr) {
253*5e3eaea3SApple OSS Distributions T_FAIL("mach_port_kernel_object() failed with kr: 0x%x", kr);
254*5e3eaea3SApple OSS Distributions }
255*5e3eaea3SApple OSS Distributions switch (flavor) {
256*5e3eaea3SApple OSS Distributions case TASK_FLAVOR_CONTROL:
257*5e3eaea3SApple OSS Distributions T_QUIET; T_EXPECT_EQ(kotype, IKOT_TASK_CONTROL, "TASK_FLAVOR_CONTROL should yield control ports");
258*5e3eaea3SApple OSS Distributions break;
259*5e3eaea3SApple OSS Distributions case TASK_FLAVOR_READ:
260*5e3eaea3SApple OSS Distributions T_QUIET; T_EXPECT_EQ(kotype, IKOT_TASK_READ, "TASK_FLAVOR_READ should yield read ports");
261*5e3eaea3SApple OSS Distributions break;
262*5e3eaea3SApple OSS Distributions case TASK_FLAVOR_INSPECT:
263*5e3eaea3SApple OSS Distributions T_QUIET; T_EXPECT_EQ(kotype, IKOT_TASK_INSPECT, "TASK_FLAVOR_INSPECT should yield inspect ports");
264*5e3eaea3SApple OSS Distributions break;
265*5e3eaea3SApple OSS Distributions case TASK_FLAVOR_NAME:
266*5e3eaea3SApple OSS Distributions T_QUIET; T_EXPECT_EQ(kotype, IKOT_TASK_NAME, "TASK_FLAVOR_NAME should yield name ports");
267*5e3eaea3SApple OSS Distributions break;
268*5e3eaea3SApple OSS Distributions default:
269*5e3eaea3SApple OSS Distributions T_FAIL("strange flavor");
270*5e3eaea3SApple OSS Distributions break;
271*5e3eaea3SApple OSS Distributions }
272*5e3eaea3SApple OSS Distributions }
273*5e3eaea3SApple OSS Distributions
274*5e3eaea3SApple OSS Distributions for (size_t i = 0; i < tcnt; i++) {
275*5e3eaea3SApple OSS Distributions mach_port_deallocate(mach_task_self(), taskList[i]);
276*5e3eaea3SApple OSS Distributions }
277*5e3eaea3SApple OSS Distributions }
278*5e3eaea3SApple OSS Distributions
279*5e3eaea3SApple OSS Distributions static void
test_task_port_mig_intrans(task_t tport,task_flavor_t flavor)280*5e3eaea3SApple OSS Distributions test_task_port_mig_intrans(
281*5e3eaea3SApple OSS Distributions task_t tport,
282*5e3eaea3SApple OSS Distributions task_flavor_t flavor)
283*5e3eaea3SApple OSS Distributions {
284*5e3eaea3SApple OSS Distributions kern_return_t kr;
285*5e3eaea3SApple OSS Distributions
286*5e3eaea3SApple OSS Distributions T_LOG("Testing various MIG/manual intrans task interfaces with task flavor %d", flavor);
287*5e3eaea3SApple OSS Distributions
288*5e3eaea3SApple OSS Distributions {
289*5e3eaea3SApple OSS Distributions /* 1. Test some control port interfaces */
290*5e3eaea3SApple OSS Distributions int data = 0x41;
291*5e3eaea3SApple OSS Distributions int new_value = 0x42;
292*5e3eaea3SApple OSS Distributions kr = mach_vm_write(tport,
293*5e3eaea3SApple OSS Distributions (mach_vm_address_t)&data,
294*5e3eaea3SApple OSS Distributions (vm_offset_t)&new_value,
295*5e3eaea3SApple OSS Distributions (mach_msg_type_number_t)sizeof(int));
296*5e3eaea3SApple OSS Distributions RESULT_CHECK(kr, flavor, TASK_FLAVOR_CONTROL, "mach_vm_write");
297*5e3eaea3SApple OSS Distributions
298*5e3eaea3SApple OSS Distributions /* mach_vm_remap_new with max_protection VM_PROT_WRITE | VM_PROT_READ */
299*5e3eaea3SApple OSS Distributions int *localAddress = 0;
300*5e3eaea3SApple OSS Distributions mach_vm_address_t localMachVMAddress = 0;
301*5e3eaea3SApple OSS Distributions vm_prot_t cur_protection = VM_PROT_WRITE | VM_PROT_READ;
302*5e3eaea3SApple OSS Distributions vm_prot_t max_protection = VM_PROT_WRITE | VM_PROT_READ;
303*5e3eaea3SApple OSS Distributions /* rdar://67706101 (mach_vm_remap flag that allows restricting protection of remapped region) */
304*5e3eaea3SApple OSS Distributions kr = mach_vm_remap_new(mach_task_self(),
305*5e3eaea3SApple OSS Distributions &localMachVMAddress,
306*5e3eaea3SApple OSS Distributions sizeof(int),
307*5e3eaea3SApple OSS Distributions 0,
308*5e3eaea3SApple OSS Distributions VM_FLAGS_ANYWHERE,
309*5e3eaea3SApple OSS Distributions tport, /* remote task, use self task port */
310*5e3eaea3SApple OSS Distributions (mach_vm_address_t)&data,
311*5e3eaea3SApple OSS Distributions false,
312*5e3eaea3SApple OSS Distributions &cur_protection,
313*5e3eaea3SApple OSS Distributions &max_protection,
314*5e3eaea3SApple OSS Distributions VM_INHERIT_NONE);
315*5e3eaea3SApple OSS Distributions localAddress = (int *)(uintptr_t)localMachVMAddress;
316*5e3eaea3SApple OSS Distributions
317*5e3eaea3SApple OSS Distributions RESULT_CHECK(kr, flavor, TASK_FLAVOR_CONTROL, "mach_vm_remap_new - VM_PROT_WRITE");
318*5e3eaea3SApple OSS Distributions if (KERN_SUCCESS == kr) {
319*5e3eaea3SApple OSS Distributions T_QUIET; T_EXPECT_EQ(max_protection, VM_PROT_READ | VM_PROT_WRITE, NULL);
320*5e3eaea3SApple OSS Distributions T_QUIET; T_EXPECT_EQ(cur_protection, VM_PROT_READ | VM_PROT_WRITE, NULL);
321*5e3eaea3SApple OSS Distributions T_QUIET; T_EXPECT_EQ(*localAddress, data, NULL); /* read */
322*5e3eaea3SApple OSS Distributions *localAddress = 0; /* write */
323*5e3eaea3SApple OSS Distributions }
324*5e3eaea3SApple OSS Distributions
325*5e3eaea3SApple OSS Distributions exception_mask_t masks[EXC_TYPES_COUNT] = {};
326*5e3eaea3SApple OSS Distributions mach_msg_type_number_t nmasks = 0;
327*5e3eaea3SApple OSS Distributions exception_port_t ports[EXC_TYPES_COUNT] = {};
328*5e3eaea3SApple OSS Distributions exception_behavior_t behaviors[EXC_TYPES_COUNT] = {};
329*5e3eaea3SApple OSS Distributions thread_state_flavor_t flavors[EXC_TYPES_COUNT] = {};
330*5e3eaea3SApple OSS Distributions kr = task_get_exception_ports(tport, EXC_MASK_ALL,
331*5e3eaea3SApple OSS Distributions masks, &nmasks, ports, behaviors, flavors);
332*5e3eaea3SApple OSS Distributions RESULT_CHECK(kr, flavor, TASK_FLAVOR_CONTROL, "task_get_exception_ports");
333*5e3eaea3SApple OSS Distributions for (size_t i = 0; i < EXC_TYPES_COUNT; i++) {
334*5e3eaea3SApple OSS Distributions mach_port_deallocate(mach_task_self(), ports[i]);
335*5e3eaea3SApple OSS Distributions }
336*5e3eaea3SApple OSS Distributions }
337*5e3eaea3SApple OSS Distributions
338*5e3eaea3SApple OSS Distributions {
339*5e3eaea3SApple OSS Distributions /* 2. Test some read port interfaces */
340*5e3eaea3SApple OSS Distributions vm_offset_t read_value = 0;
341*5e3eaea3SApple OSS Distributions mach_msg_type_number_t read_cnt = 0;
342*5e3eaea3SApple OSS Distributions int data = 0x41;
343*5e3eaea3SApple OSS Distributions kr = mach_vm_read(tport,
344*5e3eaea3SApple OSS Distributions (mach_vm_address_t)&data,
345*5e3eaea3SApple OSS Distributions (mach_msg_type_number_t)sizeof(int),
346*5e3eaea3SApple OSS Distributions &read_value,
347*5e3eaea3SApple OSS Distributions &read_cnt);
348*5e3eaea3SApple OSS Distributions RESULT_CHECK(kr, flavor, TASK_FLAVOR_READ, "mach_vm_read");
349*5e3eaea3SApple OSS Distributions
350*5e3eaea3SApple OSS Distributions /* mach_vm_remap_new with max_protection VM_PROT_READ */
351*5e3eaea3SApple OSS Distributions int *localAddress = 0;
352*5e3eaea3SApple OSS Distributions mach_vm_address_t localMachVMAddress = 0;
353*5e3eaea3SApple OSS Distributions vm_prot_t cur_protection = VM_PROT_READ;
354*5e3eaea3SApple OSS Distributions vm_prot_t max_protection = VM_PROT_READ;
355*5e3eaea3SApple OSS Distributions /* rdar://67706101 (mach_vm_remap flag that allows restricting protection of remapped region) */
356*5e3eaea3SApple OSS Distributions kr = mach_vm_remap_new(mach_task_self(),
357*5e3eaea3SApple OSS Distributions &localMachVMAddress,
358*5e3eaea3SApple OSS Distributions sizeof(int),
359*5e3eaea3SApple OSS Distributions 0,
360*5e3eaea3SApple OSS Distributions VM_FLAGS_ANYWHERE,
361*5e3eaea3SApple OSS Distributions tport, /* remote task, use self task port */
362*5e3eaea3SApple OSS Distributions (mach_vm_address_t)&data,
363*5e3eaea3SApple OSS Distributions false,
364*5e3eaea3SApple OSS Distributions &cur_protection,
365*5e3eaea3SApple OSS Distributions &max_protection,
366*5e3eaea3SApple OSS Distributions VM_INHERIT_NONE);
367*5e3eaea3SApple OSS Distributions localAddress = (int *)(uintptr_t)localMachVMAddress;
368*5e3eaea3SApple OSS Distributions
369*5e3eaea3SApple OSS Distributions RESULT_CHECK(kr, flavor, TASK_FLAVOR_READ, "mach_vm_remap_new - VM_PROT_READ");
370*5e3eaea3SApple OSS Distributions if (KERN_SUCCESS == kr) {
371*5e3eaea3SApple OSS Distributions T_QUIET; T_EXPECT_EQ(max_protection, VM_PROT_READ, NULL);
372*5e3eaea3SApple OSS Distributions T_QUIET; T_EXPECT_EQ(cur_protection, VM_PROT_READ, NULL);
373*5e3eaea3SApple OSS Distributions T_QUIET; T_EXPECT_EQ(*localAddress, data, NULL); /* read */
374*5e3eaea3SApple OSS Distributions }
375*5e3eaea3SApple OSS Distributions
376*5e3eaea3SApple OSS Distributions /* mach_vm_remap_new with copy == TRUE */
377*5e3eaea3SApple OSS Distributions int data2 = 0x42;
378*5e3eaea3SApple OSS Distributions localAddress = 0;
379*5e3eaea3SApple OSS Distributions localMachVMAddress = 0;
380*5e3eaea3SApple OSS Distributions cur_protection = VM_PROT_WRITE | VM_PROT_READ;
381*5e3eaea3SApple OSS Distributions max_protection = VM_PROT_WRITE | VM_PROT_READ;
382*5e3eaea3SApple OSS Distributions
383*5e3eaea3SApple OSS Distributions kr = mach_vm_remap_new(mach_task_self(),
384*5e3eaea3SApple OSS Distributions &localMachVMAddress,
385*5e3eaea3SApple OSS Distributions sizeof(int),
386*5e3eaea3SApple OSS Distributions 0,
387*5e3eaea3SApple OSS Distributions VM_FLAGS_ANYWHERE,
388*5e3eaea3SApple OSS Distributions tport, /* remote task, use self task port */
389*5e3eaea3SApple OSS Distributions (mach_vm_address_t)&data2,
390*5e3eaea3SApple OSS Distributions true,
391*5e3eaea3SApple OSS Distributions &cur_protection,
392*5e3eaea3SApple OSS Distributions &max_protection,
393*5e3eaea3SApple OSS Distributions VM_INHERIT_NONE);
394*5e3eaea3SApple OSS Distributions localAddress = (int *)(uintptr_t)localMachVMAddress;
395*5e3eaea3SApple OSS Distributions
396*5e3eaea3SApple OSS Distributions RESULT_CHECK(kr, flavor, TASK_FLAVOR_READ, "mach_vm_remap_new - copy==TRUE");
397*5e3eaea3SApple OSS Distributions if (KERN_SUCCESS == kr) {
398*5e3eaea3SApple OSS Distributions T_QUIET; T_EXPECT_EQ(max_protection, VM_PROT_READ | VM_PROT_WRITE, NULL);
399*5e3eaea3SApple OSS Distributions T_QUIET; T_EXPECT_EQ(cur_protection, VM_PROT_READ | VM_PROT_WRITE, NULL);
400*5e3eaea3SApple OSS Distributions /* Following is causing bus error tracked by rdar://71616700 (Unexpected BUS ERROR in mach_vm_remap_new()) */
401*5e3eaea3SApple OSS Distributions // T_QUIET; T_EXPECT_EQ(*localAddress, data2, NULL); /* read */
402*5e3eaea3SApple OSS Distributions // *localAddress = 0; /* write */
403*5e3eaea3SApple OSS Distributions }
404*5e3eaea3SApple OSS Distributions
405*5e3eaea3SApple OSS Distributions /* */
406*5e3eaea3SApple OSS Distributions mach_port_t voucher = MACH_PORT_NULL;
407*5e3eaea3SApple OSS Distributions kr = task_get_mach_voucher(tport, 0, &voucher);
408*5e3eaea3SApple OSS Distributions RESULT_CHECK(kr, flavor, TASK_FLAVOR_READ, "task_get_mach_voucher");
409*5e3eaea3SApple OSS Distributions mach_port_deallocate(mach_task_self(), voucher);
410*5e3eaea3SApple OSS Distributions
411*5e3eaea3SApple OSS Distributions /* */
412*5e3eaea3SApple OSS Distributions ipc_info_space_t space_info;
413*5e3eaea3SApple OSS Distributions ipc_info_name_array_t table;
414*5e3eaea3SApple OSS Distributions mach_msg_type_number_t tableCount;
415*5e3eaea3SApple OSS Distributions ipc_info_tree_name_array_t tree; /* unused */
416*5e3eaea3SApple OSS Distributions mach_msg_type_number_t treeCount; /* unused */
417*5e3eaea3SApple OSS Distributions kr = mach_port_space_info(tport, &space_info, &table, &tableCount, &tree, &treeCount);
418*5e3eaea3SApple OSS Distributions RESULT_CHECK(kr, flavor, TASK_FLAVOR_READ, "mach_port_space_info");
419*5e3eaea3SApple OSS Distributions }
420*5e3eaea3SApple OSS Distributions
421*5e3eaea3SApple OSS Distributions {
422*5e3eaea3SApple OSS Distributions /* 3. Test some inspect port interfaces */
423*5e3eaea3SApple OSS Distributions task_exc_guard_behavior_t exc_behavior;
424*5e3eaea3SApple OSS Distributions kr = task_get_exc_guard_behavior(tport, &exc_behavior);
425*5e3eaea3SApple OSS Distributions RESULT_CHECK(kr, flavor, TASK_FLAVOR_INSPECT, "task_get_exc_guard_behavior");
426*5e3eaea3SApple OSS Distributions }
427*5e3eaea3SApple OSS Distributions
428*5e3eaea3SApple OSS Distributions {
429*5e3eaea3SApple OSS Distributions /* 4. Test some name port interfaces */
430*5e3eaea3SApple OSS Distributions struct task_basic_info info;
431*5e3eaea3SApple OSS Distributions mach_msg_type_number_t size = sizeof(info);
432*5e3eaea3SApple OSS Distributions kr = task_info(tport,
433*5e3eaea3SApple OSS Distributions TASK_BASIC_INFO,
434*5e3eaea3SApple OSS Distributions (task_info_t)&info,
435*5e3eaea3SApple OSS Distributions &size);
436*5e3eaea3SApple OSS Distributions RESULT_CHECK(kr, flavor, TASK_FLAVOR_NAME, "task_info");
437*5e3eaea3SApple OSS Distributions }
438*5e3eaea3SApple OSS Distributions }
439*5e3eaea3SApple OSS Distributions
440*5e3eaea3SApple OSS Distributions static void
test_thread_port_mig_intrans(thread_t tport,thread_flavor_t flavor)441*5e3eaea3SApple OSS Distributions test_thread_port_mig_intrans(
442*5e3eaea3SApple OSS Distributions thread_t tport,
443*5e3eaea3SApple OSS Distributions thread_flavor_t flavor)
444*5e3eaea3SApple OSS Distributions {
445*5e3eaea3SApple OSS Distributions kern_return_t kr;
446*5e3eaea3SApple OSS Distributions
447*5e3eaea3SApple OSS Distributions T_LOG("Testing various MIG/manual intrans thread interfaces with thread flavor %d", flavor);
448*5e3eaea3SApple OSS Distributions
449*5e3eaea3SApple OSS Distributions {
450*5e3eaea3SApple OSS Distributions /* 1. Test some control port interfaces */
451*5e3eaea3SApple OSS Distributions exception_mask_t masks[EXC_TYPES_COUNT] = {};
452*5e3eaea3SApple OSS Distributions mach_msg_type_number_t nmasks = 0;
453*5e3eaea3SApple OSS Distributions exception_port_t ports[EXC_TYPES_COUNT] = {};
454*5e3eaea3SApple OSS Distributions exception_behavior_t behaviors[EXC_TYPES_COUNT] = {};;
455*5e3eaea3SApple OSS Distributions thread_state_flavor_t flavors[EXC_TYPES_COUNT] = {};;
456*5e3eaea3SApple OSS Distributions kr = thread_get_exception_ports(tport, EXC_MASK_ALL,
457*5e3eaea3SApple OSS Distributions masks, &nmasks, ports, behaviors, flavors);
458*5e3eaea3SApple OSS Distributions RESULT_CHECK(kr, flavor, THREAD_FLAVOR_CONTROL, "thread_get_exception_ports");
459*5e3eaea3SApple OSS Distributions for (size_t i = 0; i < EXC_TYPES_COUNT; i++) {
460*5e3eaea3SApple OSS Distributions mach_port_deallocate(mach_task_self(), ports[i]);
461*5e3eaea3SApple OSS Distributions }
462*5e3eaea3SApple OSS Distributions }
463*5e3eaea3SApple OSS Distributions
464*5e3eaea3SApple OSS Distributions {
465*5e3eaea3SApple OSS Distributions /* 2. Test some read port interfaces */
466*5e3eaea3SApple OSS Distributions mach_voucher_t voucher = MACH_PORT_NULL;
467*5e3eaea3SApple OSS Distributions kr = thread_get_mach_voucher(tport, 0, &voucher);
468*5e3eaea3SApple OSS Distributions RESULT_CHECK(kr, flavor, THREAD_FLAVOR_READ, "thread_get_mach_voucher");
469*5e3eaea3SApple OSS Distributions mach_port_deallocate(mach_task_self(), voucher);
470*5e3eaea3SApple OSS Distributions }
471*5e3eaea3SApple OSS Distributions
472*5e3eaea3SApple OSS Distributions {
473*5e3eaea3SApple OSS Distributions /* 3. Test some inspect port interfaces */
474*5e3eaea3SApple OSS Distributions thread_qos_policy_t info;
475*5e3eaea3SApple OSS Distributions mach_msg_type_number_t count = THREAD_QOS_POLICY_COUNT;
476*5e3eaea3SApple OSS Distributions boolean_t get_default = FALSE;
477*5e3eaea3SApple OSS Distributions
478*5e3eaea3SApple OSS Distributions processor_set_name_t name = MACH_PORT_NULL;
479*5e3eaea3SApple OSS Distributions kr = thread_policy_get(tport, THREAD_QOS_POLICY,
480*5e3eaea3SApple OSS Distributions (thread_policy_t)&info, &count, &get_default);
481*5e3eaea3SApple OSS Distributions RESULT_CHECK(kr, flavor, THREAD_FLAVOR_INSPECT, "thread_policy_get");
482*5e3eaea3SApple OSS Distributions }
483*5e3eaea3SApple OSS Distributions }
484*5e3eaea3SApple OSS Distributions
485*5e3eaea3SApple OSS Distributions static void
test_get_child_task_port(void)486*5e3eaea3SApple OSS Distributions test_get_child_task_port(void)
487*5e3eaea3SApple OSS Distributions {
488*5e3eaea3SApple OSS Distributions pid_t child_pid;
489*5e3eaea3SApple OSS Distributions kern_return_t kr;
490*5e3eaea3SApple OSS Distributions mach_port_name_t tr, ti, tp, tn;
491*5e3eaea3SApple OSS Distributions
492*5e3eaea3SApple OSS Distributions child_pid = fork();
493*5e3eaea3SApple OSS Distributions
494*5e3eaea3SApple OSS Distributions T_LOG("Testing get child task ports");
495*5e3eaea3SApple OSS Distributions
496*5e3eaea3SApple OSS Distributions if (child_pid < 0) {
497*5e3eaea3SApple OSS Distributions T_FAIL("fork failed in test_get_child_port.");
498*5e3eaea3SApple OSS Distributions }
499*5e3eaea3SApple OSS Distributions
500*5e3eaea3SApple OSS Distributions if (child_pid == 0) {
501*5e3eaea3SApple OSS Distributions /* hang the child */
502*5e3eaea3SApple OSS Distributions while (1) {
503*5e3eaea3SApple OSS Distributions sleep(10);
504*5e3eaea3SApple OSS Distributions }
505*5e3eaea3SApple OSS Distributions }
506*5e3eaea3SApple OSS Distributions
507*5e3eaea3SApple OSS Distributions kr = task_for_pid(mach_task_self(), child_pid, &tp);
508*5e3eaea3SApple OSS Distributions T_QUIET; T_EXPECT_MACH_SUCCESS(kr, "task_for_pid for child %u", child_pid);
509*5e3eaea3SApple OSS Distributions
510*5e3eaea3SApple OSS Distributions kr = task_read_for_pid(mach_task_self(), child_pid, &tr);
511*5e3eaea3SApple OSS Distributions T_QUIET; T_EXPECT_MACH_SUCCESS(kr, "task_read_for_pid for child %u", child_pid);
512*5e3eaea3SApple OSS Distributions
513*5e3eaea3SApple OSS Distributions kr = task_inspect_for_pid(mach_task_self(), child_pid, &ti);
514*5e3eaea3SApple OSS Distributions T_QUIET; T_EXPECT_MACH_SUCCESS(kr, "task_inspect_for_pid for child %u", child_pid);
515*5e3eaea3SApple OSS Distributions
516*5e3eaea3SApple OSS Distributions kr = task_name_for_pid(mach_task_self(), child_pid, &tn);
517*5e3eaea3SApple OSS Distributions T_QUIET; T_EXPECT_MACH_SUCCESS(kr, "task_name_for_pid for child %u", child_pid);
518*5e3eaea3SApple OSS Distributions
519*5e3eaea3SApple OSS Distributions mach_port_deallocate(mach_task_self(), tp);
520*5e3eaea3SApple OSS Distributions mach_port_deallocate(mach_task_self(), tr);
521*5e3eaea3SApple OSS Distributions mach_port_deallocate(mach_task_self(), ti);
522*5e3eaea3SApple OSS Distributions mach_port_deallocate(mach_task_self(), tn);
523*5e3eaea3SApple OSS Distributions
524*5e3eaea3SApple OSS Distributions kill(child_pid, SIGKILL);
525*5e3eaea3SApple OSS Distributions int status;
526*5e3eaea3SApple OSS Distributions wait(&status);
527*5e3eaea3SApple OSS Distributions }
528*5e3eaea3SApple OSS Distributions
529*5e3eaea3SApple OSS Distributions T_DECL(read_inspect, "Test critical read and inspect port interfaces")
530*5e3eaea3SApple OSS Distributions {
531*5e3eaea3SApple OSS Distributions mach_port_t control_port, movable_port, read_port, inspect_port, name_port;
532*5e3eaea3SApple OSS Distributions mach_port_t th_control_port, th_movable_port, th_read_port, th_inspect_port;
533*5e3eaea3SApple OSS Distributions #define TASK_PORT_COUNT 5
534*5e3eaea3SApple OSS Distributions #define THREAD_PORT_COUNT 4
535*5e3eaea3SApple OSS Distributions mach_port_t task_ports[TASK_PORT_COUNT];
536*5e3eaea3SApple OSS Distributions task_flavor_t task_flavors[TASK_PORT_COUNT];
537*5e3eaea3SApple OSS Distributions mach_port_t thread_ports[THREAD_PORT_COUNT];
538*5e3eaea3SApple OSS Distributions thread_flavor_t thread_flavors[THREAD_PORT_COUNT];
539*5e3eaea3SApple OSS Distributions kern_return_t kr;
540*5e3eaea3SApple OSS Distributions
541*5e3eaea3SApple OSS Distributions /* first, try getting all flavors of task port for self */
542*5e3eaea3SApple OSS Distributions kr = task_for_pid(mach_task_self(), getpid(), &control_port);
543*5e3eaea3SApple OSS Distributions T_QUIET; T_ASSERT_MACH_SUCCESS(kr, "task_for_pid()");
544*5e3eaea3SApple OSS Distributions task_ports[0] = control_port;
545*5e3eaea3SApple OSS Distributions task_flavors[0] = TASK_FLAVOR_CONTROL;
546*5e3eaea3SApple OSS Distributions
547*5e3eaea3SApple OSS Distributions kr = task_get_special_port(mach_task_self(), TASK_KERNEL_PORT, &movable_port);
548*5e3eaea3SApple OSS Distributions T_QUIET; T_ASSERT_MACH_SUCCESS(kr, "task_get_special_port(..TASK_KERNEL_PORT..)");
549*5e3eaea3SApple OSS Distributions task_ports[1] = movable_port;
550*5e3eaea3SApple OSS Distributions task_flavors[1] = TASK_FLAVOR_CONTROL;
551*5e3eaea3SApple OSS Distributions
552*5e3eaea3SApple OSS Distributions kr = task_read_for_pid(mach_task_self(), getpid(), &read_port);
553*5e3eaea3SApple OSS Distributions T_QUIET; T_ASSERT_MACH_SUCCESS(kr, "task_read_for_pid()");
554*5e3eaea3SApple OSS Distributions task_ports[2] = read_port;
555*5e3eaea3SApple OSS Distributions task_flavors[2] = TASK_FLAVOR_READ;
556*5e3eaea3SApple OSS Distributions
557*5e3eaea3SApple OSS Distributions kr = task_inspect_for_pid(mach_task_self(), getpid(), &inspect_port);
558*5e3eaea3SApple OSS Distributions T_QUIET; T_ASSERT_MACH_SUCCESS(kr, "task_inspect_for_pid()");
559*5e3eaea3SApple OSS Distributions task_ports[3] = inspect_port;
560*5e3eaea3SApple OSS Distributions task_flavors[3] = TASK_FLAVOR_INSPECT;
561*5e3eaea3SApple OSS Distributions
562*5e3eaea3SApple OSS Distributions kr = task_name_for_pid(mach_task_self(), getpid(), &name_port);
563*5e3eaea3SApple OSS Distributions T_QUIET; T_ASSERT_MACH_SUCCESS(kr, "task_name_for_pid()");
564*5e3eaea3SApple OSS Distributions task_ports[4] = name_port;
565*5e3eaea3SApple OSS Distributions task_flavors[4] = TASK_FLAVOR_NAME;
566*5e3eaea3SApple OSS Distributions
567*5e3eaea3SApple OSS Distributions
568*5e3eaea3SApple OSS Distributions for (size_t i = 0; i < TASK_PORT_COUNT; i++) {
569*5e3eaea3SApple OSS Distributions /*
570*5e3eaea3SApple OSS Distributions * 1. Make sure can't get higher priv'ed ports from lower ones through
571*5e3eaea3SApple OSS Distributions * task_get_special_port()
572*5e3eaea3SApple OSS Distributions */
573*5e3eaea3SApple OSS Distributions test_task_get_special_port(task_ports[i], task_flavors[i]);
574*5e3eaea3SApple OSS Distributions
575*5e3eaea3SApple OSS Distributions /*
576*5e3eaea3SApple OSS Distributions * 2. Make sure correct level of thread ports are returned from task_threads
577*5e3eaea3SApple OSS Distributions */
578*5e3eaea3SApple OSS Distributions test_task_threads(task_ports[i], task_flavors[i]);
579*5e3eaea3SApple OSS Distributions
580*5e3eaea3SApple OSS Distributions /*
581*5e3eaea3SApple OSS Distributions * 3. Make sure correct level of task ports are returned from processor_set_tasks
582*5e3eaea3SApple OSS Distributions */
583*5e3eaea3SApple OSS Distributions if (i >= 1) {
584*5e3eaea3SApple OSS Distributions test_processor_set_tasks(task_flavors[i]);
585*5e3eaea3SApple OSS Distributions }
586*5e3eaea3SApple OSS Distributions
587*5e3eaea3SApple OSS Distributions /*
588*5e3eaea3SApple OSS Distributions * 4. Make sure our MIG intrans enforcement for tasks does not break.
589*5e3eaea3SApple OSS Distributions */
590*5e3eaea3SApple OSS Distributions test_task_port_mig_intrans(task_ports[i], task_flavors[i]);
591*5e3eaea3SApple OSS Distributions }
592*5e3eaea3SApple OSS Distributions
593*5e3eaea3SApple OSS Distributions
594*5e3eaea3SApple OSS Distributions for (size_t i = 0; i < TASK_PORT_COUNT; i++) {
595*5e3eaea3SApple OSS Distributions mach_port_deallocate(mach_task_self(), task_ports[i]);
596*5e3eaea3SApple OSS Distributions }
597*5e3eaea3SApple OSS Distributions
598*5e3eaea3SApple OSS Distributions /* 4. Try spawning a child an get its task ports */
599*5e3eaea3SApple OSS Distributions test_get_child_task_port();
600*5e3eaea3SApple OSS Distributions
601*5e3eaea3SApple OSS Distributions /* Now, test thread read/inspect ports */
602*5e3eaea3SApple OSS Distributions th_control_port = mach_thread_self();
603*5e3eaea3SApple OSS Distributions thread_ports[0] = th_control_port;
604*5e3eaea3SApple OSS Distributions thread_flavors[0] = THREAD_FLAVOR_CONTROL;
605*5e3eaea3SApple OSS Distributions
606*5e3eaea3SApple OSS Distributions kr = thread_get_special_port(th_control_port, THREAD_KERNEL_PORT, &th_movable_port);
607*5e3eaea3SApple OSS Distributions T_QUIET; T_ASSERT_MACH_SUCCESS(kr, "thread_get_special_port(..THREAD_KERNEL_PORT..)");
608*5e3eaea3SApple OSS Distributions thread_ports[1] = th_movable_port;
609*5e3eaea3SApple OSS Distributions thread_flavors[1] = THREAD_FLAVOR_CONTROL;
610*5e3eaea3SApple OSS Distributions
611*5e3eaea3SApple OSS Distributions kr = thread_get_special_port(th_control_port, THREAD_READ_PORT, &th_read_port);
612*5e3eaea3SApple OSS Distributions T_QUIET; T_ASSERT_MACH_SUCCESS(kr, "thread_get_special_port(..THREAD_READ_PORT..)");
613*5e3eaea3SApple OSS Distributions thread_ports[2] = th_read_port;
614*5e3eaea3SApple OSS Distributions thread_flavors[2] = THREAD_FLAVOR_READ;
615*5e3eaea3SApple OSS Distributions
616*5e3eaea3SApple OSS Distributions kr = thread_get_special_port(th_control_port, THREAD_INSPECT_PORT, &th_inspect_port);
617*5e3eaea3SApple OSS Distributions T_QUIET; T_ASSERT_MACH_SUCCESS(kr, "thread_get_special_port(..THREAD_INSPECT_PORT..)");
618*5e3eaea3SApple OSS Distributions thread_ports[3] = th_inspect_port;
619*5e3eaea3SApple OSS Distributions thread_flavors[3] = THREAD_FLAVOR_INSPECT;
620*5e3eaea3SApple OSS Distributions
621*5e3eaea3SApple OSS Distributions
622*5e3eaea3SApple OSS Distributions for (size_t i = 0; i < THREAD_PORT_COUNT; i++) {
623*5e3eaea3SApple OSS Distributions /*
624*5e3eaea3SApple OSS Distributions * 1. Make sure can't get higher priv'ed ports from lower ones through
625*5e3eaea3SApple OSS Distributions * thread_get_special_port()
626*5e3eaea3SApple OSS Distributions */
627*5e3eaea3SApple OSS Distributions test_thread_get_special_port(thread_ports[i], thread_flavors[i]);
628*5e3eaea3SApple OSS Distributions
629*5e3eaea3SApple OSS Distributions /*
630*5e3eaea3SApple OSS Distributions * 2. Make sure our MIG intrans enforcement for threads does not break.
631*5e3eaea3SApple OSS Distributions */
632*5e3eaea3SApple OSS Distributions test_thread_port_mig_intrans(thread_ports[i], thread_flavors[i]);
633*5e3eaea3SApple OSS Distributions }
634*5e3eaea3SApple OSS Distributions
635*5e3eaea3SApple OSS Distributions for (size_t i = 0; i < THREAD_PORT_COUNT; i++) {
636*5e3eaea3SApple OSS Distributions mach_port_deallocate(mach_task_self(), thread_ports[i]);
637*5e3eaea3SApple OSS Distributions }
638*5e3eaea3SApple OSS Distributions }
639