install.md revision 1.21 1 1.21 is # $NetBSD: install.md,v 1.21 2003/01/13 20:34:05 is Exp $
2 1.1 is #
3 1.1 is #
4 1.1 is # Copyright (c) 1996 The NetBSD Foundation, Inc.
5 1.1 is # All rights reserved.
6 1.1 is #
7 1.1 is # This code is derived from software contributed to The NetBSD Foundation
8 1.1 is # by Jason R. Thorpe.
9 1.1 is #
10 1.1 is # Redistribution and use in source and binary forms, with or without
11 1.1 is # modification, are permitted provided that the following conditions
12 1.1 is # are met:
13 1.1 is # 1. Redistributions of source code must retain the above copyright
14 1.1 is # notice, this list of conditions and the following disclaimer.
15 1.1 is # 2. Redistributions in binary form must reproduce the above copyright
16 1.1 is # notice, this list of conditions and the following disclaimer in the
17 1.1 is # documentation and/or other materials provided with the distribution.
18 1.1 is # 3. All advertising materials mentioning features or use of this software
19 1.1 is # must display the following acknowledgement:
20 1.1 is # This product includes software developed by the NetBSD
21 1.1 is # Foundation, Inc. and its contributors.
22 1.1 is # 4. Neither the name of The NetBSD Foundation nor the names of its
23 1.1 is # contributors may be used to endorse or promote products derived
24 1.1 is # from this software without specific prior written permission.
25 1.1 is #
26 1.1 is # THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
27 1.1 is # ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
28 1.1 is # TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
29 1.3 jtc # PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
30 1.3 jtc # BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
31 1.1 is # CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
32 1.1 is # SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
33 1.1 is # INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
34 1.1 is # CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
35 1.1 is # ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
36 1.1 is # POSSIBILITY OF SUCH DAMAGE.
37 1.1 is #
38 1.1 is
39 1.1 is #
40 1.1 is # machine dependent section of installation/upgrade script.
41 1.1 is #
42 1.1 is
43 1.1 is # Machine-dependent install sets
44 1.17 mhitch MDSETS="kern-GENERIC xbase xcomp xcontrib xfont xmisc xserver"
45 1.1 is
46 1.1 is md_set_term() {
47 1.1 is if [ ! -z "$TERM" ]; then
48 1.1 is return
49 1.1 is fi
50 1.1 is echo -n "Specify terminal type [vt220]: "
51 1.1 is getresp "vt220"
52 1.1 is TERM="$resp"
53 1.1 is export TERM
54 1.1 is }
55 1.1 is
56 1.1 is __mount_kernfs() {
57 1.1 is #
58 1.1 is # Force kern_fs to be mounted
59 1.1 is #
60 1.1 is if [ ! -d /kern -o ! -e /kern/msgbuf ]; then
61 1.1 is mkdir /kern > /dev/null 2>&1
62 1.1 is /sbin/mount_kernfs /kern /kern >/dev/null 2>&1
63 1.1 is fi
64 1.1 is }
65 1.1 is
66 1.1 is md_makerootwritable() {
67 1.1 is # Mount root rw for convenience of the tester ;-)
68 1.21 is if ! cp /dev/null /tmp/.root_writable >/dev/null 2>&1; then
69 1.1 is __mount_kernfs
70 1.1 is # XXX: Use /kern/rootdev instead?
71 1.15 is mount -t ffs -u /kern/rootdev / > /dev/null 2>&1
72 1.1 is fi
73 1.1 is }
74 1.1 is
75 1.1 is md_get_diskdevs() {
76 1.1 is # return available disk devices
77 1.1 is __mount_kernfs
78 1.1 is sed -n -e '/^[sw]d[0-9] /s/ .*//p' \
79 1.1 is < /kern/msgbuf | sort -u
80 1.1 is }
81 1.1 is
82 1.1 is md_get_cddevs() {
83 1.1 is # return available CDROM devices
84 1.1 is __mount_kernfs
85 1.1 is sed -n -e '/^cd[0-9] /s/ .*//p' \
86 1.1 is < /kern/msgbuf | sort -u
87 1.1 is }
88 1.1 is
89 1.1 is md_get_partition_range() {
90 1.1 is # return an expression describing the valid partition id's
91 1.1 is echo '[a-p]'
92 1.1 is }
93 1.1 is
94 1.1 is md_installboot() {
95 1.1 is if [ -x /mnt/usr/mdec/installboot ]; then
96 1.1 is echo -n "Should a boot block be installed? [y] "
97 1.1 is getresp "y"
98 1.1 is case "$resp" in
99 1.1 is y*|Y*)
100 1.1 is echo "Installing boot block..."
101 1.16 mhitch chroot /mnt /usr/mdec/installboot /usr/mdec/bootxx_ffs /dev/r${1}a
102 1.18 mhitch cp -p /mnt/usr/mdec/boot.amiga /mnt/
103 1.1 is ;;
104 1.1 is *)
105 1.13 is echo "No bootblock installed."
106 1.1 is ;;
107 1.1 is esac
108 1.1 is elif [ "$MODE" = "install" ]; then
109 1.1 is cat << \__md_installboot_1
110 1.1 is There is no installboot program found on the installed filesystems. No boot
111 1.1 is programs are installed.
112 1.1 is __md_installboot_1
113 1.1 is else
114 1.1 is cat << \__md_installboot_2
115 1.1 is There is no installboot program found on the upgraded filesystems. No boot
116 1.1 is programs are installed.
117 1.1 is __md_installboot_2
118 1.1 is fi
119 1.1 is }
120 1.1 is
121 1.1 is md_native_fstype() {
122 1.1 is echo "ados"
123 1.1 is }
124 1.1 is
125 1.1 is md_native_fsopts() {
126 1.6 veego echo "ro"
127 1.1 is }
128 1.1 is
129 1.1 is md_prep_disklabel() {
130 1.9 is _DKDEVS=`md_get_diskdevs`
131 1.9 is echo "If you like, you can now examine the labels of your disks."
132 1.9 is echo ""
133 1.9 is echo -n "Available are "${_DKDEVS}". Look at which? [skip this step] "
134 1.11 is getresp "done"
135 1.11 is while [ "X$resp" != "Xdone" ]; do
136 1.9 is echo ""
137 1.9 is disklabel ${resp}
138 1.9 is echo ""
139 1.9 is echo -n "Available are "${_DKDEVS}". Look at which? [done] "
140 1.11 is getresp "done"
141 1.9 is done
142 1.10 is cat << \__prep_disklabel_1
143 1.10 is
144 1.10 is As a reminder: the 'c' partition is assigned to the whole disk and can't
145 1.10 is normally be used for a any file system!
146 1.10 is
147 1.10 is __prep_disklabel_1
148 1.1 is }
149 1.1 is
150 1.1 is md_labeldisk() {
151 1.1 is }
152 1.1 is
153 1.1 is md_welcome_banner() {
154 1.1 is if [ "$MODE" = "install" ]; then
155 1.1 is echo ""
156 1.1 is echo "Welcome to the NetBSD/amiga ${VERSION} installation program."
157 1.1 is cat << \__welcome_banner_1
158 1.1 is
159 1.1 is This program is designed to help you put NetBSD on your disk,
160 1.1 is in a simple and rational way. You'll be asked several questions,
161 1.1 is and it would probably be useful to have your disk's hardware
162 1.1 is manual, the installation notes, and a calculator handy.
163 1.1 is __welcome_banner_1
164 1.1 is
165 1.1 is else
166 1.1 is echo ""
167 1.1 is echo "Welcome to the NetBSD/amiga ${VERSION} upgrade program."
168 1.1 is cat << \__welcome_banner_2
169 1.1 is
170 1.1 is This program is designed to help you upgrade your NetBSD system in a
171 1.1 is simple and rational way.
172 1.1 is
173 1.1 is As a reminder, installing the `etc' binary set is NOT recommended.
174 1.1 is Once the rest of your system has been upgraded, you should manually
175 1.1 is merge any changes to files in the `etc' set into those files which
176 1.1 is already exist on your system.
177 1.1 is __welcome_banner_2
178 1.1 is fi
179 1.1 is
180 1.1 is cat << \__welcome_banner_3
181 1.1 is
182 1.1 is As with anything which modifies your disk's contents, this
183 1.1 is program can cause SIGNIFICANT data loss, and you are advised
184 1.1 is to make sure your data is backed up before beginning the
185 1.1 is installation process.
186 1.1 is
187 1.1 is Default answers are displayed in brackets after the questions.
188 1.1 is You can hit Control-C at any time to quit, but if you do so at a
189 1.1 is prompt, you may have to hit return. Also, quitting in the middle of
190 1.1 is installation may leave your system in an inconsistent state.
191 1.1 is
192 1.1 is __welcome_banner_3
193 1.1 is }
194 1.1 is
195 1.1 is md_not_going_to_install() {
196 1.1 is cat << \__not_going_to_install_1
197 1.1 is
198 1.1 is OK, then. Enter `halt' at the prompt to halt the machine. Once the
199 1.1 is machine has halted, power-cycle the system to load new boot code.
200 1.1 is
201 1.1 is Note: If you wish to have another try. Just type '^D' at the prompt. After
202 1.1 is a moment, the installer will restart itself.
203 1.1 is
204 1.1 is __not_going_to_install_1
205 1.1 is }
206 1.1 is
207 1.1 is md_congrats() {
208 1.1 is local what;
209 1.1 is if [ "$MODE" = "install" ]; then
210 1.1 is what="installed";
211 1.1 is else
212 1.1 is what="upgraded";
213 1.1 is fi
214 1.1 is cat << __congratulations_1
215 1.1 is
216 1.1 is CONGRATULATIONS! You have successfully $what NetBSD!
217 1.1 is To boot the installed system, enter halt at the command prompt. Once the
218 1.1 is system has halted, reset the machine and boot from the disk.
219 1.1 is
220 1.1 is Note: If you wish to have another try. Just type '^D' at the prompt. After
221 1.1 is a moment, the installer will restart itself.
222 1.1 is
223 1.1 is __congratulations_1
224 1.1 is }
225 1.1 is
226 1.1 is md_copy_kernel() {
227 1.1 is # This is largely a copy of install_disk and install_from_mounted_fs()
228 1.1 is # with some special frobbing.
229 1.1 is
230 1.1 is local _directory
231 1.1 is local _sets
232 1.1 is local _filename
233 1.1 is local _f
234 1.7 is
235 1.7 is if [ "$MODE" = "install" ]; then
236 1.7 is echo -n "Adding keymap initialization to rc.local..."
237 1.7 is echo /usr/sbin/loadkmap ${__keymap__} >> /mnt/etc/rc.local
238 1.7 is echo "done."
239 1.7 is fi
240 1.1 is
241 1.1 is if [ -e /netbsd ]; then
242 1.14 is if [ -e /mnt/netbsd ]; then
243 1.14 is echo "On the installation filesystem there is this kernel: "
244 1.14 is ls -l /netbsd
245 1.14 is echo "The already installed kernel is: "
246 1.14 is ls -l /mnt/netbsd
247 1.14 is echo "Do you want to replace the already installed kernel by the kernel"
248 1.14 is echo -n "on the installation filesystem? (y/n) [n] "
249 1.14 is resp="n"
250 1.14 is getresp ""
251 1.14 is if [ "${resp}" != "y" -a "${resp}" != "Y" ]; then
252 1.14 is return
253 1.14 is fi
254 1.14 is fi
255 1.14 is
256 1.1 is echo -n "Copying kernel..."
257 1.1 is cp -p /netbsd /mnt/netbsd
258 1.1 is echo "done."
259 1.1 is return
260 1.1 is fi
261 1.1 is
262 1.1 is cat << \__md_copy_kernel_1
263 1.1 is Your installation set did not include a netbsd kernel on the installation
264 1.1 is filesystem. You are now given the opportunity install it from either the
265 1.1 is kernel-floppy from the distribution or another location on one of your disks.
266 1.1 is
267 1.1 is The following disk devices are installed on your system; please select
268 1.1 is the disk device containing the partition with the netbsd kernel:
269 1.1 is __md_copy_kernel_1
270 1.1 is
271 1.1 is _DKDEVS=`md_get_diskdevs`
272 1.1 is echo "$_DKDEVS"
273 1.1 is echo "fd0"
274 1.1 is echo ""
275 1.1 is _DKDEVS="$_DKDEVS fd0" # Might be on the kernel floppy!
276 1.1 is echo -n "Which is the disk with the kernel? [abort] "
277 1.1 is
278 1.1 is if mount_a_disk ; then
279 1.1 is return # couldn't mount the disk
280 1.1 is fi
281 1.1 is
282 1.1 is # Get the directory where the file lives
283 1.1 is resp="" # force one iteration
284 1.1 is while [ "X${resp}" = X"" ]; do
285 1.1 is echo "Enter the directory relative to the mount point that"
286 1.1 is echo -n "contains the file. [${_directory}] "
287 1.1 is getresp "${_directory}"
288 1.1 is done
289 1.1 is _directory=$resp
290 1.1 is
291 1.1 is _sets=`(cd /mnt2/$_directory; ls netbsd* 2> /dev/null)`
292 1.1 is if [ -z "$_sets" ]; then
293 1.1 is echo "There are no NetBSD kernels available in \"$1\""
294 1.1 is umount -f /mnt2 > /dev/null 2>&1
295 1.1 is return
296 1.1 is fi
297 1.1 is while : ; do
298 1.1 is echo "The following kernels are available:"
299 1.1 is echo ""
300 1.1 is
301 1.1 is for _f in $_sets ; do
302 1.1 is echo " $_f"
303 1.1 is done
304 1.1 is echo ""
305 1.1 is set -- $_sets
306 1.1 is echo -n "File name [$1]? "
307 1.1 is getresp "$1"
308 1.1 is _f=$resp
309 1.1 is _filename="/mnt2/$_directory/$_f"
310 1.1 is
311 1.1 is # Ensure file exists
312 1.1 is if [ ! -f $_filename ]; then
313 1.1 is echo "File $_filename does not exist. Check to make"
314 1.1 is echo "sure you entered the information properly."
315 1.1 is echo -n "Do you want to retry [y]? "
316 1.1 is getresp "y"
317 1.1 is if [ "$resp" = "n" ]; then
318 1.1 is break
319 1.1 is fi
320 1.1 is continue
321 1.1 is fi
322 1.1 is
323 1.1 is # Copy the kernel
324 1.1 is cp $_filename /mnt
325 1.1 is break
326 1.1 is done
327 1.1 is umount -f /mnt2 > /dev/null 2>&1
328 1.1 is }
329 1.19 mhitch
330 1.19 mhitch md_lib_is_aout() {
331 1.19 mhitch local r
332 1.19 mhitch test -h $1 && return 1
333 1.19 mhitch test -f $1 || return 1
334 1.19 mhitch
335 1.19 mhitch r=`file $1 | sed -n -e '/ELF/p'`
336 1.19 mhitch test -z "$r" || return 1
337 1.19 mhitch return 0
338 1.19 mhitch }
339 1.19 mhitch
340 1.19 mhitch
341 1.19 mhitch md_mv_usr_lib() {
342 1.19 mhitch local root
343 1.19 mhitch root=$1
344 1.19 mhitch for f in $root/usr/lib/lib*.so.[0-9]*.[0-9]* ; do
345 1.19 mhitch md_lib_is_aout $f || continue
346 1.19 mhitch mv -f $f $root/emul/aout/usr/lib || return 1
347 1.19 mhitch done
348 1.19 mhitch return 0
349 1.19 mhitch }
350 1.19 mhitch
351 1.19 mhitch md_x_shlib_set_14=" \
352 1.19 mhitch libICE.so.6.3 \
353 1.19 mhitch libPEX5.so.6.0 \
354 1.19 mhitch libSM.so.6.0 \
355 1.19 mhitch libX11.so.6.1 \
356 1.19 mhitch libXIE.so.6.0 \
357 1.19 mhitch libXaw.so.6.1 \
358 1.19 mhitch libXext.so.6.3 \
359 1.19 mhitch libXi.so.6.0 \
360 1.19 mhitch libXmu.so.6.0 \
361 1.19 mhitch libXp.so.6.2 \
362 1.19 mhitch libXt.so.6.0 \
363 1.19 mhitch libXtst.so.6.1 \
364 1.19 mhitch liboldX.so.6.0"
365 1.19 mhitch
366 1.19 mhitch md_mv_x_lib() {
367 1.19 mhitch local root xlibdir
368 1.19 mhitch root=$1
369 1.19 mhitch xlibdir=$2
370 1.19 mhitch for f in $md_x_shlib_set_14; do
371 1.19 mhitch md_lib_is_aout $root/$xlibdir/$f || continue
372 1.19 mhitch mv -f $root/$xlibdir/$f $root/emul/aout/$xlibdir || return 1
373 1.19 mhitch done
374 1.19 mhitch return 0
375 1.19 mhitch }
376 1.19 mhitch
377 1.19 mhitch md_mv_aout_libs()
378 1.19 mhitch {
379 1.19 mhitch local root xlibdir
380 1.19 mhitch
381 1.19 mhitch root=/mnt # XXX - should be global
382 1.19 mhitch
383 1.19 mhitch if [ -d $root/emul/aout/. ]; then
384 1.19 mhitch echo "Using existing /emul/aout directory"
385 1.19 mhitch else
386 1.19 mhitch echo "Creating /emul/aout hierachy"
387 1.19 mhitch mkdir -p $root/usr/aout || return 1
388 1.19 mhitch
389 1.19 mhitch if [ ! -d $root/emul ]; then
390 1.19 mhitch mkdir $root/emul || return 1
391 1.19 mhitch fi
392 1.19 mhitch
393 1.19 mhitch if [ -h $root/emul/aout ]; then
394 1.19 mhitch echo "Preserving existing symbolic link from /emul/aout"
395 1.19 mhitch mv -f $root/emul/aout $root/emul/aout.old || return 1
396 1.19 mhitch fi
397 1.19 mhitch
398 1.19 mhitch ln -s ../usr/aout $root/emul/aout || return 1
399 1.19 mhitch fi
400 1.19 mhitch
401 1.19 mhitch # Create /emul/aout/etc and /emul/aout/usr/lib
402 1.19 mhitch if [ ! -d $root/emul/aout/etc ]; then
403 1.19 mhitch mkdir $root/emul/aout/etc || return 1
404 1.19 mhitch fi
405 1.19 mhitch if [ ! -d $root/emul/aout/usr/lib ]; then
406 1.19 mhitch mkdir -p $root/emul/aout/usr/lib || return 1
407 1.19 mhitch fi
408 1.19 mhitch
409 1.19 mhitch # Move ld.so.conf
410 1.19 mhitch if [ -f $root/etc/ld.so.conf ]; then
411 1.19 mhitch mv -f $root/etc/ld.so.conf $root/emul/aout/etc || return 1
412 1.19 mhitch fi
413 1.19 mhitch
414 1.19 mhitch # Finally, move the aout shared libraries from /usr/lib
415 1.19 mhitch md_mv_usr_lib $root || return 1
416 1.19 mhitch
417 1.19 mhitch # If X11 is installed, move the those libraries as well
418 1.19 mhitch xlibdir="/usr/X11R6/lib"
419 1.19 mhitch if [ -d $root/$xlibdir/. ]; then
420 1.19 mhitch mkdir -p $root/emul/aout/$xlibdir || return 1
421 1.19 mhitch md_mv_x_lib $root $xlibdir || return 1
422 1.19 mhitch fi
423 1.19 mhitch
424 1.19 mhitch echo "a.out emulation environment setup completed."
425 1.19 mhitch }
426 1.19 mhitch
427 1.19 mhitch md_prepare_upgrade()
428 1.19 mhitch {
429 1.19 mhitch cat << 'EOF'
430 1.19 mhitch This release uses the ELF binary object format. Existing (a.out) binaries
431 1.19 mhitch can still be used on your system after it has been upgraded, provided
432 1.19 mhitch that the shared libraries needed by those binaries are made available
433 1.19 mhitch in the filesystem hierarchy rooted at /emul/aout.
434 1.19 mhitch
435 1.19 mhitch This upgrade procedure will now establish this hierarchy by moving all
436 1.19 mhitch shared libraries in a.out format found in /usr/lib to /emul/aout/usr/lib.
437 1.19 mhitch It will also move the X11 shared libraries in a.out format from previous
438 1.19 mhitch NetBSD/sparc X11 installation sets, if they are installed.
439 1.19 mhitch
440 1.19 mhitch EOF
441 1.19 mhitch md_mv_aout_libs || {
442 1.19 mhitch echo "Failed to setup a.out emulation environment"
443 1.19 mhitch return 1
444 1.19 mhitch }
445 1.19 mhitch return 0
446 1.19 mhitch }
447 1.19 mhitch
448 1.19 mhitch # Flag to notify upgrade.sh of the existence of md_prepare_upgrade()
449 1.19 mhitch md_upgrade_prep_needed=1
450