1*8e74b1f0Smillert# $OpenBSD: rc,v 1.24 1996/09/07 20:45:24 millert Exp $ 2df930be7Sderaadt 3df930be7Sderaadt# System startup script run by init on autoboot 4df930be7Sderaadt# or after single-user. 5df930be7Sderaadt# Output and error are redirected to console by init, 6df930be7Sderaadt# and the console is the controlling terminal. 7df930be7Sderaadt 8df930be7Sderaadtstty status '^T' 9df930be7Sderaadt 10df930be7Sderaadt# Set shell to ignore SIGINT (2), but not children; 11df930be7Sderaadt# shell catches SIGQUIT (3) and returns to single user after fsck. 12df930be7Sderaadttrap : 2 13df930be7Sderaadttrap : 3 # shouldn't be needed 14df930be7Sderaadt 15df930be7SderaadtHOME=/; export HOME 16df930be7SderaadtPATH=/sbin:/bin:/usr/sbin:/usr/bin 17df930be7Sderaadtexport PATH 18df930be7Sderaadt 19df930be7Sderaadt# Configure ccd devices. 208b7444a6Sderaadtif [ -f /etc/ccd.conf ]; then 21df930be7Sderaadt ccdconfig -C 22df930be7Sderaadtfi 23df930be7Sderaadt 248b7444a6Sderaadtif [ -e /fastboot ]; then 25df930be7Sderaadt echo "Fast boot: skipping disk checks." 268b7444a6Sderaadtelif [ $1x = autobootx ]; then 27df930be7Sderaadt echo "Automatic boot in progress: starting file system checks." 28df930be7Sderaadt fsck -p 29df930be7Sderaadt case $? in 30df930be7Sderaadt 0) 31df930be7Sderaadt ;; 32df930be7Sderaadt 2) 33df930be7Sderaadt exit 1 34df930be7Sderaadt ;; 35df930be7Sderaadt 4) 36df930be7Sderaadt echo "Rebooting..." 37df930be7Sderaadt reboot 38df930be7Sderaadt echo "Reboot failed; help!" 39df930be7Sderaadt exit 1 40df930be7Sderaadt ;; 41df930be7Sderaadt 8) 42df930be7Sderaadt echo "Automatic file system check failed; help!" 43df930be7Sderaadt exit 1 44df930be7Sderaadt ;; 45df930be7Sderaadt 12) 46df930be7Sderaadt echo "Boot interrupted." 47df930be7Sderaadt exit 1 48df930be7Sderaadt ;; 49df930be7Sderaadt 130) 50df930be7Sderaadt # interrupt before catcher installed 51df930be7Sderaadt exit 1 52df930be7Sderaadt ;; 53df930be7Sderaadt *) 54df930be7Sderaadt echo "Unknown error; help!" 55df930be7Sderaadt exit 1 56df930be7Sderaadt ;; 57df930be7Sderaadt esac 58df930be7Sderaadtfi 59df930be7Sderaadt 60df930be7Sderaadttrap "echo 'Boot interrupted.'; exit 1" 3 61df930be7Sderaadt 62df930be7Sderaadtswapon -a 63df930be7Sderaadt 64df930be7Sderaadtumount -a >/dev/null 2>&1 65df930be7Sderaadtmount -a -t nonfs 66df930be7Sderaadtrm -f /fastboot # XXX (root now writeable) 67df930be7Sderaadt 68df930be7Sderaadt# set flags on ttys. (do early, in case they use tty for SLIP in netstart) 69df930be7Sderaadtecho 'setting tty flags' 70df930be7Sderaadtttyflags -a 71df930be7Sderaadt 72df930be7Sderaadt# set hostname, turn on network 73df930be7Sderaadtecho 'starting network' 74df930be7Sderaadt. /etc/netstart 75df930be7Sderaadt 76df930be7Sderaadtmount /usr >/dev/null 2>&1 77df930be7Sderaadtmount /var >/dev/null 2>&1 78df930be7Sderaadt 799a844b63Sdmif [ X"${ipfilter}" = X"YES" -a X"${ipmon_flags}" != X"NO" ]; then 809a844b63Sdm ipmon ${ipmon_flags} & 819a844b63Sdmfi 829a844b63Sdm 83df930be7Sderaadt# clean up left-over files 84df930be7Sderaadtrm -f /etc/nologin 85df930be7Sderaadtrm -f /var/spool/lock/LCK.* 86df930be7Sderaadtrm -f /var/spool/uucp/STST/* 87df930be7Sderaadt(cd /var/run && { rm -rf -- *; install -c -m 664 -g utmp /dev/null utmp; }) 88df930be7Sderaadt 89df930be7Sderaadtecho -n 'starting rpc daemons:' 90*8e74b1f0Smillert 91*8e74b1f0Smillert# $portmap is imported from /etc/netstart; 92*8e74b1f0Smillert# if $portmap == YES, the portmapper is started. 93*8e74b1f0Smillertif [ X"${portmap}" = X"YES" ]; then 94df930be7Sderaadt echo -n ' portmap'; portmap 95423a3640Sderaadtfi 96df930be7Sderaadt 979704da5bSderaadtif [ -d /var/yp/binding ]; then 982d5ee5bcSderaadt if [ -d /var/yp/`domainname` ]; then 99b25099beSderaadt # yp server capabilities needed... 1002d5ee5bcSderaadt echo -n ' ypserv'; ypserv -d 101d52cd61fSderaadt #echo -n ' ypxfrd'; ypxfrd 1027f2d1b00Sderaadt fi 103b25099beSderaadt 1047f2d1b00Sderaadt echo -n ' ypbind'; ypbind 1057f2d1b00Sderaadt 1067f2d1b00Sderaadt if [ -d /var/yp/`domainname` ]; then 107b25099beSderaadt # if we are the master server, run rpc.yppasswdd 108b25099beSderaadt _host1=`ypwhich -m passwd 2> /dev/null` 109b25099beSderaadt _host2=`hostname` 110fd917f6eSderaadt if [ `grep '^lookup' /etc/resolv.conf | grep yp | wc -c` -ne 0 ]; then 111b25099beSderaadt _host1=`ypmatch $_host1 hosts | cut -d' ' -f2` 112b25099beSderaadt _host2=`ypmatch $_host2 hosts | cut -d' ' -f2 | head -1` 113b25099beSderaadt else 114b25099beSderaadt _host1=`nslookup $_host1 | grep '^Name: ' | \ 115b25099beSderaadt sed -e 's/^Name: //'` 116b25099beSderaadt _host2=`nslookup $_host2 | grep '^Name: ' | \ 117b25099beSderaadt sed -e 's/^Name: //'` 118b25099beSderaadt fi 119234efc0eSderaadt if [ "$_host2" = "$_host1" ]; then 1202d5ee5bcSderaadt echo -n ' rpc.yppasswdd'; rpc.yppasswdd 1212d5ee5bcSderaadt fi 1222d5ee5bcSderaadt fi 123df930be7Sderaadtfi 124df930be7Sderaadt 125df930be7Sderaadt# $nfs_server is imported from /etc/netstart; 126df930be7Sderaadt# if $nfs_server == YES, the machine is setup for being an nfs server 127df930be7Sderaadtif [ X${nfs_server} = X"YES" -a -r /etc/exports ]; then 128df930be7Sderaadt rm -f /var/db/mountdtab 129df930be7Sderaadt echo -n > /var/db/mountdtab 130df930be7Sderaadt echo -n ' mountd'; mountd 131df930be7Sderaadt echo -n ' nfsd'; nfsd -tun 4 132df930be7Sderaadtfi 133df930be7Sderaadt 134df930be7Sderaadt# $nfs_client is imported from /etc/netstart; 135df930be7Sderaadt# if $nfs_client == YES, the machine is setup for being an nfs client 136df930be7Sderaadtif [ X${nfs_client} = X"YES" ]; then 137df930be7Sderaadt echo -n ' nfsiod'; nfsiod -n 4 138df930be7Sderaadtfi 139df930be7Sderaadt 140df930be7Sderaadtif [ X${amd} = X"YES" -a -d ${amd_dir} -a -r ${amd_master} ]; then 141df930be7Sderaadt echo -n ' amd' 142df930be7Sderaadt amd -l syslog -x error,noinfo,nostats -p \ 143df930be7Sderaadt -a ${amd_dir} `cat ${amd_master}` > /var/run/amd.pid 144df930be7Sderaadtfi 145df930be7Sderaadt 146df930be7Sderaadtecho '.' 147df930be7Sderaadtmount -a -t nfs 148df930be7Sderaadt 149df930be7Sderaadtecho -n 'starting system logger' 150df930be7Sderaadtrm -f /dev/log 15192de4609Sderaadtsyslogd 152df930be7Sderaadt 153df930be7Sderaadt# $timed_flags is imported from /etc/netstart; 154df930be7Sderaadt# if $timed_flags == NO, timed isn't run. 155df930be7Sderaadtif [ "X${timed_flags}" != X"NO" ]; then 156df930be7Sderaadt echo -n ', time daemon'; timed $timed_flags 157df930be7Sderaadtfi 158df930be7Sderaadtecho '.' 159df930be7Sderaadt 160df930be7Sderaadt# /var/crash should be a directory or a symbolic link 161df930be7Sderaadt# to the crash directory if core dumps are to be saved. 162df930be7Sderaadtif [ -d /var/crash ]; then 163df930be7Sderaadt echo checking for core dump... 164df930be7Sderaadt savecore /var/crash 165df930be7Sderaadtfi 166df930be7Sderaadt 167df930be7Sderaadt echo -n 'checking quotas:' 168df930be7Sderaadtquotacheck -a 169df930be7Sderaadt echo ' done.' 170df930be7Sderaadtquotaon -a 171df930be7Sderaadt 172df930be7Sderaadt# build ps databases 173df930be7Sderaadtecho 'building databases...' 174e8bd198cSderaadtkvm_mkdb /bsd 175df930be7Sderaadtdev_mkdb 176df930be7Sderaadt 177df930be7Sderaadtchmod 666 /dev/tty[pqrs]* 178df930be7Sderaadt 179df930be7Sderaadt# check the password temp/lock file 1808b7444a6Sderaadtif [ -f /etc/ptmp ]; then 181df930be7Sderaadt logger -s -p auth.err \ 182df930be7Sderaadt 'password file may be incorrect -- /etc/ptmp exists' 183df930be7Sderaadtfi 184df930be7Sderaadt 185df930be7Sderaadtvirecovery=/var/tmp/vi.recover/recover.* 186df930be7Sderaadtif [ "$virecovery" != "/var/tmp/vi.recover/recover.*" ]; then 187df930be7Sderaadt echo preserving editor files 188df930be7Sderaadt for i in $virecovery; do 189df930be7Sderaadt sendmail -t < $i 190df930be7Sderaadt done 191df930be7Sderaadtfi 192df930be7Sderaadt 193df930be7Sderaadtecho clearing /tmp 194df930be7Sderaadt 195df930be7Sderaadt# prune quickly with one rm, then use find to clean up /tmp/[lq]* 196df930be7Sderaadt# (not needed with mfs /tmp, but doesn't hurt there...) 197df930be7Sderaadt(cd /tmp && rm -rf [a-km-pr-zA-Z]* && 198df930be7Sderaadt find . ! -name . ! -name lost+found ! -name quota.user \ 199df930be7Sderaadt ! -name quota.group -exec rm -rf -- {} \; -type d -prune) 200df930be7Sderaadt 201df930be7Sderaadtif [ -f /var/account/acct ]; then 202df930be7Sderaadt echo 'turning on accounting'; accton /var/account/acct 203df930be7Sderaadtfi 204df930be7Sderaadt 205df930be7Sderaadtecho -n standard daemons: 206df930be7Sderaadtecho -n ' cron'; cron 207df930be7Sderaadtecho '.' 208df930be7Sderaadt 209df930be7Sderaadtecho -n starting network daemons: 210df930be7Sderaadt 211df930be7Sderaadt# $gated and $routed_flags are imported from /etc/netstart. 212df930be7Sderaadt# If $gated == YES, gated is used; otherwise routed. 213df930be7Sderaadt# If $routed_flags == NO, routed isn't run. 214df930be7Sderaadtif [ X${gated} = X"YES" -a -r /etc/gated.conf ]; then 215df930be7Sderaadt echo -n ' gated'; gated $gated_flags 216df930be7Sderaadtelif [ "X${routed_flags}" != X"NO" ]; then 217df930be7Sderaadt echo -n ' routed'; routed $routed_flags 218df930be7Sderaadtfi 219df930be7Sderaadt 22069b30726Sderaadt# $mrouted_flags is imported from /etc/netstart; 22169b30726Sderaadt# If $mrouted_flags == NO, then mrouted isn't run. 22269b30726Sderaadtif [ "X${mrouted_flags}" != X"NO" ]; then 22369b30726Sderaadt echo -n ' mrouted'; mrouted $mrouted_flags 22469b30726Sderaadtfi 22569b30726Sderaadt 22669b30726Sderaadt# $named_flags is imported from /etc/netstart; 227df930be7Sderaadt# if $named_flags != NO, named is run. 228df930be7Sderaadtif [ "X${named_flags}" != X"NO" ]; then 229df930be7Sderaadt echo -n ' named'; named $named_flags 230df930be7Sderaadtfi 231df930be7Sderaadt 232df930be7Sderaadt# $rwhod is imported from /etc/netstart; 233df930be7Sderaadt# if $rwhod == YES, rwhod is run. 234df930be7Sderaadtif [ X${rwhod} = X"YES" ]; then 235df930be7Sderaadt echo -n ' rwhod'; rwhod 236df930be7Sderaadtfi 237df930be7Sderaadt 238423a3640Sderaadt 239423a3640Sderaadtif [ X${lpd} = X"YES" ]; then 240df930be7Sderaadt echo -n ' printer'; lpd 241423a3640Sderaadtfi 242df930be7Sderaadt 243df930be7Sderaadt# $sendmail_flags is imported from /etc/netstart; 244df930be7Sderaadt# If $sendmail_flags == NO or /etc/sendmail.cf doesn't exist, then 2454844ae79Sderaadt# sendmail isn't run. We call sendmail with a full path so that 2464844ae79Sderaadt# SIGHUP works. 247df930be7Sderaadtif [ "X${sendmail_flags}" != X"NO" -a -r /etc/sendmail.cf ]; then 2484844ae79Sderaadt echo -n ' sendmail'; /usr/sbin/sendmail ${sendmail_flags} 249df930be7Sderaadtfi 250df930be7Sderaadt 251423a3640Sderaadtif [ X${inetd} = X"YES" ]; then 252df930be7Sderaadt echo -n ' inetd'; inetd 253423a3640Sderaadtfi 254df930be7Sderaadt 255df930be7Sderaadt# $rarpd_flags is imported from /etc/netstart; 256df930be7Sderaadt# If $rarpd_flags == NO or /etc/ethers doesn't exist, then 257df930be7Sderaadt# rarpd isn't run. 258df930be7Sderaadtif [ "X${rarpd_flags}" != X"NO" -a -r /etc/ethers ]; then 259df930be7Sderaadt echo -n ' rarpd'; rarpd ${rarpd_flags} 260df930be7Sderaadtfi 261df930be7Sderaadt 262df930be7Sderaadt# $bootparamd_flags is imported from /etc/netstart; 263df930be7Sderaadt# If $bootparamd_flags == NO or /etc/bootparams doesn't exist, then 264df930be7Sderaadt# bootparamd isn't run. 265df930be7Sderaadtif [ "X${bootparamd_flags}" != X"NO" -a -r /etc/bootparams ]; then 266df930be7Sderaadt echo -n ' rpc.bootparamd'; rpc.bootparamd ${bootparamd_flags} 267df930be7Sderaadtfi 268df930be7Sderaadt 269df930be7Sderaadt# $rbootd_flags is imported from /etc/netstart; 270df930be7Sderaadt# If $rbootd_flags == NO or /etc/rbootd.conf doesn't exist, then 271df930be7Sderaadt# rbootd isn't run. 272df930be7Sderaadtif [ "X${rbootd_flags}" != X"NO" -a -r /etc/rbootd.conf ]; then 273df930be7Sderaadt echo -n ' rbootd'; rbootd ${rbootd_flags} 274df930be7Sderaadtfi 275df930be7Sderaadt 276df930be7Sderaadtecho '.' 277df930be7Sderaadt 278e1ebb78aSderaadtif [ -f /sbin/kbd -a -f /etc/kbdtype ]; then 279e1ebb78aSderaadt kbd `cat /etc/kbdtype` 280e1ebb78aSderaadtfi 281e1ebb78aSderaadt 2828b7444a6Sderaadt# patch /etc/motd 2838b7444a6Sderaadtif [ ! -f /etc/motd ]; then 2848b7444a6Sderaadt install -c -o root -g wheel -m 664 /dev/null /etc/motd 2858b7444a6Sderaadtfi 2868b7444a6SderaadtT=/tmp/_motd 2878b7444a6Sderaadtrm -f $T 2888b7444a6Sderaadtsysctl -n kern.version | sed 1q > $T 2898b7444a6Sderaadtecho "" >> $T 2908b7444a6Sderaadtsed '1,/^$/d' < /etc/motd >> $T 2918b7444a6Sderaadtcmp -s $T /etc/motd || cp $T /etc/motd 2928b7444a6Sderaadtrm -f $T 2938b7444a6Sderaadt 2948b7444a6Sderaadtif [ -f /sbin/ldconfig ]; then 2958b7444a6Sderaadt echo 'creating runtime link editor directory cache.' 296ba8d1601Sdownsj ldconfig /usr/local/lib /usr/X11R6/lib 2978b7444a6Sderaadtfi 2988b7444a6Sderaadt 2998b7444a6Sderaadt# Kerberos runs ONLY on the Kerberos server machine 3008b7444a6Sderaadtif [ X${kerberos_server} = X"YES" ]; then 3018b7444a6Sderaadt echo 'kerberos server'; kerberos >> /var/log/kerberos.log & 3028b7444a6Sderaadtfi 3038b7444a6Sderaadt 3048b7444a6Sderaadt. /etc/rc.local 3058b7444a6Sderaadt 306df930be7Sderaadtdate 307df930be7Sderaadtexit 0 308