aboutsummaryrefslogtreecommitdiffstats
path: root/kernel/fork.c
diff options
context:
space:
mode:
Diffstat (limited to 'kernel/fork.c')
-rw-r--r--kernel/fork.c4
1 files changed, 3 insertions, 1 deletions
diff --git a/kernel/fork.c b/kernel/fork.c
index 12cdd9fc9d02..bc551efb5fd4 100644
--- a/kernel/fork.c
+++ b/kernel/fork.c
@@ -1112,6 +1112,7 @@ static task_t *copy_process(unsigned long clone_flags,
1112 * We dont wake it up yet. 1112 * We dont wake it up yet.
1113 */ 1113 */
1114 p->group_leader = p; 1114 p->group_leader = p;
1115 INIT_LIST_HEAD(&p->thread_group);
1115 INIT_LIST_HEAD(&p->ptrace_children); 1116 INIT_LIST_HEAD(&p->ptrace_children);
1116 INIT_LIST_HEAD(&p->ptrace_list); 1117 INIT_LIST_HEAD(&p->ptrace_list);
1117 1118
@@ -1165,7 +1166,9 @@ static task_t *copy_process(unsigned long clone_flags,
1165 retval = -EAGAIN; 1166 retval = -EAGAIN;
1166 goto bad_fork_cleanup_namespace; 1167 goto bad_fork_cleanup_namespace;
1167 } 1168 }
1169
1168 p->group_leader = current->group_leader; 1170 p->group_leader = current->group_leader;
1171 list_add_tail_rcu(&p->thread_group, &p->group_leader->thread_group);
1169 1172
1170 if (current->signal->group_stop_count > 0) { 1173 if (current->signal->group_stop_count > 0) {
1171 /* 1174 /*
@@ -1213,7 +1216,6 @@ static task_t *copy_process(unsigned long clone_flags,
1213 list_add_tail(&p->tasks, &init_task.tasks); 1216 list_add_tail(&p->tasks, &init_task.tasks);
1214 __get_cpu_var(process_counts)++; 1217 __get_cpu_var(process_counts)++;
1215 } 1218 }
1216 attach_pid(p, PIDTYPE_TGID, p->tgid);
1217 attach_pid(p, PIDTYPE_PID, p->pid); 1219 attach_pid(p, PIDTYPE_PID, p->pid);
1218 nr_threads++; 1220 nr_threads++;
1219 } 1221 }