mirror of
git://github.com/lxc/lxc
synced 2025-08-31 11:59:33 +00:00
start: reorder START_SYNC_POST_CONFIGURE
Signed-off-by: Christian Brauner <christian.brauner@ubuntu.com>
This commit is contained in:
@@ -1800,32 +1800,32 @@ static int lxc_spawn(struct lxc_handler *handler)
|
||||
ERROR("Failed to create the network");
|
||||
goto out_delete_net;
|
||||
}
|
||||
|
||||
ret = lxc_network_send_to_child(handler);
|
||||
if (ret < 0) {
|
||||
ERROR("Failed to send veth names to child");
|
||||
goto out_delete_net;
|
||||
}
|
||||
}
|
||||
|
||||
/* Tell the child to continue its initialization. */
|
||||
if (!lxc_sync_wake_child(handler, START_SYNC_POST_CONFIGURE))
|
||||
goto out_delete_net;
|
||||
|
||||
ret = lxc_rootfs_prepare_parent(handler);
|
||||
if (ret) {
|
||||
ERROR("Failed to prepare rootfs");
|
||||
goto out_delete_net;
|
||||
}
|
||||
|
||||
if (handler->ns_clone_flags & CLONE_NEWNET) {
|
||||
ret = lxc_network_send_to_child(handler);
|
||||
if (ret < 0) {
|
||||
ERROR("Failed to send veth names to child");
|
||||
goto out_delete_net;
|
||||
}
|
||||
}
|
||||
|
||||
if (!lxc_list_empty(&conf->procs)) {
|
||||
ret = setup_proc_filesystem(&conf->procs, handler->pid);
|
||||
if (ret < 0)
|
||||
goto out_delete_net;
|
||||
}
|
||||
|
||||
/* Tell the child to continue its initialization. We'll get
|
||||
* START_SYNC_CGROUP when it is ready for us to setup cgroups.
|
||||
*/
|
||||
if (!lxc_sync_barrier_child(handler, START_SYNC_POST_CONFIGURE))
|
||||
goto out_delete_net;
|
||||
|
||||
if (!lxc_list_empty(&conf->limits)) {
|
||||
ret = setup_resource_limits(&conf->limits, handler->pid);
|
||||
if (ret < 0) {
|
||||
@@ -1834,6 +1834,13 @@ static int lxc_spawn(struct lxc_handler *handler)
|
||||
}
|
||||
}
|
||||
|
||||
/*
|
||||
* Wait for the child to tell us that it's ready for us to prepare
|
||||
* cgroups.
|
||||
*/
|
||||
if (!lxc_sync_wait_child(handler, START_SYNC_CGROUP))
|
||||
goto out_delete_net;
|
||||
|
||||
if (!lxc_sync_barrier_child(handler, START_SYNC_CGROUP_UNSHARE))
|
||||
goto out_delete_net;
|
||||
|
||||
|
Reference in New Issue
Block a user