2
0
mirror of https://github.com/checkpoint-restore/criu synced 2025-09-01 06:45:35 +00:00

Quick bug fix for missing fd for move_in_cgroup

There is an issue where if the proccess to be killed spawns a child proccess and
moves it in a child cgroup of the one the parent process is in, the cgroup fd
was being closed in the parent process before it forked the child. Then when
move_in_cgroup() is called for the child process, the file descriptor has
already been closed causing a failure for the second call to move_in_cgroup().
Moved the fd close after the fork call.

Change-Id: I6ae88b95c5410a7f56108e28eb3133f113e868d0
Signed-off-by: Garrison Bellack <gbellack@google.com>
Signed-off-by: Pavel Emelyanov <xemul@parallels.com>
This commit is contained in:
gbellack
2014-08-07 15:26:11 -07:00
committed by Pavel Emelyanov
parent 7a203afe0a
commit 9752c11d23
2 changed files with 8 additions and 1 deletions

View File

@@ -619,7 +619,6 @@ static int move_in_cgroup(CgSetEntry *se)
}
}
close_service_fd(CGROUP_YARD);
return 0;
}

View File

@@ -1388,6 +1388,14 @@ static int restore_task_with_children(void *_arg)
if (create_children_and_session())
goto err;
/*
* This must be done after forking to allow child
* to get the cgroup fd so it can move into the
* correct /tasks file if it is in a different cgroup
* set than its parent
*/
close_service_fd(CGROUP_YARD);
if (restore_task_mnt_ns(current))
goto err;