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