summaryrefslogtreecommitdiffstats
path: root/sys-utils/unshare.c
diff options
context:
space:
mode:
authorEric W. Biederman2013-01-17 01:36:32 +0100
committerKarel Zak2013-01-17 13:18:08 +0100
commitc91280a4bd738eba0f19c8d3714da2f319dcd602 (patch)
treec078e71fdc98b7b639f95b5fb1be2c3b684410e0 /sys-utils/unshare.c
parentnsenter: Replace a bare strtoul with strtoul_or_err (diff)
downloadkernel-qcow2-util-linux-c91280a4bd738eba0f19c8d3714da2f319dcd602.tar.gz
kernel-qcow2-util-linux-c91280a4bd738eba0f19c8d3714da2f319dcd602.tar.xz
kernel-qcow2-util-linux-c91280a4bd738eba0f19c8d3714da2f319dcd602.zip
unshare,nsenter: Move the old libc handling into a common header namespace.h
Move the defitions of CLONE_NEWNS, CLONE_NEWUTS, CLONE_NEWIPC, CLONE_NEWNET, CLONE_NEWUSER, CLONE_NEWPID into namespace.h in case sched.h does not provide those definitions. Are there systems around that are old enough that still need this? Move the definitions of unshare() and setns() into namespace.h for supporting old versions of libc that does not provice these. I have tested this support with setns as I still have systems old enough that glibc does not wrap setns. Signed-off-by: "Eric W. Biederman" <ebiederm@xmission.com>
Diffstat (limited to 'sys-utils/unshare.c')
-rw-r--r--sys-utils/unshare.c29
1 files changed, 1 insertions, 28 deletions
diff --git a/sys-utils/unshare.c b/sys-utils/unshare.c
index 00cc2cf79..9b849ee9e 100644
--- a/sys-utils/unshare.c
+++ b/sys-utils/unshare.c
@@ -28,34 +28,7 @@
#include "nls.h"
#include "c.h"
#include "closestream.h"
-
-#ifndef CLONE_NEWSNS
-# define CLONE_NEWNS 0x00020000
-#endif
-#ifndef CLONE_NEWUTS
-# define CLONE_NEWUTS 0x04000000
-#endif
-#ifndef CLONE_NEWIPC
-# define CLONE_NEWIPC 0x08000000
-#endif
-#ifndef CLONE_NEWNET
-# define CLONE_NEWNET 0x40000000
-#endif
-#ifndef CLONE_NEWUSER
-# define CLONE_NEWUSER 0x10000000
-#endif
-#ifndef CLONE_NEWPID
-# define CLONE_NEWPID 0x20000000
-#endif
-
-#ifndef HAVE_UNSHARE
-# include <sys/syscall.h>
-
-static int unshare(int flags)
-{
- return syscall(SYS_unshare, flags);
-}
-#endif
+#include "namespace.h"
static void usage(int status)
{