]> git.ipfire.org Git - thirdparty/lxc.git/commitdiff
attach: do not reload container
authorChristian Brauner <christian.brauner@ubuntu.com>
Thu, 16 May 2019 13:29:41 +0000 (15:29 +0200)
committerChristian Brauner <christian.brauner@ubuntu.com>
Sat, 18 May 2019 09:53:53 +0000 (11:53 +0200)
Let lxc_attach() reuse the already initialized container.

Closes https://github.com/lxc/lxd/issues/5755.

Signed-off-by: Christian Brauner <christian.brauner@ubuntu.com>
src/lxc/attach.c
src/lxc/attach.h
src/lxc/lxccontainer.c

index 3212fad789641cb500ce81165df8e049b87e410f..d22e6bd773b6028b041e00a202bf9a2db1b9c749 100644 (file)
@@ -1004,9 +1004,9 @@ static inline void lxc_attach_terminal_close_log(struct lxc_terminal *terminal)
        close_prot_errno_disarm(terminal->log_fd);
 }
 
-int lxc_attach(const char *name, const char *lxcpath,
-              lxc_attach_exec_t exec_function, void *exec_payload,
-              lxc_attach_options_t *options, pid_t *attached_process)
+int lxc_attach(struct lxc_container *container, lxc_attach_exec_t exec_function,
+              void *exec_payload, lxc_attach_options_t *options,
+              pid_t *attached_process)
 {
        int i, ret, status;
        int ipc_sockets[2];
@@ -1016,6 +1016,7 @@ int lxc_attach(const char *name, const char *lxcpath,
        struct lxc_proc_context_info *init_ctx;
        struct lxc_terminal terminal;
        struct lxc_conf *conf;
+       char *name, *lxcpath;
        struct attach_clone_payload payload = {0};
 
        ret = access("/proc/self/ns", X_OK);
@@ -1024,21 +1025,34 @@ int lxc_attach(const char *name, const char *lxcpath,
                return -1;
        }
 
+       if (!container)
+               return minus_one_set_errno(EINVAL);
+
+       if (!lxc_container_get(container))
+               return minus_one_set_errno(EINVAL);
+
+       name = container->name;
+       lxcpath = container->config_path;
+
        if (!options)
                options = &attach_static_default_options;
 
        init_pid = lxc_cmd_get_init_pid(name, lxcpath);
        if (init_pid < 0) {
                ERROR("Failed to get init pid");
+               lxc_container_put(container);
                return -1;
        }
 
        init_ctx = lxc_proc_get_context_info(init_pid);
        if (!init_ctx) {
                ERROR("Failed to get context of init process: %ld", (long)init_pid);
+               lxc_container_put(container);
                return -1;
        }
 
+       init_ctx->container = container;
+
        personality = get_personality(name, lxcpath);
        if (init_ctx->personality < 0) {
                ERROR("Failed to get personality of the container");
@@ -1047,12 +1061,6 @@ int lxc_attach(const char *name, const char *lxcpath,
        }
        init_ctx->personality = personality;
 
-       init_ctx->container = lxc_container_new(name, lxcpath);
-       if (!init_ctx->container) {
-               lxc_proc_put_context_info(init_ctx);
-               return -1;
-       }
-
        if (!init_ctx->container->lxc_conf) {
                init_ctx->container->lxc_conf = lxc_conf_init();
                if (!init_ctx->container->lxc_conf) {
index 4bf9578ee95aaf3cf9a47c4c08a4c89bd59c8305..c576aa9fcaac9b201da01d02efca9521a5f488b5 100644 (file)
@@ -41,7 +41,7 @@ struct lxc_proc_context_info {
        int ns_fd[LXC_NS_MAX];
 };
 
-extern int lxc_attach(const char *name, const char *lxcpath,
+extern int lxc_attach(struct lxc_container *container,
                      lxc_attach_exec_t exec_function, void *exec_payload,
                      lxc_attach_options_t *options, pid_t *attached_process);
 
index 60e0631856d501e619d5d0efe00a763704a00a67..9f039d964e5e161dc51337d67e15b7d05d491907 100644 (file)
@@ -4023,7 +4023,7 @@ static int lxcapi_attach(struct lxc_container *c, lxc_attach_exec_t exec_functio
 
        current_config = c->lxc_conf;
 
-       ret = lxc_attach(c->name, c->config_path, exec_function, exec_payload, options, attached_process);
+       ret = lxc_attach(c, exec_function, exec_payload, options, attached_process);
        current_config = NULL;
        return ret;
 }
@@ -4040,7 +4040,7 @@ static int do_lxcapi_attach_run_wait(struct lxc_container *c, lxc_attach_options
        command.program = (char*)program;
        command.argv = (char**)argv;
 
-       r = lxc_attach(c->name, c->config_path, lxc_attach_run_command, &command, options, &pid);
+       r = lxc_attach(c, lxc_attach_run_command, &command, options, &pid);
        if (r < 0) {
                ERROR("ups");
                return r;