Fix chroot, leave console alone if -c not specified, and yank debug code.
(I still haven't set up a test environment to confirm this works...)
This commit is contained in:
parent
7b363fd3c9
commit
5d84c2398e
@ -56,17 +56,17 @@ static void delete_contents(char *directory)
|
|||||||
closedir(dir);
|
closedir(dir);
|
||||||
|
|
||||||
// Directory should now be empty. Zap it.
|
// Directory should now be empty. Zap it.
|
||||||
printf("rmdir %s\n",directory); // rmdir(directory);
|
rmdir(directory);
|
||||||
}
|
}
|
||||||
|
|
||||||
// It wasn't a directory. Zap it.
|
// It wasn't a directory. Zap it.
|
||||||
|
|
||||||
} else printf("unlink %s\n",directory); //unlink(directory);
|
} else unlink(directory);
|
||||||
}
|
}
|
||||||
|
|
||||||
int switch_root_main(int argc, char *argv[])
|
int switch_root_main(int argc, char *argv[])
|
||||||
{
|
{
|
||||||
char *newroot, *console="/dev/console";
|
char *newroot, *console=NULL;
|
||||||
struct stat st1, st2;
|
struct stat st1, st2;
|
||||||
struct statfs stfs;
|
struct statfs stfs;
|
||||||
|
|
||||||
@ -98,19 +98,24 @@ int switch_root_main(int argc, char *argv[])
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Zap everything out of rootdev
|
// Zap everything out of rootdev
|
||||||
|
|
||||||
delete_contents("/");
|
delete_contents("/");
|
||||||
|
|
||||||
// Overmount / with newdir
|
// Overmount / with newdir and chroot into it. The chdir is needed to
|
||||||
|
// recalculate "." and ".." links.
|
||||||
|
|
||||||
if (mount(".", "/", NULL, MS_MOVE, NULL) || chdir("/"))
|
if (mount(".", "/", NULL, MS_MOVE, NULL) || chroot(".") || chdir("/"))
|
||||||
bb_error_msg_and_die("moving root");
|
bb_error_msg_and_die("moving root");
|
||||||
|
|
||||||
// Reopen stdin/stdout/stderr to /dev/console
|
// If a new console specified, redirect stdin/stdout/stderr to that.
|
||||||
|
|
||||||
|
if (console) {
|
||||||
close(0);
|
close(0);
|
||||||
if(open(console, O_RDWR) < 0)
|
if(open(console, O_RDWR) < 0)
|
||||||
bb_error_msg_and_die("Bad console '%s'",console);
|
bb_error_msg_and_die("Bad console '%s'",console);
|
||||||
dup2(0, 1);
|
dup2(0, 1);
|
||||||
dup2(0, 2);
|
dup2(0, 2);
|
||||||
|
}
|
||||||
|
|
||||||
// Exec real init. (This is why we must be pid 1.)
|
// Exec real init. (This is why we must be pid 1.)
|
||||||
execv(argv[optind],argv+optind+1);
|
execv(argv[optind],argv+optind+1);
|
||||||
|
Loading…
Reference in New Issue
Block a user