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