Home | History | Annotate | Line # | Download | only in etc
rc revision 1.17
      1 #	@(#)rc	5.27 (Berkeley) 6/5/91
      2 
      3 # System startup script run by init on autoboot
      4 # or after single-user.
      5 # Output and error are redirected to console by init,
      6 # and the console is the controlling terminal.
      7 
      8 stty status '^T'
      9 
     10 # Set shell to ignore SIGINT (2), but not children;
     11 # shell catches SIGQUIT (3) and returns to single user after fsck.
     12 trap : 2
     13 trap : 3	# shouldn't be needed
     14 
     15 HOME=/; export HOME
     16 PATH=/sbin:/bin:/usr/sbin:/usr/bin
     17 export PATH
     18 
     19 if [ -e /fastboot ]
     20 then
     21 	echo Fast boot ... skipping disk checks
     22 elif [ $1x = autobootx ]
     23 then
     24 	echo Automatic reboot in progress...
     25 	fsck -p
     26 	case $? in
     27 	0)
     28 		;;
     29 	2)
     30 		exit 1
     31 		;;
     32 	4)
     33 		reboot
     34 		echo "reboot failed... help!"
     35 		exit 1
     36 		;;
     37 	8)
     38 		echo "Automatic file system check failed... help!"
     39 		exit 1
     40 		;;
     41 	12)
     42 		echo "Reboot interrupted"
     43 		exit 1
     44 		;;
     45 	130)
     46 		# interrupt before catcher installed
     47 		exit 1
     48 		;;
     49 	*)
     50 		echo "Unknown error in reboot"
     51 		exit 1
     52 		;;
     53 	esac
     54 fi
     55 
     56 trap "echo 'Reboot interrupted'; exit 1" 3
     57 
     58 swapon -a
     59 
     60 umount -a >/dev/null 2>&1
     61 mount -a -t nonfs
     62 rm -f /fastboot		# XXX (root now writeable)
     63 
     64 # set hostname, turn on network
     65 echo 'starting network'
     66 . /etc/netstart
     67 
     68 mount -a -t nfs >/dev/null 2>&1 &	# XXX shouldn't need background
     69 
     70 # clean up left-over files
     71 rm -f /etc/nologin
     72 rm -f /var/spool/uucp/LCK.*
     73 rm -f /var/spool/uucp/STST/*
     74 (cd /var/run && { rm -rf -- *; cp /dev/null utmp; chmod 644 utmp; })
     75 
     76 echo -n 'starting system logger'
     77 rm -f /dev/log
     78 syslogd
     79 
     80 # $timedflags is imported from /etc/netstart;
     81 # if $timedflags == NO, timed isn't run.
     82 if [ X${timedflags} != X"NO" ]; then
     83 	echo -n ', time daemon'; timed $timedflags
     84 fi
     85 echo '.'
     86 
     87 # /var/crash should be a directory or a symbolic link
     88 # to the crash directory if core dumps are to be saved.
     89 if [ -d /var/crash ]; then
     90 	echo checking for core dump...
     91 	savecore /var/crash
     92 fi
     93 
     94 #				echo -n 'checking quotas:'
     95 #quotacheck -a
     96 #				echo ' done.'
     97 #quotaon -a
     98 
     99 # build ps databases
    100 echo 'building databases...'
    101 kvm_mkdb /netbsd
    102 dev_mkdb
    103 
    104 chmod 666 /dev/tty[pqrs]*
    105 
    106 # check the password temp/lock file
    107 if [ -f /etc/ptmp ]
    108 then
    109 	logger -s -p auth.err \
    110 	'password file may be incorrect -- /etc/ptmp exists'
    111 fi
    112 
    113 echo preserving editor files
    114 (cd /var/tmp && /usr/libexec/elvispreserve "-the system rebooted" elvis* &&
    115      rm -f elvis[0-9a-f][0-9a-f][0-9a-f][0-9a-f]* \
    116 	 elvis_[0-9a-f][0-9a-f][0-9a-f][0-9a-f]*)
    117 
    118 echo clearing /tmp
    119 
    120 # prune quickly with one rm, then use find to clean up /tmp/[lq]*
    121 # (not needed with mfs /tmp, but doesn't hurt there...)
    122 (cd /tmp && rm -rf [a-km-pr-zA-Z]* &&
    123     find . ! -name . ! -name lost+found ! -name quotas \
    124 	-exec rm -rf -- {} \; -type d -prune)
    125 
    126 if [ -d /var/account ]; then
    127 	echo 'turning on accounting'
    128 	accountant
    129 	accton
    130 fi
    131 
    132 echo -n standard daemons:
    133 echo -n ' update';		update
    134 echo -n ' crond';		/usr/libexec/crond
    135 echo '.'
    136 
    137 echo -n starting network daemons:
    138 
    139 # $gated and $routedflags are imported from /etc/netstart.
    140 # If $gated == YES, gated is used; otherwise routed.
    141 # If $routedflags == NO, routed isn't run.
    142 if [ X${gated} = X"YES" -a -r /etc/gated.conf ]; then
    143 	echo -n ' gated';	gated $gatedflags
    144 elif [ X${routedflags} != X"NO" ]; then
    145 	echo -n ' routed';	routed $routedflags
    146 fi
    147 
    148 if [ X${name_server} = X"YES" -a -r /etc/named.boot ]; then
    149 	echo -n ' named';		named
    150 fi
    151 
    152 # $rwhod is imported from /etc/netstart;
    153 # if $rwhod == YES, rwhod is run.
    154 if [ X${rwhod} = X"YES" ]; then
    155 	echo -n ' rwhod';	rwhod
    156 fi
    157 
    158 echo -n ' printer';		lpd
    159 
    160 echo -n ' portmap';		portmap
    161 
    162 # if $nfs_server == YES, the machine is setup for being an nfs server
    163 if [ X${nfs_server} = X"YES" -a -r /etc/exports ]; then
    164 	rm -f /var/db/mountdtab	
    165 	echo -n ' mountd';		mountd
    166 	echo -n ' nfsd';		nfsd -u 0,0,4 -t 0,0
    167 fi
    168 
    169 # if $nfs_client == YES, the machine is setup for being an nfs client
    170 if [ X${nfs_client} = X"YES" ]; then
    171 	echo -n ' nfsiod';		nfsiod 4
    172 fi
    173 
    174 echo -n ' sendmail';		sendmail -bd -q30m
    175 echo -n ' inetd';		inetd
    176 echo '.'
    177 
    178 sh /etc/rc.local
    179 
    180 date
    181 
    182 exit 0
    183