X-Git-Url: https://git.kernel.dk/?a=blobdiff_plain;f=kernel%2Fexit.c;h=06de6c4e8ca3a66937ce8763d33ca42852fbb698;hb=3eb1b3a40722cbb46631db373af66d13d1e7ac81;hp=2e4c13cba95ae7af79bc373a859ecac42a340225;hpb=c394cc9fbb367f87faa2228ec2eabacd2d4701c6;p=linux-2.6-block.git diff --git a/kernel/exit.c b/kernel/exit.c index 2e4c13cba95a..06de6c4e8ca3 100644 --- a/kernel/exit.c +++ b/kernel/exit.c @@ -18,8 +18,10 @@ #include #include #include +#include #include #include +#include #include #include #include @@ -38,6 +40,7 @@ #include #include /* for audit_free() */ #include +#include #include #include @@ -125,6 +128,7 @@ static void __exit_signal(struct task_struct *tsk) flush_sigqueue(&tsk->pending); if (sig) { flush_sigqueue(&sig->shared_pending); + taskstats_tgid_free(sig); __cleanup_signal(sig); } } @@ -395,9 +399,11 @@ void daemonize(const char *name, ...) fs = init_task.fs; current->fs = fs; atomic_inc(&fs->count); - exit_namespace(current); - current->namespace = init_task.namespace; - get_namespace(current->namespace); + + exit_task_namespaces(current); + current->nsproxy = init_task.nsproxy; + get_task_namespaces(current); + exit_files(current); current->files = init_task.files; atomic_inc(¤t->files->count); @@ -915,7 +921,6 @@ fastcall NORET_TYPE void do_exit(long code) exit_sem(tsk); __exit_files(tsk); __exit_fs(tsk); - exit_namespace(tsk); exit_thread(); cpuset_exit(tsk); exit_keys(tsk); @@ -930,6 +935,7 @@ fastcall NORET_TYPE void do_exit(long code) tsk->exit_code = code; proc_exit_connector(tsk); exit_notify(tsk); + exit_task_namespaces(tsk); #ifdef CONFIG_NUMA mpol_free(tsk->mempolicy); tsk->mempolicy = NULL;