virprocess: Introduce virProcessSetupPrivateMountNS

This part of code that LXC currently uses will be reused so move
to a generic function.

Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
This commit is contained in:
Michal Privoznik 2016-11-10 14:55:48 +01:00
parent de8607d77d
commit 48a12d3b25
5 changed files with 43 additions and 18 deletions

View File

@ -272,7 +272,7 @@ dnl and various less common threadsafe functions
AC_CHECK_FUNCS_ONCE([cfmakeraw fallocate geteuid getgid getgrnam_r \ AC_CHECK_FUNCS_ONCE([cfmakeraw fallocate geteuid getgid getgrnam_r \
getmntent_r getpwuid_r getrlimit getuid kill mmap newlocale posix_fallocate \ getmntent_r getpwuid_r getrlimit getuid kill mmap newlocale posix_fallocate \
posix_memalign prlimit regexec sched_getaffinity setgroups setns \ posix_memalign prlimit regexec sched_getaffinity setgroups setns \
setrlimit symlink sysctlbyname getifaddrs sched_setscheduler]) setrlimit symlink sysctlbyname getifaddrs sched_setscheduler unshare])
dnl Availability of pthread functions. Because of $LIB_PTHREAD, we dnl Availability of pthread functions. Because of $LIB_PTHREAD, we
dnl cannot use AC_CHECK_FUNCS_ONCE. LIB_PTHREAD and LIBMULTITHREAD dnl cannot use AC_CHECK_FUNCS_ONCE. LIB_PTHREAD and LIBMULTITHREAD

View File

@ -2263,6 +2263,7 @@ virProcessSetMaxMemLock;
virProcessSetMaxProcesses; virProcessSetMaxProcesses;
virProcessSetNamespaces; virProcessSetNamespaces;
virProcessSetScheduler; virProcessSetScheduler;
virProcessSetupPrivateMountNS;
virProcessTranslateStatus; virProcessTranslateStatus;
virProcessWait; virProcessWait;

View File

@ -2092,8 +2092,6 @@ lxcCreateTty(virLXCControllerPtr ctrl, int *ttymaster,
static int static int
virLXCControllerSetupPrivateNS(void) virLXCControllerSetupPrivateNS(void)
{ {
int ret = -1;
/* /*
* If doing a chroot style setup, we need to prepare * If doing a chroot style setup, we need to prepare
* a private /dev/pts for the child now, which they * a private /dev/pts for the child now, which they
@ -2115,21 +2113,7 @@ virLXCControllerSetupPrivateNS(void)
* marked as shared * marked as shared
*/ */
if (unshare(CLONE_NEWNS) < 0) { return virProcessSetupPrivateMountNS();
virReportSystemError(errno, "%s",
_("Cannot unshare mount namespace"));
goto cleanup;
}
if (mount("", "/", NULL, MS_SLAVE|MS_REC, NULL) < 0) {
virReportSystemError(errno, "%s",
_("Failed to switch root mount into slave mode"));
goto cleanup;
}
ret = 0;
cleanup:
return ret;
} }

View File

@ -28,6 +28,9 @@
#include <stdlib.h> #include <stdlib.h>
#include <sys/wait.h> #include <sys/wait.h>
#include <unistd.h> #include <unistd.h>
#if HAVE_SYS_MOUNT_H
# include <sys/mount.h>
#endif
#if HAVE_SETRLIMIT #if HAVE_SETRLIMIT
# include <sys/time.h> # include <sys/time.h>
# include <sys/resource.h> # include <sys/resource.h>
@ -1146,6 +1149,41 @@ virProcessRunInMountNamespace(pid_t pid,
} }
#if defined(HAVE_SYS_MOUNT_H) && defined(HAVE_UNSHARE)
int
virProcessSetupPrivateMountNS(void)
{
int ret = -1;
if (unshare(CLONE_NEWNS) < 0) {
virReportSystemError(errno, "%s",
_("Cannot unshare mount namespace"));
goto cleanup;
}
if (mount("", "/", NULL, MS_SLAVE|MS_REC, NULL) < 0) {
virReportSystemError(errno, "%s",
_("Failed to switch root mount into slave mode"));
goto cleanup;
}
ret = 0;
cleanup:
return ret;
}
#else /* !defined(HAVE_SYS_MOUNT_H) || !defined(HAVE_UNSHARE) */
int
virProcessSetupPrivateMountNS(void)
{
virReportSystemError(ENOSYS, "%s",
_("Namespaces are not supported on this platform."));
return -1;
}
#endif /* !defined(HAVE_SYS_MOUNT_H) || !defined(HAVE_UNSHARE) */
/** /**
* virProcessExitWithStatus: * virProcessExitWithStatus:
* @status: raw status to be reproduced when this process dies * @status: raw status to be reproduced when this process dies

View File

@ -90,6 +90,8 @@ int virProcessRunInMountNamespace(pid_t pid,
virProcessNamespaceCallback cb, virProcessNamespaceCallback cb,
void *opaque); void *opaque);
int virProcessSetupPrivateMountNS(void);
int virProcessSetScheduler(pid_t pid, int virProcessSetScheduler(pid_t pid,
virProcessSchedPolicy policy, virProcessSchedPolicy policy,
int priority); int priority);