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