From: Lennart Poettering Date: Tue, 6 Mar 2012 01:06:29 +0000 (+0100) Subject: nspawn: be less cryptic when clone() fails X-Git-Tag: v44~61 X-Git-Url: https://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=elogind.git;a=commitdiff_plain;h=52af21063b365f231ee6ae8bac18d690fff85799;hp=0716c60e37d2083325cd5316caf4310f0acc9a89 nspawn: be less cryptic when clone() fails Based on a patch suggested by Shawn Landden. --- diff --git a/src/nspawn.c b/src/nspawn.c index b8b379d99..b548b126c 100644 --- a/src/nspawn.c +++ b/src/nspawn.c @@ -706,8 +706,13 @@ int main(int argc, char *argv[]) { sigset_add_many(&mask, SIGCHLD, SIGWINCH, SIGTERM, SIGINT, -1); assert_se(sigprocmask(SIG_BLOCK, &mask, NULL) == 0); - if ((pid = syscall(__NR_clone, SIGCHLD|CLONE_NEWIPC|CLONE_NEWNS|CLONE_NEWPID|CLONE_NEWUTS|(arg_private_network ? CLONE_NEWNET : 0), NULL)) < 0) { - log_error("clone() failed: %m"); + pid = syscall(__NR_clone, SIGCHLD|CLONE_NEWIPC|CLONE_NEWNS|CLONE_NEWPID|CLONE_NEWUTS|(arg_private_network ? CLONE_NEWNET : 0), NULL); + if (pid < 0) { + if (errno == EINVAL) + log_error("clone() failed, do you have namespace support enabled in your kernel? (You need UTS, IPC, PID and NET namespacing built in): %m"); + else + log_error("clone() failed: %m"); + goto finish; }