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