rc revision 1.37
1# @(#)rc 5.27 (Berkeley) 6/5/91 2# $Id: rc,v 1.37 1994/03/17 23:22:40 cgd 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..." 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 in reboot" 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 hostname, turn on network 67echo 'starting network' 68. /etc/netstart 69 70mount /usr >/dev/null 2>&1 71 72echo -n 'starting rpc daemons:' 73echo -n ' portmap'; portmap 74 75if [ -f /usr/sbin/ypbind -a -d /var/yp ]; then 76 echo -n ' ypbind'; ypbind 77fi 78 79# $nfs_server is imported from /etc/netstart; 80# if $nfs_server == YES, the machine is setup for being an nfs server 81if [ X${nfs_server} = X"YES" -a -r /etc/exports ]; then 82 rm -f /var/db/mountdtab 83 echo -n ' mountd'; mountd 84 echo -n ' nfsd'; nfsd -u 0,0,4 -t 0,0 85fi 86 87# $nfs_client is imported from /etc/netstart; 88# if $nfs_client == YES, the machine is setup for being an nfs client 89if [ X${nfs_client} = X"YES" ]; then 90 echo -n ' nfsiod'; nfsiod 4 91fi 92 93if [ X${amd} = X"YES" -a -d ${amd_dir} -a -r ${amd_master} ]; then 94 echo -n ' amd' 95 amd -l syslog -x error,noinfo,nostats -a ${amd_dir} `cat ${amd_master}` 96fi 97 98echo '.' 99mount -a -t nfs 100 101# clean up left-over files 102rm -f /etc/nologin 103rm -f /var/spool/lock/LCK.* 104rm -f /var/spool/uucp/STST/* 105(cd /var/run && { rm -rf -- *; cp /dev/null utmp; chmod 644 utmp; }) 106 107echo 'runtime link editor directory cache' 108rm -f /var/run/ld.so.hints 109ldconfig 110 111echo -n 'starting system logger' 112rm -f /dev/log 113syslogd 114 115# $timed_flags is imported from /etc/netstart; 116# if $timed_flags == NO, timed isn't run. 117if [ "X${timed_flags}" != X"NO" ]; then 118 echo -n ', time daemon'; timed $timed_flags 119fi 120echo '.' 121 122# /var/crash should be a directory or a symbolic link 123# to the crash directory if core dumps are to be saved. 124if [ -d /var/crash ]; then 125 echo checking for core dump... 126 savecore /var/crash 127fi 128 129# echo -n 'checking quotas:' 130#quotacheck -a 131# echo ' done.' 132#quotaon -a 133 134# build ps databases 135echo 'building databases...' 136kvm_mkdb /netbsd 137dev_mkdb 138 139chmod 666 /dev/tty[pqrs]* 140 141# check the password temp/lock file 142if [ -f /etc/ptmp ] 143then 144 logger -s -p auth.err \ 145 'password file may be incorrect -- /etc/ptmp exists' 146fi 147 148virecovery=/var/tmp/vi.recover/recover.* 149if [ "$virecovery" != "/var/tmp/vi.recover/recover.*" ]; then 150 echo preserving editor files 151 for i in $virecovery; do 152 sendmail -t < $i 153 done 154fi 155 156echo clearing /tmp 157 158# prune quickly with one rm, then use find to clean up /tmp/[lq]* 159# (not needed with mfs /tmp, but doesn't hurt there...) 160(cd /tmp && rm -rf [a-km-pr-zA-Z]* && 161 find . ! -name . ! -name lost+found ! -name quotas \ 162 -exec rm -rf -- {} \; -type d -prune) 163 164if [ -f /var/account/acct ]; then 165 echo 'turning on accounting'; accton /var/account/acct 166fi 167 168echo -n standard daemons: 169echo -n ' update'; update 170echo -n ' cron'; cron 171echo '.' 172 173echo -n starting network daemons: 174 175# $gated and $routed_flags are imported from /etc/netstart. 176# If $gated == YES, gated is used; otherwise routed. 177# If $routed_flags == NO, routed isn't run. 178if [ X${gated} = X"YES" -a -r /etc/gated.conf ]; then 179 echo -n ' gated'; gated $gated_flags 180elif [ "X${routed_flags}" != X"NO" ]; then 181 echo -n ' routed'; routed $routed_flags 182fi 183 184# $name_server is imported from /etc/netstart; 185# if $name_server == YES, named is run. 186if [ X${name_server} = X"YES" -a -r /etc/named.boot ]; then 187 echo -n ' named'; named 188fi 189 190# $rwhod is imported from /etc/netstart; 191# if $rwhod == YES, rwhod is run. 192if [ X${rwhod} = X"YES" ]; then 193 echo -n ' rwhod'; rwhod 194fi 195 196echo -n ' printer'; lpd 197 198# $sendmail_flags is imported from /etc/netstart; 199# If $sendmail_flags == NO or /etc/sendmail.cf doesn't exist, then 200# sendmail isn't run. 201if [ "X${sendmail_flags}" != X"NO" -a -r /etc/sendmail.cf ]; then 202 echo -n ' sendmail'; sendmail ${sendmail_flags} 203fi 204 205echo -n ' inetd'; inetd 206 207# $rarpd_flags is importent from /etc/netstart; 208# If $rarpd_flags == NO or /etc/ethers doesn't exist, then 209# rarpd isn't run. 210if [ "X${rarpd_flags}" != X"NO" -a -r /etc/ethers ]; then 211 echo -n ' rarpd'; rarpd ${rarpd_flags} 212fi 213 214# $bootparamd_flags is importent from /etc/netstart; 215# If $bootparamd_flags == NO or /etc/bootparams doesn't exist, then 216# bootparamd isn't run. 217if [ "X${bootparamd_flags}" != X"NO" -a -r /etc/bootparams ]; then 218 echo -n ' rpc.bootparamd'; rpc.bootparamd ${bootparamd_flags} 219fi 220 221echo '.' 222 223. /etc/rc.local 224 225date 226 227exit 0 228