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