#! @shell@ # !!! copied from stage 1; remove duplication # Print a greeting. echo echo "<<< NixOS Stage 2 >>>" echo # Set the PATH. export PATH=/empty for i in @startPath@; do PATH=$PATH:$i/bin if test -e $i/sbin; then PATH=$PATH:$i/sbin fi done # Mount special file systems. needWritableDir() { if test -n "@readOnlyRoot@"; then mount -t tmpfs -o "mode=$2" none $1 $3 else mkdir -m $2 -p $1 fi } needWritableDir /etc 0755 -n # to shut up mount test -e /etc/fstab || touch /etc/fstab # idem mount -n -t proc none /proc cat /proc/mounts > /etc/mtab # Process the kernel command line. for o in $(cat /proc/cmdline); do case $o in debugtrace) # Show each command. set -x ;; debug2) echo "Debug shell called from @out@" exec @shell@ ;; S|s|single) # !!! argh, can't pass a startup event to Upstart yet. exec @shell@ ;; esac done # More special file systems, initialise required directories. mount -t sysfs none /sys mount -t tmpfs -o "mode=0755" none /dev needWritableDir /tmp 01777 needWritableDir /var 0755 needWritableDir /nix/var 0755 mkdir -m 0755 -p /nix/var/nix/db mkdir -m 0755 -p /nix/var/nix/gcroots mkdir -m 0755 -p /nix/var/nix/temproots mkdir -m 0755 -p /var/log ln -sf /nix/var/nix/profiles /nix/var/nix/gcroots/ # Set up the statically computed bits of /etc. rm -f /etc/static ln -s @etc@/etc /etc/static for i in $(cd /etc/static && find * -type l); do mkdir -p /etc/$(dirname $i) rm -f /etc/$i ln -s /etc/static/$i /etc/$i done # Ensure that the module tools can find the kernel modules. export MODULE_DIR=@kernel@/lib/modules/ # Miscellaneous cleanup. rm -rf /var/run mkdir -m 0755 -p /var/run echo -n > /var/run/utmp # must exist chmod 664 /var/run/utmp # Start udev. udevd --daemon # Let udev create device nodes for all modules that have already been # loaded into the kernel (or for which support is built into the # kernel). udevtrigger udevsettle # wait for udev to finish # !!! Hack - should be done with udev rules. chmod 666 /dev/null # Enable a password-less root login. source @accounts@ if ! test -e /etc/passwd; then if test -n "@readOnlyRoot@"; then rootHome=/ else rootHome=/home/root mkdir -p $rootHome fi createUser root '' 0 0 'System administrator' $rootHome/var/empty @shell@ fi if ! test -e /etc/group; then echo "root:*:0" > /etc/group fi # Set up Nix accounts. if test -z "@readOnlyRoot@"; then for i in $(seq 1 10); do account=nixbld$i if ! userExists $account; then createUser $account x \ $((i + 30000)) 30000 \ 'Nix build user' /var/empty /noshell fi accounts="$accounts${accounts:+,}$account" done if ! grep -q "^nixbld:" /etc/group; then echo "nixbld:*:30000:$accounts" >> /etc/group fi mkdir -p /nix/etc/nix cat > /nix/etc/nix/nix.conf < /etc/profile < $wrapperDir/$i.real chown root.root $wrapperDir/$i chmod 4755 $wrapperDir/$i done # Set the host name. hostname @hostName@ # Start an interactive shell. #exec @shell@ # Start Upstart's init. exec @upstart@/sbin/init -v