xref: /openbsd/etc/rc (revision 8e74b1f0)
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