xref: /xnu-11417.140.69/bsd/dev/dtrace/scripts/vm_object_ownership.d (revision 43a90889846e00bfb5cf1d255cdc0a701a1e05a4)
1*43a90889SApple OSS Distributions #!/usr/sbin/dtrace -s
2*43a90889SApple OSS Distributions 
3*43a90889SApple OSS Distributions vminfo:::object_ownership_change
4*43a90889SApple OSS Distributions {
5*43a90889SApple OSS Distributions 	old_owner = (task_t)arg1;
6*43a90889SApple OSS Distributions 	if (old_owner == 0) {
7*43a90889SApple OSS Distributions 		old_pid = -1;
8*43a90889SApple OSS Distributions 		old_name = "(nil)";
9*43a90889SApple OSS Distributions 	} else {
10*43a90889SApple OSS Distributions 		old_proc = xlate <psinfo_t *>((proc_t)old_owner->t_tro->tro_proc);
11*43a90889SApple OSS Distributions 		old_pid = old_proc->pr_pid;
12*43a90889SApple OSS Distributions 		old_name = old_proc->pr_fname;
13*43a90889SApple OSS Distributions 	}
14*43a90889SApple OSS Distributions 	new_owner = (task_t)arg4;
15*43a90889SApple OSS Distributions 	if (new_owner == 0) {
16*43a90889SApple OSS Distributions 		new_pid = -1;
17*43a90889SApple OSS Distributions 		new_name = "(nil)";
18*43a90889SApple OSS Distributions 	} else {
19*43a90889SApple OSS Distributions 		new_proc = xlate <psinfo_t *>((proc_t)new_owner->t_tro->tro_proc);
20*43a90889SApple OSS Distributions 		new_pid = new_proc->pr_pid;
21*43a90889SApple OSS Distributions 		new_name = new_proc->pr_fname;
22*43a90889SApple OSS Distributions 	}
23*43a90889SApple OSS Distributions 
24*43a90889SApple OSS Distributions 	printf("%d[%s] object 0x%p id 0x%x purgeable:%d owner:0x%p (%d[%s]) tag:%d nofootprint:%d -> owner:0x%p (%d[%s]) tag:%d nofootprint:%d",
25*43a90889SApple OSS Distributions 	       pid, execname, arg0, arg7, ((vm_object_t)arg0)->purgable,
26*43a90889SApple OSS Distributions 	       old_owner, old_pid, old_name,
27*43a90889SApple OSS Distributions 	       arg2, arg3,
28*43a90889SApple OSS Distributions 	       new_owner, new_pid, new_name,
29*43a90889SApple OSS Distributions 	       arg5, arg6);
30*43a90889SApple OSS Distributions 	stack();
31*43a90889SApple OSS Distributions 	ustack();
32*43a90889SApple OSS Distributions }
33