Home | History | Annotate | Line # | Download | only in etc
rc revision 1.95
      1  1.95  drochner #	$NetBSD: rc,v 1.95 1997/10/10 09:37:54 drochner Exp $
      2  1.73     perry #	originally from: @(#)rc	8.2 (Berkeley) 3/17/94
      3   1.1       cgd 
      4   1.1       cgd # System startup script run by init on autoboot
      5   1.1       cgd # or after single-user.
      6   1.1       cgd # Output and error are redirected to console by init,
      7   1.1       cgd # and the console is the controlling terminal.
      8   1.1       cgd 
      9   1.1       cgd stty status '^T'
     10   1.1       cgd 
     11   1.1       cgd # Set shell to ignore SIGINT (2), but not children;
     12   1.1       cgd # shell catches SIGQUIT (3) and returns to single user after fsck.
     13   1.1       cgd trap : 2
     14   1.1       cgd trap : 3	# shouldn't be needed
     15   1.1       cgd 
     16  1.68   mycroft export HOME=/
     17  1.68   mycroft export PATH=/sbin:/bin:/usr/sbin:/usr/bin
     18  1.50   thorpej 
     19  1.50   thorpej # Configure ccd devices.
     20  1.63       mrg if [ -f /etc/ccd.conf ]; then
     21  1.50   thorpej 	ccdconfig -C
     22  1.50   thorpej fi
     23   1.1       cgd 
     24  1.79   thorpej # Add all block-type swap devices; these might be necessary
     25  1.79   thorpej # during disk checks.
     26  1.79   thorpej swapctl -A -t blk
     27  1.79   thorpej 
     28  1.63       mrg if [ -e /fastboot ]; then
     29  1.38       cgd 	echo "Fast boot: skipping disk checks."
     30  1.68   mycroft elif [ "$1" = autoboot ]; then
     31  1.38       cgd 	echo "Automatic boot in progress: starting file system checks."
     32   1.1       cgd 	fsck -p
     33   1.1       cgd 	case $? in
     34   1.1       cgd 	0)
     35   1.1       cgd 		;;
     36   1.1       cgd 	2)
     37   1.1       cgd 		exit 1
     38   1.1       cgd 		;;
     39   1.1       cgd 	4)
     40  1.35       cgd 		echo "Rebooting..."
     41   1.1       cgd 		reboot
     42  1.38       cgd 		echo "Reboot failed; help!"
     43   1.1       cgd 		exit 1
     44   1.1       cgd 		;;
     45   1.1       cgd 	8)
     46  1.38       cgd 		echo "Automatic file system check failed; help!"
     47   1.1       cgd 		exit 1
     48   1.1       cgd 		;;
     49   1.1       cgd 	12)
     50  1.38       cgd 		echo "Boot interrupted."
     51   1.1       cgd 		exit 1
     52   1.1       cgd 		;;
     53   1.1       cgd 	130)
     54   1.1       cgd 		# interrupt before catcher installed
     55   1.1       cgd 		exit 1
     56   1.1       cgd 		;;
     57   1.1       cgd 	*)
     58  1.38       cgd 		echo "Unknown error; help!"
     59   1.1       cgd 		exit 1
     60   1.1       cgd 		;;
     61   1.1       cgd 	esac
     62   1.1       cgd fi
     63   1.1       cgd 
     64  1.38       cgd trap "echo 'Boot interrupted.'; exit 1" 3
     65   1.1       cgd 
     66   1.1       cgd umount -a >/dev/null 2>&1
     67  1.83  drochner mount /
     68   1.1       cgd rm -f /fastboot		# XXX (root now writeable)
     69  1.40       cgd 
     70  1.90     veego if [ -f /etc/rc.subr ]; then
     71  1.90     veego 	. /etc/rc.subr
     72  1.89       cjs else
     73  1.90     veego 	echo "Can't read /etc/rc.subr; aborting."
     74  1.89       cjs 	exit 1;
     75  1.89       cjs fi
     76  1.89       cjs 
     77  1.71   mycroft if [ -f /etc/rc.conf ]; then
     78  1.63       mrg 	. /etc/rc.conf
     79  1.63       mrg fi
     80  1.63       mrg 
     81  1.89       cjs if [ "$rc_configured" != YES ]; then
     82  1.89       cjs 	echo "/etc/rc.conf is not configured. Multiuser boot aborted."
     83  1.89       cjs 	exit 1
     84  1.89       cjs fi
     85  1.89       cjs 
     86  1.40       cgd # set flags on ttys.  (do early, in case they use tty for SLIP in netstart)
     87  1.40       cgd echo 'setting tty flags'
     88  1.40       cgd ttyflags -a
     89   1.1       cgd 
     90  1.83  drochner # load kernel modules specified in /etc/lkm.conf if the /usr filesystem
     91  1.83  drochner # is already present with "/" or can be mounted now
     92  1.93  drochner if checkyesno lkm && [ -f /etc/rc.lkm ]; then
     93  1.83  drochner 	mount /usr >/dev/null 2>&1
     94  1.83  drochner 	if [ -x /usr/bin/ld ]; then
     95  1.83  drochner 		lkmstage=BEFORENET
     96  1.83  drochner 		. /etc/rc.lkm
     97  1.83  drochner 	fi
     98  1.63       mrg fi
     99  1.63       mrg 
    100   1.1       cgd # set hostname, turn on network
    101   1.1       cgd echo 'starting network'
    102  1.76    scottr sh /etc/netstart
    103  1.76    scottr if [ $? -ne 0 ]; then
    104  1.76    scottr 	exit 1
    105  1.76    scottr fi
    106   1.1       cgd 
    107  1.95  drochner for fs in /usr /var $critical_filesystems; do
    108  1.95  drochner 	mount | (
    109  1.95  drochner         		ismounted=no
    110  1.95  drochner         		while read what _on on _type type; do
    111  1.95  drochner                		 if [ $on = $fs ]; then
    112  1.95  drochner                         			ismounted=yes
    113  1.95  drochner                		 fi
    114  1.95  drochner         		done
    115  1.95  drochner        		if [ $ismounted = no ]; then
    116  1.95  drochner 			mount $fs >/dev/null 2>&1
    117  1.95  drochner 		fi
    118  1.95  drochner 	)
    119  1.95  drochner done
    120  1.79   thorpej 
    121  1.79   thorpej # "Critical" file systems are now mounted.  Go ahead and swap
    122  1.79   thorpej # to files now, since they will be residing in the critical file
    123  1.79   thorpej # systems (or, at least, better).
    124  1.79   thorpej swapctl -A -t noblk
    125  1.26   deraadt 
    126  1.41       jtc # clean up left-over files
    127  1.41       jtc rm -f /etc/nologin
    128  1.41       jtc rm -f /var/spool/lock/LCK.*
    129  1.41       jtc rm -f /var/spool/uucp/STST/*
    130  1.45       cgd (cd /var/run && { rm -rf -- *; install -c -m 664 -g utmp /dev/null utmp; })
    131  1.41       jtc 
    132  1.84     veego # start the system logger first, so that all messages from daemons
    133  1.84     veego # are logged, then start savecore to get a dump on low memory systems
    134  1.84     veego # and then start the name server.
    135  1.63       mrg 
    136  1.89       cjs if checkyesno syslogd; then
    137  1.63       mrg 	echo 'starting system logger'
    138  1.63       mrg 	rm -f /dev/log
    139  1.63       mrg 	syslogd $syslogd_flags
    140  1.94     lukem fi
    141  1.94     lukem 
    142  1.94     lukem # Enable ipmon (only useful if ipfilter is running)
    143  1.94     lukem # NOTE: requires the IPFILTER_LOG kernel option.
    144  1.94     lukem if checkyesno ipmon; then
    145  1.94     lukem 	echo 'starting ipmon'
    146  1.94     lukem 	ipmon $ipmon_flags &
    147  1.63       mrg fi
    148  1.63       mrg 
    149  1.84     veego # /var/crash should be a directory or a symbolic link
    150  1.84     veego # to the crash directory if core dumps are to be saved.
    151  1.89       cjs if checkyesno savecore; then
    152  1.89       cjs 	if [ -d /var/crash ]; then
    153  1.89       cjs 		echo checking for core dump...
    154  1.89       cjs 		savecore $savecore_flags /var/crash
    155  1.89       cjs 	else
    156  1.89       cjs 		logger -s "WARNING: no /var/crash directory; savecore not run."
    157  1.84     veego 	fi
    158  1.84     veego fi
    159  1.84     veego 
    160  1.89       cjs if checkyesno named; then
    161  1.89       cjs 	echo 'starting name server';	named $named_flags
    162  1.89       cjs fi
    163  1.89       cjs 
    164  1.89       cjs # set time, if requested
    165  1.89       cjs if checkyesno ntpdate; then
    166  1.91     mikel 	if [ -z "$ntpdate_hosts" ]; then
    167  1.89       cjs 		ntpdate_hosts=`awk '/^server/ {print $2}' </etc/ntp.conf`
    168  1.89       cjs 	fi
    169  1.89       cjs 	if [ -n "$ntpdate_hosts"  ]; then
    170  1.89       cjs 		echo 'Setting date via ntp.'
    171  1.89       cjs 		ntpdate -b $ntpdate_hosts
    172  1.67   mycroft 	fi
    173  1.63       mrg fi
    174  1.63       mrg 
    175  1.84     veego # now start the rpc servers, for YP server/client.
    176  1.63       mrg echo -n 'starting rpc daemons:'
    177  1.63       mrg 
    178  1.63       mrg # note that portmap is generally required for all other rpc services.
    179  1.89       cjs if checkyesno portmap; then
    180  1.63       mrg 	echo -n ' portmap';             portmap
    181  1.63       mrg fi
    182  1.63       mrg 
    183  1.89       cjs if checkyesno ypserv; then
    184  1.63       mrg         echo -n ' ypserv';              ypserv $ypserv_flags
    185  1.63       mrg fi
    186  1.63       mrg 
    187  1.89       cjs if checkyesno ypbind; then
    188  1.63       mrg         echo -n ' ypbind';              ypbind $ypbind_flags
    189  1.63       mrg fi
    190  1.63       mrg 
    191  1.89       cjs if checkyesno yppasswdd; then
    192  1.63       mrg         echo -n ' rpc.yppasswdd';       rpc.yppasswdd $yppasswdd_flags
    193  1.63       mrg fi
    194  1.63       mrg 
    195  1.89       cjs if checkyesno bootparamd; then
    196  1.89       cjs 	if [ -r /etc/bootparams ]; then
    197  1.89       cjs 		echo -n ' rpc.bootparamd'; rpc.bootparamd $bootparamd_flags
    198  1.89       cjs 	else
    199  1.89       cjs 		echo
    200  1.89       cjs 		logger -s "WARNING: /etc/bootparams not found. " \
    201  1.89       cjs 		    "bootparamd not started."
    202  1.67   mycroft 	fi
    203  1.63       mrg fi
    204  1.63       mrg 
    205  1.84     veego echo '.'
    206  1.84     veego 
    207  1.84     veego # load kernel modules specified in /etc/lkm.conf
    208  1.89       cjs if checkyesno lkm; then
    209  1.89       cjs 	if [ -r /etc/rc.lkm ]; then
    210  1.89       cjs 		lkmstage=BEFOREMOUNT
    211  1.89       cjs 		. /etc/rc.lkm
    212  1.89       cjs 	else
    213  1.89       cjs 		logger -s "WARNING: /etc/rc.lkm not found; LKMs not loaded."
    214  1.89       cjs 	fi
    215  1.84     veego fi
    216  1.84     veego 
    217  1.84     veego mount -a
    218  1.84     veego 
    219  1.84     veego # now start the rpc servers, for NFS server/client.
    220  1.90     veego echo -n 'starting nfs daemons:'
    221  1.84     veego 
    222  1.67   mycroft nfs_locking=NO
    223  1.67   mycroft 
    224  1.89       cjs if checkyesno nfs_server; then
    225  1.89       cjs 	if [ -r /etc/exports ]; then
    226  1.89       cjs 		rm -f /var/db/mountdtab
    227  1.89       cjs 		echo -n > /var/db/mountdtab
    228  1.89       cjs 		echo -n ' mountd';              mountd $mountd_flags
    229  1.89       cjs 		echo -n ' nfsd';                nfsd $nfsd_flags
    230  1.89       cjs 		nfs_locking=MAYBE
    231  1.89       cjs 	else
    232  1.89       cjs 		echo
    233  1.89       cjs 		logger -s "WARNING: /etc/exports not readable; " \
    234  1.89       cjs 		    "NFS server not started."
    235  1.69   mycroft 	fi
    236   1.1       cgd fi
    237  1.63       mrg 
    238  1.89       cjs if checkyesno nfs_client; then
    239  1.63       mrg         echo -n ' nfsiod';              nfsiod $nfsiod_flags
    240  1.67   mycroft 	nfs_locking=MAYBE
    241  1.66    scottr fi
    242  1.66    scottr 
    243  1.67   mycroft if [ "$nfs_locking" != NO ]; then
    244  1.89       cjs 	if checkyesno statd; then
    245  1.71   mycroft 		echo -n ' rpc.statd';		rpc.statd $statd_flags
    246  1.66    scottr 	fi
    247  1.89       cjs 	if checkyesno lockd; then
    248  1.71   mycroft 		echo -n ' rpc.lockd';		rpc.lockd $lockd_flags
    249  1.66    scottr 	fi
    250  1.63       mrg fi
    251  1.63       mrg 
    252  1.89       cjs if checkyesno amd; then
    253  1.89       cjs 	if [ -d "$amd_dir" ]; then
    254  1.89       cjs 		if [ -r "$amd_master" ]; then
    255  1.89       cjs 			echo -n ' amd'
    256  1.89       cjs 			amd $amd_flags -p -a $amd_dir `cat $amd_master` \
    257  1.89       cjs 			    > /var/run/amd.pid
    258  1.89       cjs 		else
    259  1.89       cjs 			echo
    260  1.89       cjs 			logger -s "WARNING: \$amd_master ($amd_master)not " \
    261  1.89       cjs 			    "readable; amd not started."
    262  1.89       cjs 		fi
    263  1.89       cjs 	else
    264  1.89       cjs 		echo
    265  1.89       cjs 		logger -s "WARNING: \$amd_dir ($amd_dir) not a directory; " \
    266  1.89       cjs 		    "amd not started."
    267  1.67   mycroft 	fi
    268  1.63       mrg fi
    269  1.63       mrg 
    270   1.1       cgd echo '.'
    271  1.83  drochner 
    272  1.63       mrg if [ -f /sbin/ldconfig ]; then
    273  1.63       mrg 	echo 'creating runtime link editor directory cache.'
    274  1.88   thorpej 	ldconfig
    275  1.63       mrg fi 
    276  1.83  drochner 
    277  1.83  drochner # load kernel modules specified in /etc/lkm.conf
    278  1.89       cjs if checkyesno lkm && [ -f /etc/rc.lkm ]; then
    279  1.83  drochner 	lkmstage=AFTERMOUNT
    280  1.83  drochner 	. /etc/rc.lkm
    281   1.1       cgd fi
    282   1.1       cgd 
    283  1.89       cjs echo -n 'checking quotas:'; quotacheck -a; echo ' done.'
    284  1.47   deraadt quotaon -a
    285   1.1       cgd 
    286   1.1       cgd # build ps databases
    287   1.2       cgd echo 'building databases...'
    288  1.11       cgd kvm_mkdb /netbsd
    289   1.1       cgd dev_mkdb
    290   1.1       cgd 
    291   1.1       cgd chmod 666 /dev/tty[pqrs]*
    292   1.1       cgd 
    293   1.1       cgd # check the password temp/lock file
    294   1.1       cgd if [ -f /etc/ptmp ]
    295   1.1       cgd then
    296   1.1       cgd 	logger -s -p auth.err \
    297   1.1       cgd 	'password file may be incorrect -- /etc/ptmp exists'
    298   1.1       cgd fi
    299   1.1       cgd 
    300  1.85     perry virecovery=`echo /var/tmp/vi.recover/recover.*`
    301  1.32   mycroft if [ "$virecovery" != "/var/tmp/vi.recover/recover.*" ]; then
    302  1.32   mycroft 	echo preserving editor files
    303  1.32   mycroft 	for i in $virecovery; do
    304  1.32   mycroft 		sendmail -t < $i
    305  1.32   mycroft 	done
    306  1.32   mycroft fi
    307   1.1       cgd 
    308   1.1       cgd echo clearing /tmp
    309   1.1       cgd 
    310  1.65     mikel # Prune quickly with one rm, then use find to clean up /tmp/[lq]* (this
    311  1.65     mikel # is not needed with mfs /tmp, but doesn't hurt anything).
    312   1.1       cgd (cd /tmp && rm -rf [a-km-pr-zA-Z]* &&
    313  1.46   deraadt     find . ! -name . ! -name lost+found ! -name quota.user \
    314  1.46   deraadt 	! -name quota.group -exec rm -rf -- {} \; -type d -prune)
    315   1.1       cgd 
    316  1.74     perry # Update kernel info in /etc/motd
    317  1.74     perry # Must be done *before* interactive logins are possible to prevent
    318  1.74     perry # possible race conditions.
    319  1.89       cjs if checkyesno update_motd; then
    320  1.74     perry 	echo 'updating motd.'
    321  1.74     perry 	if [ ! -f /etc/motd ]; then
    322  1.74     perry 		install -c -o root -g wheel -m 664 /dev/null /etc/motd
    323  1.74     perry 	fi
    324  1.74     perry 	T=/tmp/_motd
    325  1.74     perry 	rm -f $T
    326  1.74     perry 	sysctl -n kern.version | sed 1q > $T
    327  1.74     perry 	echo "" >> $T
    328  1.74     perry 	sed '1,/^$/d' < /etc/motd >> $T
    329  1.74     perry 	cmp -s $T /etc/motd || cp $T /etc/motd
    330  1.74     perry 	rm -f $T
    331  1.74     perry fi
    332  1.74     perry 
    333  1.34       cgd if [ -f /var/account/acct ]; then
    334  1.34       cgd 	echo 'turning on accounting';	accton /var/account/acct
    335  1.34       cgd fi
    336   1.1       cgd 
    337   1.1       cgd echo -n standard daemons:
    338  1.89       cjs if checkyesno update; then
    339  1.70   mycroft 	echo -n ' update';		update $update_flags
    340  1.70   mycroft fi
    341  1.31       jtc echo -n ' cron';		cron
    342   1.1       cgd echo '.'
    343   1.1       cgd 
    344  1.63       mrg # now start all the other daemons
    345   1.1       cgd echo -n starting network daemons:
    346   1.1       cgd 
    347  1.89       cjs if checkyesno gated && checkyesno routed; then
    348  1.89       cjs 	echo
    349  1.89       cjs 	logger -s "WARNING: gated and routed both requested to be run: " \
    350  1.89       cjs 	    "running only gated."
    351  1.89       cjs 	routed=NO
    352  1.89       cjs fi
    353  1.89       cjs 
    354  1.89       cjs if checkyesno gated; then
    355  1.89       cjs 	if [ -r /etc/gated.conf ]; then
    356  1.89       cjs 		echo -n ' gated';		gated $gated_flags
    357  1.89       cjs 	else
    358  1.89       cjs 		logger -s "WARNING: no /etc/gated.conf; gated not started."
    359  1.67   mycroft 	fi
    360  1.89       cjs fi
    361  1.89       cjs 
    362  1.89       cjs if checkyesno routed; then
    363  1.48   mycroft 	echo -n ' routed';		routed $routed_flags
    364   1.1       cgd fi
    365   1.1       cgd 
    366  1.89       cjs if checkyesno mrouted; then
    367  1.55   thorpej 	echo -n ' mrouted';		mrouted $mrouted_flags
    368  1.55   thorpej fi
    369  1.55   thorpej 
    370  1.89       cjs if checkyesno timed; then
    371  1.67   mycroft 	echo -n ' timed'; 		timed $timed_flags
    372  1.63       mrg fi
    373  1.63       mrg 
    374  1.89       cjs if checkyesno xntpd; then
    375  1.67   mycroft 	echo -n ' xntpd';		xntpd $xntpd_flags
    376  1.61       mrg fi
    377  1.61       mrg 
    378  1.89       cjs if checkyesno dhcpd; then
    379  1.89       cjs 	if [ -r /etc/dhcpd.conf ]; then
    380  1.89       cjs 		echo -n ' dhcpd';		dhcpd $dhcpd_flags
    381  1.89       cjs 	else
    382  1.89       cjs 		echo
    383  1.89       cjs 		logger -s "WARNING: /etc/dhcpd.conf not readable; " \
    384  1.89       cjs 		    "dhcpd not started."
    385  1.67   mycroft 	fi
    386  1.29   mycroft fi
    387  1.29   mycroft 
    388  1.89       cjs if checkyesno rwhod; then
    389  1.48   mycroft 	echo -n ' rwhod';		rwhod
    390   1.1       cgd fi
    391   1.1       cgd 
    392  1.89       cjs if checkyesno lpd; then
    393  1.89       cjs 	echo -n ' lpd';			lpd $lpd_flags
    394  1.60       tls fi
    395  1.60       tls 
    396  1.63       mrg # We call sendmail with a full path so that SIGHUP works.
    397  1.89       cjs if checkyesno sendmail; then
    398  1.89       cjs 	if [ -r /etc/sendmail.cf ]; then
    399  1.89       cjs 		echo -n ' sendmail';	/usr/sbin/sendmail $sendmail_flags
    400  1.89       cjs 	else
    401  1.89       cjs 		echo
    402  1.89       cjs 		logger -s "WARNING: /etc/sendmail.cf not readable; " \
    403  1.89       cjs 		    "sendmail not started."
    404  1.67   mycroft 	fi
    405  1.60       tls fi
    406  1.60       tls 
    407  1.89       cjs if checkyesno rarpd; then
    408  1.89       cjs 	if [ -r /etc/ethers ]; then
    409  1.89       cjs 		echo -n ' rarpd';	rarpd $rarpd_flags
    410  1.89       cjs 	else
    411  1.89       cjs 		echo
    412  1.89       cjs 		logger -s "WARNING: /etc/ethers not readable; " \
    413  1.89       cjs 		    "rarpd not started."
    414  1.67   mycroft 	fi
    415  1.60       tls fi
    416  1.60       tls 
    417  1.89       cjs if checkyesno rbootd; then
    418  1.89       cjs 	if [ -r /etc/rbootd.conf ]; then
    419  1.89       cjs 		echo -n ' rbootd';	rbootd $rbootd_flags
    420  1.89       cjs 	else
    421  1.89       cjs 		echo
    422  1.89       cjs 		logger -s "WARNING: /etc/rbootd.conf not readable; " \
    423  1.89       cjs 		    "rarpd not started."
    424  1.67   mycroft 	fi
    425  1.72       cjs fi
    426  1.72       cjs 
    427  1.89       cjs if checkyesno mopd; then
    428  1.72       cjs 	echo -n ' mopd';		mopd $mopd_flags
    429  1.86     perry fi
    430  1.86     perry 
    431  1.89       cjs if checkyesno apmd; then
    432  1.86     perry 	echo -n ' apmd';		apmd $apmd_flags
    433  1.52   thorpej fi
    434  1.52   thorpej 
    435  1.89       cjs if checkyesno inetd; then
    436  1.89       cjs 	if [ -r /etc/inetd.conf ]; then
    437  1.89       cjs 		echo -n ' inetd';	inetd $inetd_flags
    438  1.89       cjs 	else
    439  1.89       cjs 		echo
    440  1.89       cjs 		logger -s "WARNING: /etc/inetd.conf not readable; " \
    441  1.89       cjs 		    "inetd not started."
    442  1.67   mycroft 	fi
    443  1.30   mycroft fi
    444  1.30   mycroft 
    445   1.1       cgd echo '.'
    446  1.73     perry 
    447  1.73     perry # Kerberos runs ONLY on the Kerberos server machine
    448  1.89       cjs if checkyesno kerberos; then
    449  1.73     perry 	echo -n 'starting kerberos daemons:'
    450  1.73     perry 	echo -n ' kerberos';	kerberos >> /var/log/kerberos.log &
    451  1.73     perry 	echo -n ' kadmind';	kadmind -n >> /var/log/kadmind.log &
    452  1.73     perry 	echo '.'
    453  1.73     perry fi
    454   1.1       cgd 
    455  1.25   mycroft . /etc/rc.local
    456   1.1       cgd 
    457   1.1       cgd date
    458   1.1       cgd exit 0
    459