summaryrefslogtreecommitdiff
path: root/pkg/rootless
diff options
context:
space:
mode:
authorOpenShift Merge Robot <openshift-merge-robot@users.noreply.github.com>2019-03-08 11:00:52 -0800
committerGitHub <noreply@github.com>2019-03-08 11:00:52 -0800
commitbf8c2096d8bba5d94a6e6201ba483f2aa72f1d01 (patch)
tree4789ab531f7259212be9337a4f516d6072c870fd /pkg/rootless
parent5ae7359184a20859d775bc59f1b1c53348b04ecd (diff)
parentcc411dd98fed42a19d2d4f8ec1922ba62da49957 (diff)
downloadpodman-bf8c2096d8bba5d94a6e6201ba483f2aa72f1d01.tar.gz
podman-bf8c2096d8bba5d94a6e6201ba483f2aa72f1d01.tar.bz2
podman-bf8c2096d8bba5d94a6e6201ba483f2aa72f1d01.zip
Merge pull request #2588 from giuseppe/rootless-propagate-error-from-info
rootless: propagate errors from info
Diffstat (limited to 'pkg/rootless')
-rw-r--r--pkg/rootless/rootless_linux.c2
-rw-r--r--pkg/rootless/rootless_linux.go1
2 files changed, 3 insertions, 0 deletions
diff --git a/pkg/rootless/rootless_linux.c b/pkg/rootless/rootless_linux.c
index 41acd3475..ff39e9e77 100644
--- a/pkg/rootless/rootless_linux.c
+++ b/pkg/rootless/rootless_linux.c
@@ -277,6 +277,8 @@ reexec_in_user_namespace (int ready)
_exit (EXIT_FAILURE);
}
close (ready);
+ if (b != '1')
+ _exit (EXIT_FAILURE);
if (syscall_setresgid (0, 0, 0) < 0)
{
diff --git a/pkg/rootless/rootless_linux.go b/pkg/rootless/rootless_linux.go
index 55fba900e..933cfa2c2 100644
--- a/pkg/rootless/rootless_linux.go
+++ b/pkg/rootless/rootless_linux.go
@@ -229,6 +229,7 @@ func BecomeRootInUserNS() (bool, int, error) {
}
defer r.Close()
defer w.Close()
+ defer w.Write([]byte("0"))
pidC := C.reexec_in_user_namespace(C.int(r.Fd()))
pid := int(pidC)