From: Eric W. Biederman Date: Thu, 17 Jan 2013 00:36:32 +0000 (-0800) Subject: unshare,nsenter: Move the old libc handling into a common header namespace.h X-Git-Tag: v2.23-rc1~337 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=c91280a4bd738eba0f19c8d3714da2f319dcd602;p=thirdparty%2Futil-linux.git 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" --- diff --git a/include/namespace.h b/include/namespace.h new file mode 100644 index 0000000000..8ccc3f6b36 --- /dev/null +++ b/include/namespace.h @@ -0,0 +1,43 @@ +/* Compat code so unshare and setns can be used with older libcs */ +#ifndef UTIL_LINUX_NAMESPACE_H +#define UTIL_LINUX_NAMESPACE_H + +#include + +#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 + +static inline int unshare(int flags) +{ + return syscall(SYS_unshare, flags); +} +#endif + +#ifndef HAVE_SETNS +# include +static inline int setns(int fd, int nstype) +{ + return syscall(SYS_setns, fd, nstype); +} +#endif /* HAVE_SETNS */ + +#endif /* UTIL_LINUX_NAMESPACE_H */ diff --git a/sys-utils/nsenter.c b/sys-utils/nsenter.c index 99b18b05fd..0b5d17da77 100644 --- a/sys-utils/nsenter.c +++ b/sys-utils/nsenter.c @@ -31,33 +31,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_SETNS -# include -static int setns(int fd, int nstype) -{ - return syscall(SYS_setns, fd, nstype); -} -#endif /* HAVE_SETNS */ +#include "namespace.h" static struct namespace_file{ int nstype; diff --git a/sys-utils/unshare.c b/sys-utils/unshare.c index 00cc2cf792..9b849ee9e4 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 - -static int unshare(int flags) -{ - return syscall(SYS_unshare, flags); -} -#endif +#include "namespace.h" static void usage(int status) {