rc revision 1.48
1# from: @(#)rc 8.2 (Berkeley) 3/17/94 2# $Id: rc,v 1.48 1994/09/16 23:38:01 mycroft Exp $ 3 4# System startup script run by init on autoboot 5# or after single-user. 6# Output and error are redirected to console by init, 7# and the console is the controlling terminal. 8 9stty status '^T' 10 11# Set shell to ignore SIGINT (2), but not children; 12# shell catches SIGQUIT (3) and returns to single user after fsck. 13trap : 2 14trap : 3 # shouldn't be needed 15 16HOME=/; export HOME 17PATH=/sbin:/bin:/usr/sbin:/usr/bin 18export PATH 19 20if [ -e /fastboot ] 21then 22 echo "Fast boot: skipping disk checks." 23elif [ $1x = autobootx ] 24then 25 echo "Automatic boot in progress: starting file system checks." 26 fsck -p 27 case $? in 28 0) 29 ;; 30 2) 31 exit 1 32 ;; 33 4) 34 echo "Rebooting..." 35 reboot 36 echo "Reboot failed; help!" 37 exit 1 38 ;; 39 8) 40 echo "Automatic file system check failed; help!" 41 exit 1 42 ;; 43 12) 44 echo "Boot interrupted." 45 exit 1 46 ;; 47 130) 48 # interrupt before catcher installed 49 exit 1 50 ;; 51 *) 52 echo "Unknown error; help!" 53 exit 1 54 ;; 55 esac 56fi 57 58trap "echo 'Boot interrupted.'; exit 1" 3 59 60swapon -a 61 62umount -a >/dev/null 2>&1 63mount -a -t nonfs 64rm -f /fastboot # XXX (root now writeable) 65 66# set flags on ttys. (do early, in case they use tty for SLIP in netstart) 67echo 'setting tty flags' 68ttyflags -a 69 70# set hostname, turn on network 71echo 'starting network' 72. /etc/netstart 73 74mount /usr >/dev/null 2>&1 75mount /var >/dev/null 2>&1 76 77# clean up left-over files 78rm -f /etc/nologin 79rm -f /var/spool/lock/LCK.* 80rm -f /var/spool/uucp/STST/* 81(cd /var/run && { rm -rf -- *; install -c -m 664 -g utmp /dev/null utmp; }) 82 83echo -n 'starting rpc daemons:' 84echo -n ' portmap'; portmap 85 86if [ -f /usr/sbin/ypbind -a -d /var/yp ]; then 87 echo -n ' ypbind'; ypbind 88fi 89 90# $nfs_server is imported from /etc/netstart; 91# if $nfs_server == YES, the machine is setup for being an nfs server 92if [ X${nfs_server} = X"YES" -a -r /etc/exports ]; then 93 rm -f /var/db/mountdtab 94 echo -n > /var/db/mountdtab 95 echo -n ' mountd'; mountd 96 echo -n ' nfsd'; nfsd -tun 4 97fi 98 99# $nfs_client is imported from /etc/netstart; 100# if $nfs_client == YES, the machine is setup for being an nfs client 101if [ X${nfs_client} = X"YES" ]; then 102 echo -n ' nfsiod'; nfsiod -n 4 103fi 104 105if [ X${amd} = X"YES" -a -d ${amd_dir} -a -r ${amd_master} ]; then 106 echo -n ' amd' 107 amd -l syslog -x error,noinfo,nostats -p > /var/run/amd.pid \ 108 -a ${amd_dir} `cat ${amd_master}` 109fi 110 111echo '.' 112mount -a -t nfs 113 114echo -n 'starting system logger' 115rm -f /dev/log 116syslogd 117 118# $timed_flags is imported from /etc/netstart; 119# if $timed_flags == NO, timed isn't run. 120if [ "X${timed_flags}" != X"NO" ]; then 121 echo -n ', time daemon'; timed $timed_flags 122fi 123echo '.' 124 125# /var/crash should be a directory or a symbolic link 126# to the crash directory if core dumps are to be saved. 127if [ -d /var/crash ]; then 128 echo checking for core dump... 129 savecore /var/crash 130fi 131 132 echo -n 'checking quotas:' 133quotacheck -a 134 echo ' done.' 135quotaon -a 136 137# build ps databases 138echo 'building databases...' 139kvm_mkdb /netbsd 140dev_mkdb 141 142chmod 666 /dev/tty[pqrs]* 143 144# check the password temp/lock file 145if [ -f /etc/ptmp ] 146then 147 logger -s -p auth.err \ 148 'password file may be incorrect -- /etc/ptmp exists' 149fi 150 151virecovery=/var/tmp/vi.recover/recover.* 152if [ "$virecovery" != "/var/tmp/vi.recover/recover.*" ]; then 153 echo preserving editor files 154 for i in $virecovery; do 155 sendmail -t < $i 156 done 157fi 158 159echo clearing /tmp 160 161# prune quickly with one rm, then use find to clean up /tmp/[lq]* 162# (not needed with mfs /tmp, but doesn't hurt there...) 163(cd /tmp && rm -rf [a-km-pr-zA-Z]* && 164 find . ! -name . ! -name lost+found ! -name quota.user \ 165 ! -name quota.group -exec rm -rf -- {} \; -type d -prune) 166 167if [ -f /var/account/acct ]; then 168 echo 'turning on accounting'; accton /var/account/acct 169fi 170 171echo -n standard daemons: 172echo -n ' update'; update 173echo -n ' cron'; cron 174echo '.' 175 176echo -n starting network daemons: 177 178# $gated and $routed_flags are imported from /etc/netstart. 179# If $gated == YES, gated is used; otherwise routed. 180# If $routed_flags == NO, routed isn't run. 181if [ X${gated} = X"YES" -a -r /etc/gated.conf ]; then 182 echo -n ' gated'; gated $gated_flags 183elif [ "X${routed_flags}" != X"NO" ]; then 184 echo -n ' routed'; routed $routed_flags 185fi 186 187# $name_server is imported from /etc/netstart; 188# if $named_flags != NO, named is run. 189if [ "X${named_flags}" != X"NO" ]; then 190 echo -n ' named'; named $named_flags 191fi 192 193# $rwhod is imported from /etc/netstart; 194# if $rwhod == YES, rwhod is run. 195if [ X${rwhod} = X"YES" ]; then 196 echo -n ' rwhod'; rwhod 197fi 198 199echo -n ' printer'; lpd 200 201# $sendmail_flags is imported from /etc/netstart; 202# If $sendmail_flags == NO or /etc/sendmail.cf doesn't exist, then 203# sendmail isn't run. 204if [ "X${sendmail_flags}" != X"NO" -a -r /etc/sendmail.cf ]; then 205 echo -n ' sendmail'; sendmail ${sendmail_flags} 206fi 207 208echo -n ' inetd'; inetd 209 210# $rarpd_flags is importent from /etc/netstart; 211# If $rarpd_flags == NO or /etc/ethers doesn't exist, then 212# rarpd isn't run. 213if [ "X${rarpd_flags}" != X"NO" -a -r /etc/ethers ]; then 214 echo -n ' rarpd'; rarpd ${rarpd_flags} 215fi 216 217# $bootparamd_flags is importent from /etc/netstart; 218# If $bootparamd_flags == NO or /etc/bootparams doesn't exist, then 219# bootparamd isn't run. 220if [ "X${bootparamd_flags}" != X"NO" -a -r /etc/bootparams ]; then 221 echo -n ' rpc.bootparamd'; rpc.bootparamd ${bootparamd_flags} 222fi 223 224echo '.' 225 226. /etc/rc.local 227 228date 229exit 0 230