X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=elogind.git;a=blobdiff_plain;f=src%2Fnspawn.c;h=f340805f38339835d8162d291dfd33a73961ef9d;hp=82b0ce4f133bb318d49337bf1cba4208c0b45cb0;hb=90df7e567f668b4d0e7761fd15fa8cebffc759a0;hpb=124640f177c118b096ed2c531a4617d52a283395 diff --git a/src/nspawn.c b/src/nspawn.c index 82b0ce4f1..f340805f3 100644 --- a/src/nspawn.c +++ b/src/nspawn.c @@ -254,7 +254,7 @@ static int copy_devnodes(const char *dest) { r = -errno; } - if (mount(from, to, "bind", MS_BIND, NULL) < 0) { + if (mount(from, to, "bind", MS_BIND|MS_RDONLY, NULL) < 0) { log_error("bind mount for /dev/console failed: %m"); if (r == 0) @@ -390,6 +390,11 @@ int main(int argc, char *argv[]) { if (pid == 0) { const char *hn; + const char *envp[] = { + "HOME=/root", + "PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin", + NULL + }; /* child */ @@ -425,9 +430,11 @@ int main(int argc, char *argv[]) { sethostname(hn, strlen(hn)); if (argc > optind) - execvp(argv[optind], argv + optind); - else - execl("/bin/bash", "/bin/bash", NULL); + execvpe(argv[optind], argv + optind, (char**) envp); + else { + chdir("/root"); + execle("/bin/bash", "-bash", NULL, (char**) envp); + } log_error("execv() failed: %m");