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