Lines Matching refs:father
517 static struct task_struct *find_child_reaper(struct task_struct *father, in find_child_reaper() argument
522 struct pid_namespace *pid_ns = task_active_pid_ns(father); in find_child_reaper()
526 if (likely(reaper != father)) in find_child_reaper()
529 reaper = find_alive_thread(father); in find_child_reaper()
545 return father; in find_child_reaper()
555 static struct task_struct *find_new_reaper(struct task_struct *father, in find_new_reaper() argument
560 thread = find_alive_thread(father); in find_new_reaper()
564 if (father->signal->has_child_subreaper) { in find_new_reaper()
565 unsigned int ns_level = task_pid(father)->level; in find_new_reaper()
574 for (reaper = father->real_parent; in find_new_reaper()
593 static void reparent_leader(struct task_struct *father, struct task_struct *p, in reparent_leader() argument
611 kill_orphaned_pgrp(p, father); in reparent_leader()
622 static void forget_original_parent(struct task_struct *father, in forget_original_parent() argument
627 if (unlikely(!list_empty(&father->ptraced))) in forget_original_parent()
628 exit_ptrace(father, dead); in forget_original_parent()
631 reaper = find_child_reaper(father, dead); in forget_original_parent()
632 if (list_empty(&father->children)) in forget_original_parent()
635 reaper = find_new_reaper(father, reaper); in forget_original_parent()
636 list_for_each_entry(p, &father->children, sibling) { in forget_original_parent()
639 BUG_ON((!t->ptrace) != (rcu_access_pointer(t->parent) == father)); in forget_original_parent()
651 if (!same_thread_group(reaper, father)) in forget_original_parent()
652 reparent_leader(father, p, dead); in forget_original_parent()
654 list_splice_tail_init(&father->children, &reaper->children); in forget_original_parent()