1 diff -urN system_cmds-880.60.2/lsmp.tproj/common.h system_cmds-880.100.5/lsmp.tproj/common.h
2 --- system_cmds-880.60.2/lsmp.tproj/common.h 2020-05-26 14:16:58.000000000 -0400
3 +++ system_cmds-880.100.5/lsmp.tproj/common.h 2021-01-15 00:52:22.000000000 -0500
5 #define system_cmds_common_h
8 +#include <mach_debug/ipc_info.h>
11 #define PROC_NAME_LEN 100
13 /* exception port information */
14 struct exc_port_info {
15 mach_msg_type_number_t count;
16 - mach_port_t ports[EXC_TYPES_COUNT];
17 + ipc_info_port_t ports_info[EXC_TYPES_COUNT];
18 exception_mask_t masks[EXC_TYPES_COUNT];
19 exception_behavior_t behaviors[EXC_TYPES_COUNT];
20 thread_state_flavor_t flavors[EXC_TYPES_COUNT];
23 /* private structure to wrap up per-task info */
24 typedef struct my_per_task_info {
28 vm_address_t task_kobject;
29 ipc_info_space_t info;
32 /* mach port related functions */
33 const char * kobject_name(natural_t kotype);
34 -void get_receive_port_context(task_t taskp, mach_port_name_t portname, mach_port_context_t *context);
35 -int get_recieve_port_status(task_t taskp, mach_port_name_t portname, mach_port_info_ext_t *info);
36 +void get_receive_port_context(task_read_t taskp, mach_port_name_t portname, mach_port_context_t *context);
37 +int get_recieve_port_status(task_read_t taskp, mach_port_name_t portname, mach_port_info_ext_t *info);
38 void show_task_mach_ports(my_per_task_info_t *taskinfo, uint32_t taskCount, my_per_task_info_t *allTaskInfos, JSON_t json);
40 /* task and thread related helper functions */
41 -kern_return_t collect_per_task_info(my_per_task_info_t *taskinfo, task_t target_task);
42 +kern_return_t collect_per_task_info(my_per_task_info_t *taskinfo, task_read_t target_task);
43 my_per_task_info_t * allocate_taskinfo_memory(uint32_t taskCount);
44 void deallocate_taskinfo_memory(my_per_task_info_t *data);
45 kern_return_t print_task_exception_info(my_per_task_info_t *taskinfo, JSON_t json);
48 void get_exc_behavior_string(exception_behavior_t b, char *out_string, size_t len);
49 void get_exc_mask_string(exception_mask_t m, char *out_string, size_t len);
50 -kern_return_t get_taskinfo_of_receiver_by_send_right(ipc_info_name_t *sendright, my_per_task_info_t **out_taskinfo, mach_port_name_t *out_recv_info);
51 -kern_return_t get_ipc_info_from_lsmp_spaceinfo(mach_port_t port_name, ipc_info_name_t *out_sendright);
52 +kern_return_t get_taskinfo_of_receiver_by_send_right(ipc_info_name_t sendright, my_per_task_info_t **out_taskinfo, mach_port_name_t *out_recv_info);
53 +kern_return_t get_taskinfo_of_receiver_by_send_right_info(ipc_info_port_t sendright_info, my_per_task_info_t **out_taskinfo, mach_port_name_t *out_recv_info);
55 /* basic util functions */
56 uint32_t print_hex_data(char *outstr, uint32_t maxlen, char *prefix, char *desc, void *addr, int len);
57 diff -urN system_cmds-880.60.2/lsmp.tproj/entitlements.plist system_cmds-880.100.5/lsmp.tproj/entitlements.plist
58 --- system_cmds-880.60.2/lsmp.tproj/entitlements.plist 2015-07-21 20:13:05.000000000 -0400
59 +++ system_cmds-880.100.5/lsmp.tproj/entitlements.plist 2021-01-15 00:52:22.000000000 -0500
61 <!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
64 - <key>task_for_pid-allow</key>
66 - <key>com.apple.system-task-ports</key>
67 + <key>com.apple.system-task-ports.read</key>
71 diff -urN system_cmds-880.60.2/lsmp.tproj/lsmp.c system_cmds-880.100.5/lsmp.tproj/lsmp.c
72 --- system_cmds-880.60.2/lsmp.tproj/lsmp.c 2019-04-09 18:58:12.000000000 -0400
73 +++ system_cmds-880.100.5/lsmp.tproj/lsmp.c 2021-01-15 00:52:22.000000000 -0500
76 * @APPLE_LICENSE_HEADER_END@
78 +#include <System/sys/proc.h>
80 #include <mach/mach.h>
81 #include <mach/mach_error.h>
85 #if (TARGET_OS_IPHONE && !TARGET_OS_SIMULATOR)
86 -#define TASK_FOR_PID_USAGE_MESG "\nPlease check your boot-args to ensure you have access to task_for_pid()."
87 +#define TASK_FOR_PID_USAGE_MESG "\nPlease check your boot-args to ensure you have access to task_read_for_pid()."
89 #define TASK_FOR_PID_USAGE_MESG ""
93 int main(int argc, char *argv[]) {
97 my_per_task_info_t *taskinfo = NULL;
99 char *progname = "lsmp";
100 @@ -153,10 +154,10 @@
101 mach_port_deallocate(mach_task_self(), psets[0]);
102 vm_deallocate(mach_task_self(), (vm_address_t)psets, (vm_size_t)psetCount * sizeof(mach_port_t));
104 - /* convert the processor-set-priv to a list of tasks for the processor set */
105 - ret = processor_set_tasks(pset_priv, &tasks, &taskCount);
106 + /* convert the processor-set-priv to a list of task read ports for the processor set */
107 + ret = processor_set_tasks_with_flavor(pset_priv, TASK_FLAVOR_READ, &tasks, &taskCount);
108 if (ret != KERN_SUCCESS) {
109 - fprintf(stderr, "processor_set_tasks() failed: %s\n", mach_error_string(ret));
110 + fprintf(stderr, "processor_set_tasks_with_flavor() failed: %s\n", mach_error_string(ret));
113 mach_port_deallocate(mach_task_self(), pset_priv);
115 /* swap my current instances port to be last to collect all threads and exception port info */
116 int myTaskPosition = -1;
117 for (int i = 0; i < taskCount; i++) {
118 - if (tasks[i] == mach_task_self()){
119 + if (mach_task_is_self(tasks[i])){
125 fprintf(stderr, "warning: should run as root for best output (cross-ref to other tasks' ports).\n");
126 /* just the one process */
127 - ret = task_for_pid(mach_task_self(), lsmp_config.pid, &aTask);
128 + ret = task_read_for_pid(mach_task_self(), lsmp_config.pid, &aTask);
129 if (ret != KERN_SUCCESS) {
130 fprintf(stderr, "task_for_pid() failed: %s %s\n", mach_error_string(ret), TASK_FOR_PID_USAGE_MESG);
136 - if (psettaskinfo[i].pid == lsmp_config.pid)
137 + if (psettaskinfo[i].pid == lsmp_config.pid) {
138 taskinfo = &psettaskinfo[i];
142 JSON_OBJECT_BEGIN(lsmp_config.json_output);
143 diff -urN system_cmds-880.60.2/lsmp.tproj/port_details.c system_cmds-880.100.5/lsmp.tproj/port_details.c
144 --- system_cmds-880.60.2/lsmp.tproj/port_details.c 2020-05-26 14:16:58.000000000 -0400
145 +++ system_cmds-880.100.5/lsmp.tproj/port_details.c 2021-01-15 00:52:22.000000000 -0500
147 return voucher_outstr;
150 -void get_receive_port_context(task_t taskp, mach_port_name_t portname, mach_port_context_t *context) {
151 +void get_receive_port_context(task_read_t taskp, mach_port_name_t portname, mach_port_context_t *context) {
152 if (context == NULL) {
159 -int get_recieve_port_status(task_t taskp, mach_port_name_t portname, mach_port_info_ext_t *info){
160 +int get_recieve_port_status(task_read_t taskp, mach_port_name_t portname, mach_port_info_ext_t *info){
164 @@ -625,13 +625,19 @@
165 if (ret == KERN_SUCCESS && kotype != 0) {
166 JSON_OBJECT_SET(json, identifier, "0x%08x", (natural_t)kobject);
167 JSON_OBJECT_SET(json, type, "%s", kobject_name(kotype));
169 - JSON_OBJECT_SET(json, description, "%s", desc);
170 - printf(" 0x%08x %s %s", (natural_t)kobject, kobject_name(kotype), desc);
172 - printf(" 0x%08x %s", (natural_t)kobject, kobject_name(kotype));
174 - if ((kotype == IKOT_TASK_RESUME) || (kotype == IKOT_TASK_CONTROL) || (kotype == IKOT_TASK_NAME)) {
177 + JSON_OBJECT_SET(json, description, "%s", desc);
178 + printf(" 0x%08x %s %s", (natural_t)kobject, kobject_name(kotype), desc);
180 + printf(" 0x%08x %s", (natural_t)kobject, kobject_name(kotype));
183 + if ((kotype == IKOT_TASK_RESUME) ||
184 + (kotype == IKOT_TASK_CONTROL) ||
185 + (kotype == IKOT_TASK_READ) ||
186 + (kotype == IKOT_TASK_INSPECT) ||
187 + (kotype == IKOT_TASK_NAME)) {
188 if (taskinfo->task_kobject == kobject) {
189 /* neat little optimization since in most cases tasks have themselves in their ipc space */
190 JSON_OBJECT_SET(json, pid, %d, taskinfo->pid);
195 - if (kotype == IKOT_THREAD_CONTROL) {
196 + if ((kotype == IKOT_THREAD_CONTROL) ||
197 + (kotype == IKOT_THREAD_READ) ||
198 + (kotype == IKOT_THREAD_INSPECT)) {
199 for (int i = 0; i < taskinfo->threadCount; i++) {
200 if (taskinfo->threadInfos[i].th_kobject == kobject) {
201 printf(" (%#llx)", taskinfo->threadInfos[i].th_id);
203 /* not kobject - find the receive right holder */
204 my_per_task_info_t *recv_holder_taskinfo;
205 mach_port_name_t recv_name = MACH_PORT_NULL;
206 - if (KERN_SUCCESS == get_taskinfo_of_receiver_by_send_right(entry, &recv_holder_taskinfo, &recv_name)) {
207 + if (KERN_SUCCESS == get_taskinfo_of_receiver_by_send_right(*entry, &recv_holder_taskinfo, &recv_name)) {
208 mach_port_status_t port_status;
209 mach_port_info_ext_t info;
210 mach_port_context_t port_context = (mach_port_context_t)0;
211 diff -urN system_cmds-880.60.2/lsmp.tproj/task_details.c system_cmds-880.100.5/lsmp.tproj/task_details.c
212 --- system_cmds-880.60.2/lsmp.tproj/task_details.c 2020-05-26 14:16:58.000000000 -0400
213 +++ system_cmds-880.100.5/lsmp.tproj/task_details.c 2021-01-15 00:52:22.000000000 -0500
218 -kern_return_t collect_per_task_info(my_per_task_info_t *taskinfo, task_t target_task)
219 +kern_return_t collect_per_task_info(my_per_task_info_t *taskinfo, task_read_t target_task)
222 kern_return_t ret = KERN_SUCCESS;
223 @@ -149,10 +149,10 @@
224 taskinfo->task = target_task;
225 pid_for_task(target_task, &taskinfo->pid);
227 - ret = task_get_exception_ports(taskinfo->task, EXC_MASK_ALL, taskinfo->exceptionInfo.masks, &taskinfo->exceptionInfo.count, taskinfo->exceptionInfo.ports, taskinfo->exceptionInfo.behaviors, taskinfo->exceptionInfo.flavors);
228 + ret = task_get_exception_ports_info(taskinfo->task, EXC_MASK_ALL, taskinfo->exceptionInfo.masks, &taskinfo->exceptionInfo.count, taskinfo->exceptionInfo.ports_info, taskinfo->exceptionInfo.behaviors, taskinfo->exceptionInfo.flavors);
230 if (ret != KERN_SUCCESS) {
231 - fprintf(stderr, "task_get_exception_ports() failed: pid:%d error: %s\n",taskinfo->pid, mach_error_string(ret));
232 + fprintf(stderr, "task_get_exception_ports_info() failed: pid:%d error: %s\n",taskinfo->pid, mach_error_string(ret));
237 mach_msg_type_number_t th_info_count = THREAD_IDENTIFIER_INFO_COUNT;
238 struct exc_port_info *excinfo = &(taskinfo->threadExceptionInfos[i]);
240 - ret = thread_get_exception_ports(threadPorts[i], EXC_MASK_ALL, excinfo->masks, &excinfo->count, excinfo->ports, excinfo->behaviors, excinfo->flavors);
241 + ret = thread_get_exception_ports_info(threadPorts[i], EXC_MASK_ALL, excinfo->masks, &excinfo->count, excinfo->ports_info, excinfo->behaviors, excinfo->flavors);
242 if (ret != KERN_SUCCESS){
243 - fprintf(stderr, "thread_get_exception_ports() failed: pid: %d thread: %d error %s\n", taskinfo->pid, threadPorts[i], mach_error_string(ret));
244 + fprintf(stderr, "thread_get_exception_ports_info() failed: pid: %d thread: %d error %s\n", taskinfo->pid, threadPorts[i], mach_error_string(ret));
247 if (excinfo->count != 0) {
249 proc_pid_to_name(taskinfo->pid, taskinfo->processName);
251 ret = mach_port_kernel_object(mach_task_self(), taskinfo->task, &kotype, (unsigned *)&kobject);
253 - if (ret == KERN_SUCCESS && kotype == IKOT_TASK_CONTROL) {
255 + /* Now that we are using read ports, kotype should be checked against IKOT_TASK_READ */
256 + if (ret == KERN_SUCCESS && kotype == IKOT_TASK_READ) {
257 taskinfo->task_kobject = kobject;
258 taskinfo->valid = TRUE;
260 @@ -307,23 +308,32 @@
262 boolean_t header_required = TRUE;
263 for (int i = 0; i < taskinfo->exceptionInfo.count; i++) {
264 - if (taskinfo->exceptionInfo.ports[i] != MACH_PORT_NULL) {
265 + if (taskinfo->exceptionInfo.ports_info[i].iip_port_object != 0) {
266 + my_per_task_info_t * _found_task;
268 if (header_required) {
270 - printf(" exc_port flavor <behaviors> mask \n");
271 + printf(" exc_port_object receiver_task flavor <behaviors> mask \n");
272 header_required = FALSE;
274 get_exc_behavior_string(taskinfo->exceptionInfo.behaviors[i], behavior_string, sizeof(behavior_string));
275 get_exc_mask_string(taskinfo->exceptionInfo.masks[i], mask_string, sizeof(mask_string));
277 JSON_OBJECT_BEGIN(json);
278 - JSON_OBJECT_SET(json, port, "0x%08x", taskinfo->exceptionInfo.ports[i]);
279 + JSON_OBJECT_SET(json, port_object, "0x%08x", taskinfo->exceptionInfo.ports_info[i].iip_port_object);
280 + JSON_OBJECT_SET(json, receiver_object, "0x%08x", taskinfo->exceptionInfo.ports_info[i].iip_receiver_object);
281 JSON_OBJECT_SET(json, flavor, "0x%03x", taskinfo->exceptionInfo.flavors[i]);
282 JSON_OBJECT_SET(json, behavior, "%s", behavior_string);
283 JSON_OBJECT_SET(json, mask, "%s", mask_string);
284 JSON_OBJECT_END(json); // exception port
286 - printf(" 0x%08x 0x%03x <%s> %s \n" , taskinfo->exceptionInfo.ports[i], taskinfo->exceptionInfo.flavors[i], behavior_string, mask_string);
288 + _found_task = get_taskinfo_by_kobject((natural_t)taskinfo->exceptionInfo.ports_info[i].iip_receiver_object);
290 + printf(" 0x%08x (%d) %s 0x%03x <%s> %s \n",
291 + taskinfo->exceptionInfo.ports_info[i].iip_port_object,
293 + _found_task->processName,
294 + taskinfo->exceptionInfo.flavors[i], behavior_string, mask_string);
298 @@ -389,39 +399,35 @@
299 for (int i = 0; i < excinfo->count; i++) {
300 JSON_OBJECT_BEGIN(json);
302 - if (excinfo->ports[i] != MACH_PORT_NULL) {
303 + if (excinfo->ports_info[i].iip_port_object != 0) {
304 if (header_required) {
305 - printf("\n exc_port flavor <behaviors> mask -> name owner\n");
306 + printf("\n exc_port_object exc_port_receiver flavor <behaviors> mask -> name owner\n");
307 header_required = FALSE;
309 get_exc_behavior_string(excinfo->behaviors[i], behavior_string, sizeof(behavior_string));
310 get_exc_mask_string(excinfo->masks[i], mask_string, sizeof(mask_string));
312 - JSON_OBJECT_SET(json, port, "0x%08x", excinfo->ports[i]);
313 + JSON_OBJECT_SET(json, port_object, "0x%08x", excinfo->ports_info[i].iip_port_object);
314 + JSON_OBJECT_SET(json, receiver_object, "0x%08x", excinfo->ports_info[i].iip_receiver_object);
315 JSON_OBJECT_SET(json, flavor, "0x%03x", excinfo->flavors[i]);
316 JSON_OBJECT_SET(json, behavior, "%s", behavior_string);
317 JSON_OBJECT_SET(json, mask, "%s", mask_string);
319 - printf(" 0x%08x 0x%03x <%s> %s " , excinfo->ports[i], excinfo->flavors[i], behavior_string, mask_string);
320 + printf(" 0x%08x 0x%08x 0x%03x <%s> %s " , excinfo->ports_info[i].iip_port_object, excinfo->ports_info[i].iip_receiver_object, excinfo->flavors[i], behavior_string, mask_string);
322 - ipc_info_name_t actual_sendinfo;
323 - if (KERN_SUCCESS == get_ipc_info_from_lsmp_spaceinfo(excinfo->ports[i], &actual_sendinfo)) {
324 - my_per_task_info_t *recv_holder_taskinfo;
325 - mach_port_name_t recv_name = MACH_PORT_NULL;
326 - if (KERN_SUCCESS == get_taskinfo_of_receiver_by_send_right(&actual_sendinfo, &recv_holder_taskinfo, &recv_name)) {
327 + my_per_task_info_t *recv_holder_taskinfo;
328 + mach_port_name_t recv_name = MACH_PORT_NULL;
329 + if (KERN_SUCCESS == get_taskinfo_of_receiver_by_send_right_info(excinfo->ports_info[i], &recv_holder_taskinfo, &recv_name)) {
330 + JSON_OBJECT_SET(json, name, "0x%08x", recv_name);
331 + JSON_OBJECT_SET(json, ipc-object, "0x%08x", excinfo->ports_info[i].iip_port_object);
332 + JSON_OBJECT_SET(json, pid, %d, recv_holder_taskinfo->pid);
333 + JSON_OBJECT_SET(json, process, "%s", recv_holder_taskinfo->processName);
335 - JSON_OBJECT_SET(json, name, "0x%08x", recv_name);
336 - JSON_OBJECT_SET(json, ipc-object, "0x%08x", actual_sendinfo.iin_object);
337 - JSON_OBJECT_SET(json, pid, %d, recv_holder_taskinfo->pid);
338 - JSON_OBJECT_SET(json, process, "%s", recv_holder_taskinfo->processName);
340 - printf(" -> 0x%08x 0x%08x (%d) %s\n",
342 - actual_sendinfo.iin_object,
343 - recv_holder_taskinfo->pid,
344 - recv_holder_taskinfo->processName);
347 + printf(" -> 0x%08x 0x%08x (%d) %s\n",
349 + excinfo->ports_info[i].iip_port_object,
350 + recv_holder_taskinfo->pid,
351 + recv_holder_taskinfo->processName);
353 fprintf(stderr, "failed to find");
355 @@ -463,14 +469,14 @@
359 -kern_return_t get_taskinfo_of_receiver_by_send_right(ipc_info_name_t *sendright, my_per_task_info_t **out_taskinfo, mach_port_name_t *out_recv_info)
360 +static kern_return_t _get_taskinfo_of_receiver_by_send_right(natural_t kobject, my_per_task_info_t **out_taskinfo, mach_port_name_t *out_recv_info)
362 *out_taskinfo = &NOT_FOUND_TASK_INFO;
363 struct k2n_table_node *k2nnode;
365 - for (int j = 0; j < global_taskcount; j++) {
366 - if ((k2nnode = k2n_table_lookup(global_taskinfo[j].k2ntable, sendright->iin_object))) {
367 - assert(k2nnode->info_name->iin_object == sendright->iin_object);
368 + for (unsigned int j = 0; j < global_taskcount; j++) {
369 + if ((k2nnode = k2n_table_lookup(global_taskinfo[j].k2ntable, kobject))) {
370 + assert(k2nnode->info_name->iin_object == kobject);
372 if (k2nnode->info_name->iin_type & MACH_PORT_TYPE_RECEIVE) {
373 *out_taskinfo = &global_taskinfo[j];
374 @@ -483,25 +489,12 @@
378 -kern_return_t get_ipc_info_from_lsmp_spaceinfo(mach_port_t port_name, ipc_info_name_t *out_sendright){
379 - kern_return_t retval = KERN_FAILURE;
380 - bzero(out_sendright, sizeof(ipc_info_name_t));
381 - my_per_task_info_t *mytaskinfo = NULL;
382 - for (int i = global_taskcount - 1; i >= 0; i--){
383 - if (global_taskinfo[i].task == mach_task_self()){
384 - mytaskinfo = &global_taskinfo[i];
389 - for (int k = 0; k < mytaskinfo->tableCount; k++) {
390 - if (port_name == mytaskinfo->table[k].iin_name){
391 - bcopy(&mytaskinfo->table[k], out_sendright, sizeof(ipc_info_name_t));
392 - retval = KERN_SUCCESS;
398 +kern_return_t get_taskinfo_of_receiver_by_send_right(ipc_info_name_t sendright, my_per_task_info_t **out_taskinfo, mach_port_name_t *out_recv_info)
400 + return _get_taskinfo_of_receiver_by_send_right(sendright.iin_object, out_taskinfo, out_recv_info);
403 +kern_return_t get_taskinfo_of_receiver_by_send_right_info(ipc_info_port_t sendright_info, my_per_task_info_t **out_taskinfo, mach_port_name_t *out_recv_info)
405 + return _get_taskinfo_of_receiver_by_send_right(sendright_info.iip_port_object, out_taskinfo, out_recv_info);