Serge Hallyn
f52624fa56
Merge pull request #2309 from brauner/2018-05-08/fix_execute
...
execute: do not check inherited fds again
2018-05-09 08:49:07 -05:00
Christian Brauner
c7a2deb2dc
execute: do not check inherited fds again
...
This is already done in do_lxcapi_start{l}() so a) no need to do it again here
and b) this would close the state socket pair sockets, corrup the fd, and lead
to EBADF.
Signed-off-by: Christian Brauner <christian.brauner@ubuntu.com>
2018-05-08 18:10:13 +02:00
Christian Brauner
7101cb035b
Merge pull request #2305 from brauner/2018-05-04/fix_execute_logging
...
fix logic for execute log file
2018-05-04 12:35:23 +02:00
Christian Brauner
321614a5da
execute: use static buffer
...
Signed-off-by: Christian Brauner <christian.brauner@ubuntu.com>
2018-05-04 11:59:27 +02:00
Christian Brauner
aa769a272f
utils: add LXC_PROC_PID_FD_LEN
...
Signed-off-by: Christian Brauner <christian.brauner@ubuntu.com>
2018-05-04 11:59:11 +02:00
Tycho Andersen
cd90db2c0e
fix logic for execute log file
...
The problem here is that lxc-init runs *inside* the container. So if a
person has the log file set to /home/$USER/foo, lxc-init ends up making a
directory /home/$USER/foo inside the container to put the log file in. What
we really want are the logs to be propagated from inside the container to
the outside. We accomplish this by passing an fd without O_CLOEXEC, and
telling lxc-init to log to that file.
Signed-off-by: Tycho Andersen <tycho@tycho.ws>
2018-05-03 18:32:19 +00:00
Christian Brauner
cef701ede3
coverity: #1435263
...
Use after free
Signed-off-by: Christian Brauner <christian.brauner@ubuntu.com>
2018-04-30 12:18:23 +02:00
Stéphane Graber
ff62067703
Merge pull request #2297 from brauner/2018-04-29/bugfixes
...
coverity
2018-04-30 05:29:41 -04:00
Christian Brauner
e62fd16fff
lxccontainer: non-functional changes
...
Signed-off-by: Christian Brauner <christian.brauner@ubuntu.com>
2018-04-29 16:58:06 +02:00
Christian Brauner
630ac7c61b
lxccontainer: non-functional changes
...
Signed-off-by: Christian Brauner <christian.brauner@ubuntu.com>
2018-04-29 16:56:58 +02:00
Christian Brauner
9640c6a767
lxccontainer: non-functional changes
...
Signed-off-by: Christian Brauner <christian.brauner@ubuntu.com>
2018-04-29 16:45:43 +02:00
Christian Brauner
7cea590585
lxccontainer: use thread-safe open() + write()
...
Signed-off-by: Christian Brauner <christian.brauner@ubuntu.com>
2018-04-29 16:42:44 +02:00
Christian Brauner
d630991d8f
lxccontainer: non-functional changes
...
Signed-off-by: Christian Brauner <christian.brauner@ubuntu.com>
2018-04-29 15:08:46 +02:00
Christian Brauner
e898947399
lxccontainer: do_lxcapi_unfreeze()
...
Signed-off-by: Christian Brauner <christian.brauner@ubuntu.com>
2018-04-29 14:53:12 +02:00
Christian Brauner
5df46fad0c
lxccontainer: do_lxcapi_freeze()
...
Signed-off-by: Christian Brauner <christian.brauner@ubuntu.com>
2018-04-29 14:52:40 +02:00
Christian Brauner
9e6304187b
lxccontainer: do_lxcapi_is_running()
...
There's no need to do string comparisons.
Signed-off-by: Christian Brauner <christian.brauner@ubuntu.com>
2018-04-29 14:49:36 +02:00
Christian Brauner
44619b6cd2
lxccontainer: non-functional changes
...
Signed-off-by: Christian Brauner <christian.brauner@ubuntu.com>
2018-04-29 14:48:08 +02:00
Christian Brauner
5647455516
lxccontainer: use thread-safe *_OFD_* locks
...
If they aren't available fallback to BSD flock()s.
Signed-off-by: Christian Brauner <christian.brauner@ubuntu.com>
2018-04-29 13:56:15 +02:00
Christian Brauner
0e14584db8
lxccontainer: non-functional changes
...
Signed-off-by: Christian Brauner <christian.brauner@ubuntu.com>
2018-04-29 13:39:16 +02:00
Christian Brauner
d2b5acecea
coverity: #1426734
...
Argument cannot be negative
Signed-off-by: Christian Brauner <christian.brauner@ubuntu.com>
2018-04-29 01:10:54 +02:00
Christian Brauner
ba1de6dbfe
coverity: #1435198
...
Unchecked return value
Signed-off-by: Christian Brauner <christian.brauner@ubuntu.com>
2018-04-29 00:50:50 +02:00
Christian Brauner
205fc0103b
coverity: #1435200
...
Resource leak
Signed-off-by: Christian Brauner <christian.brauner@ubuntu.com>
2018-04-29 00:49:30 +02:00
Christian Brauner
c1768f3f25
coverity: #1435203
...
Resource leak
Signed-off-by: Christian Brauner <christian.brauner@ubuntu.com>
2018-04-29 00:43:34 +02:00
Christian Brauner
dbdf8cf420
coverity: #1435205
...
Unchecked return value
Signed-off-by: Christian Brauner <christian.brauner@ubuntu.com>
2018-04-29 00:38:29 +02:00
Christian Brauner
46768cced9
coverity: #1435206
...
Time of check time of use
Signed-off-by: Christian Brauner <christian.brauner@ubuntu.com>
2018-04-29 00:36:24 +02:00
Christian Brauner
91ae555c99
coverity: #1435207
...
Unchecked return value
Signed-off-by: Christian Brauner <christian.brauner@ubuntu.com>
2018-04-29 00:22:54 +02:00
Christian Brauner
8186c5c7c3
coverity: #1435208
...
Unused value
Signed-off-by: Christian Brauner <christian.brauner@ubuntu.com>
2018-04-29 00:21:33 +02:00
Christian Brauner
13939498ed
coverity: #1435210
...
Logically dead code
Signed-off-by: Christian Brauner <christian.brauner@ubuntu.com>
2018-04-29 00:16:05 +02:00
Christian Brauner
ad38dca193
Merge pull request #2279 from kunkku/create-umask
...
do_lxcapi_create: set umask
2018-04-28 23:23:27 +02:00
Christian Brauner
61068d39af
Merge pull request #2293 from pkun/master
...
Fix tool_utils.c build when HAVE_SETNS is unset
2018-04-26 18:36:46 +02:00
Serj Kalichev
09e6e41e05
Fix tool_utils.c build when HAVE_SETNS is unset
...
Add inline setns() function to tool_utils.h. Without it
tool_utils.c can't be build when HAVE_SETNS is unset.
Signed-off-by: Serj Kalichev <serj.kalichev@gmail.com>
2018-04-26 16:20:30 +03:00
Christian Brauner
fca96eb6da
Merge pull request #2289 from lifeng68/Fix_mem_leak_list_active_containers
...
Fix memory leak in list_active_containers
2018-04-24 15:14:25 +02:00
LiFeng
e07eafa839
Fix memory leak in list_active_containers
...
Signed-off-by: LiFeng <lifeng68@huawei.com>
2018-04-24 15:26:32 -04:00
LiFeng
71cb9afb44
Fix the memory leak in cgfsng_attach
...
Signed-off-by: LiFeng <lifeng68@huawei.com>
2018-04-24 12:53:57 -04:00
Christian Brauner
48d02a2f03
Merge pull request #2288 from lifeng68/Fix_mem_leak_cgfsng_attach
...
Fix the memory leak in cgfsng_attach
2018-04-24 10:40:22 +02:00
Christian Brauner
d31660efe7
Merge pull request #2287 from thyth/master
...
Also pass action scripts to CRIU on checkpointing
2018-04-24 10:16:04 +02:00
Daniel Selifonov
497a78630c
Also pass action scripts to CRIU on checkpointing
...
Signed-off-by: Daniel Selifonov <ds@thyth.com>
2018-04-23 23:03:44 -07:00
Christian Brauner
31283a46ac
Merge pull request #2284 from 3XX0/pamcgfs-ignore-umask
...
pam-cgfs: ignore the system umask when creating the cgroup hierarchy
2018-04-23 23:09:39 +02:00
Jonathan Calmels
c4a4578fa0
pam-cgfs: ignore the system umask when creating the cgroup hierarchy
...
Fixes : #2277
Signed-off-by: Jonathan Calmels <jcalmels@nvidia.com>
2018-04-23 13:24:11 -07:00
Christian Brauner
5dfc91865b
Merge pull request #2285 from tpetazzoni/offsetof-stddef-fix
...
lxc/tools/lxc_monitor: include missing <stddef.h>
2018-04-20 13:00:07 +02:00
Thomas Petazzoni
77d407537f
lxc/tools/lxc_monitor: include missing <stddef.h>
...
lxc_monitor.c uses offsetof(), so it should include
<stddef.h>. Otherwise the build fails with the musl C library:
tools/lxc_monitor.c: In function ‘lxc_abstract_unix_connect’:
tools/lxc_monitor.c:324:9: warning: implicit declaration of function ‘offsetof’ [-Wimplicit-function-declaration]
offsetof(struct sockaddr_un, sun_path) + len + 1);
^~~~~~~~
tools/lxc_monitor.c:324:18: error: expected expression before ‘struct’
offsetof(struct sockaddr_un, sun_path) + len + 1);
^~~~~~
Signed-off-by: Thomas Petazzoni <thomas.petazzoni@bootlin.com>
2018-04-20 12:26:33 +02:00
Christian Brauner
7d675310ae
Merge pull request #2283 from flx42/lxc-oci-mkdir-download-directory
...
lxc-oci: mkdir the download directory
2018-04-19 15:07:05 +02:00
Felix Abecassis
8c7536ecf2
lxc-oci: mkdir the download directory
...
Signed-off-by: Felix Abecassis <fabecassis@nvidia.com>
2018-04-18 14:12:55 -07:00
Serge Hallyn
a5fb69a3f1
Merge pull request #2281 from brauner/2018-04-15/seccomp_fixes
...
seccomp: handle arch inversion - The Architecture Strikes Back
2018-04-18 11:35:11 -05:00
Christian Brauner
eca6736eb0
seccomp: handle arch inversion II
...
LXC generates and loads the seccomp-bpf filter in the host/container which
spawn the new container. In other words, userspace N is responsible for
generating and loading the seccomp-bpf filter which restricts userspace N + 1.
Assume 64bit kernel and 32bit userspace running a 64bit container. In this case
the 32-bit x86 userspace is used to create a seccomp-bpf filter for a 64-bit
userspace. Unless one explicitly adds the 64-bit ABI to the libseccomp filter,
or adjusts the default behavior for "BAD_ARCH", *all* 64-bit x86 syscalls will
be blocked.
Signed-off-by: Christian Brauner <christian.brauner@ubuntu.com>
Suggested-by: Paul Moore <paul@paul-moore.com>
2018-04-18 16:00:54 +02:00
Christian Brauner
7e84441ec3
seccomp: non-functional changes
...
Rename "compat_ctx" to "contexts" and "compat_arch" to "architectures".
Signed-off-by: Christian Brauner <christian.brauner@ubuntu.com>
2018-04-18 14:40:49 +02:00
Christian Brauner
4160ef02e5
tools: document -d/--daemonize for lxc-execute
...
Closes #2280 .
Signed-off-by: Christian Brauner <christian.brauner@ubuntu.com>
2018-04-15 22:43:21 +02:00
Christian Brauner
94d5605414
seccomp: improve logging
...
Signed-off-by: Christian Brauner <christian.brauner@ubuntu.com>
2018-04-15 22:39:07 +02:00
Christian Brauner
d648e178f1
seccomp: cleanup compat architecture handling
...
Signed-off-by: Christian Brauner <christian.brauner@ubuntu.com>
2018-04-15 22:12:51 +02:00
Kaarle Ritvanen
51f0f73b4f
do_lxcapi_create: set umask
...
Always use 022 as the umask when creating the rootfs directory and
executing the template. A too loose umask may cause security issues.
A too strict umask may cause programs to fail inside the container.
Signed-off-by: Kaarle Ritvanen <kaarle.ritvanen@datakunkku.fi>
2018-04-15 16:09:41 +03:00