install.md revision 1.25 1 1.25 is # $NetBSD: install.md,v 1.25 2006/01/18 13:39:05 is Exp $
2 1.1 is #
3 1.1 is #
4 1.25 is # Copyright (c) 1996,2006 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.24 mhitch MDSETS="kern-GENERIC xbase xcomp xetc xfont 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.22 mhitch if [ -x /mnt/usr/sbin/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.22 mhitch chroot /mnt /usr/sbin/installboot /dev/r${1}a /usr/mdec/bootxx_ffs
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.25 is }
131 1.25 is
132 1.25 is md_view_labels_possible=1
133 1.25 is md_view_labels() {
134 1.9 is _DKDEVS=`md_get_diskdevs`
135 1.9 is echo "If you like, you can now examine the labels of your disks."
136 1.9 is echo ""
137 1.9 is echo -n "Available are "${_DKDEVS}". Look at which? [skip this step] "
138 1.11 is getresp "done"
139 1.11 is while [ "X$resp" != "Xdone" ]; do
140 1.9 is echo ""
141 1.9 is disklabel ${resp}
142 1.9 is echo ""
143 1.9 is echo -n "Available are "${_DKDEVS}". Look at which? [done] "
144 1.11 is getresp "done"
145 1.9 is done
146 1.10 is cat << \__prep_disklabel_1
147 1.10 is
148 1.10 is As a reminder: the 'c' partition is assigned to the whole disk and can't
149 1.10 is normally be used for a any file system!
150 1.10 is
151 1.10 is __prep_disklabel_1
152 1.1 is }
153 1.1 is
154 1.1 is md_labeldisk() {
155 1.1 is }
156 1.1 is
157 1.1 is md_welcome_banner() {
158 1.1 is if [ "$MODE" = "install" ]; then
159 1.1 is echo ""
160 1.1 is echo "Welcome to the NetBSD/amiga ${VERSION} installation program."
161 1.1 is cat << \__welcome_banner_1
162 1.1 is
163 1.1 is This program is designed to help you put NetBSD on your disk,
164 1.1 is in a simple and rational way. You'll be asked several questions,
165 1.1 is and it would probably be useful to have your disk's hardware
166 1.1 is manual, the installation notes, and a calculator handy.
167 1.1 is __welcome_banner_1
168 1.1 is
169 1.1 is else
170 1.1 is echo ""
171 1.1 is echo "Welcome to the NetBSD/amiga ${VERSION} upgrade program."
172 1.1 is cat << \__welcome_banner_2
173 1.1 is
174 1.1 is This program is designed to help you upgrade your NetBSD system in a
175 1.1 is simple and rational way.
176 1.1 is
177 1.1 is As a reminder, installing the `etc' binary set is NOT recommended.
178 1.1 is Once the rest of your system has been upgraded, you should manually
179 1.1 is merge any changes to files in the `etc' set into those files which
180 1.1 is already exist on your system.
181 1.1 is __welcome_banner_2
182 1.1 is fi
183 1.1 is
184 1.1 is cat << \__welcome_banner_3
185 1.1 is
186 1.1 is As with anything which modifies your disk's contents, this
187 1.1 is program can cause SIGNIFICANT data loss, and you are advised
188 1.1 is to make sure your data is backed up before beginning the
189 1.1 is installation process.
190 1.1 is
191 1.1 is Default answers are displayed in brackets after the questions.
192 1.1 is You can hit Control-C at any time to quit, but if you do so at a
193 1.1 is prompt, you may have to hit return. Also, quitting in the middle of
194 1.1 is installation may leave your system in an inconsistent state.
195 1.1 is
196 1.1 is __welcome_banner_3
197 1.1 is }
198 1.1 is
199 1.1 is md_not_going_to_install() {
200 1.1 is cat << \__not_going_to_install_1
201 1.1 is
202 1.1 is OK, then. Enter `halt' at the prompt to halt the machine. Once the
203 1.1 is machine has halted, power-cycle the system to load new boot code.
204 1.1 is
205 1.1 is Note: If you wish to have another try. Just type '^D' at the prompt. After
206 1.1 is a moment, the installer will restart itself.
207 1.1 is
208 1.1 is __not_going_to_install_1
209 1.1 is }
210 1.1 is
211 1.1 is md_congrats() {
212 1.1 is local what;
213 1.1 is if [ "$MODE" = "install" ]; then
214 1.1 is what="installed";
215 1.1 is else
216 1.1 is what="upgraded";
217 1.1 is fi
218 1.1 is cat << __congratulations_1
219 1.1 is
220 1.1 is CONGRATULATIONS! You have successfully $what NetBSD!
221 1.1 is To boot the installed system, enter halt at the command prompt. Once the
222 1.1 is system has halted, reset the machine and boot from the disk.
223 1.1 is
224 1.1 is Note: If you wish to have another try. Just type '^D' at the prompt. After
225 1.1 is a moment, the installer will restart itself.
226 1.1 is
227 1.1 is __congratulations_1
228 1.1 is }
229 1.1 is
230 1.1 is md_copy_kernel() {
231 1.1 is # This is largely a copy of install_disk and install_from_mounted_fs()
232 1.1 is # with some special frobbing.
233 1.1 is
234 1.1 is local _directory
235 1.1 is local _sets
236 1.1 is local _filename
237 1.1 is local _f
238 1.7 is
239 1.7 is if [ "$MODE" = "install" ]; then
240 1.7 is echo -n "Adding keymap initialization to rc.local..."
241 1.7 is echo /usr/sbin/loadkmap ${__keymap__} >> /mnt/etc/rc.local
242 1.7 is echo "done."
243 1.7 is fi
244 1.1 is
245 1.1 is if [ -e /netbsd ]; then
246 1.14 is if [ -e /mnt/netbsd ]; then
247 1.14 is echo "On the installation filesystem there is this kernel: "
248 1.14 is ls -l /netbsd
249 1.14 is echo "The already installed kernel is: "
250 1.14 is ls -l /mnt/netbsd
251 1.14 is echo "Do you want to replace the already installed kernel by the kernel"
252 1.14 is echo -n "on the installation filesystem? (y/n) [n] "
253 1.14 is resp="n"
254 1.14 is getresp ""
255 1.14 is if [ "${resp}" != "y" -a "${resp}" != "Y" ]; then
256 1.14 is return
257 1.14 is fi
258 1.14 is fi
259 1.14 is
260 1.1 is echo -n "Copying kernel..."
261 1.1 is cp -p /netbsd /mnt/netbsd
262 1.1 is echo "done."
263 1.1 is return
264 1.1 is fi
265 1.1 is
266 1.1 is cat << \__md_copy_kernel_1
267 1.1 is Your installation set did not include a netbsd kernel on the installation
268 1.1 is filesystem. You are now given the opportunity install it from either the
269 1.1 is kernel-floppy from the distribution or another location on one of your disks.
270 1.1 is
271 1.1 is The following disk devices are installed on your system; please select
272 1.1 is the disk device containing the partition with the netbsd kernel:
273 1.1 is __md_copy_kernel_1
274 1.1 is
275 1.1 is _DKDEVS=`md_get_diskdevs`
276 1.1 is echo "$_DKDEVS"
277 1.1 is echo "fd0"
278 1.1 is echo ""
279 1.1 is _DKDEVS="$_DKDEVS fd0" # Might be on the kernel floppy!
280 1.1 is echo -n "Which is the disk with the kernel? [abort] "
281 1.1 is
282 1.1 is if mount_a_disk ; then
283 1.1 is return # couldn't mount the disk
284 1.1 is fi
285 1.1 is
286 1.1 is # Get the directory where the file lives
287 1.1 is resp="" # force one iteration
288 1.1 is while [ "X${resp}" = X"" ]; do
289 1.1 is echo "Enter the directory relative to the mount point that"
290 1.1 is echo -n "contains the file. [${_directory}] "
291 1.1 is getresp "${_directory}"
292 1.1 is done
293 1.1 is _directory=$resp
294 1.1 is
295 1.1 is _sets=`(cd /mnt2/$_directory; ls netbsd* 2> /dev/null)`
296 1.1 is if [ -z "$_sets" ]; then
297 1.1 is echo "There are no NetBSD kernels available in \"$1\""
298 1.1 is umount -f /mnt2 > /dev/null 2>&1
299 1.1 is return
300 1.1 is fi
301 1.1 is while : ; do
302 1.1 is echo "The following kernels are available:"
303 1.1 is echo ""
304 1.1 is
305 1.1 is for _f in $_sets ; do
306 1.1 is echo " $_f"
307 1.1 is done
308 1.1 is echo ""
309 1.1 is set -- $_sets
310 1.1 is echo -n "File name [$1]? "
311 1.1 is getresp "$1"
312 1.1 is _f=$resp
313 1.1 is _filename="/mnt2/$_directory/$_f"
314 1.1 is
315 1.1 is # Ensure file exists
316 1.1 is if [ ! -f $_filename ]; then
317 1.1 is echo "File $_filename does not exist. Check to make"
318 1.1 is echo "sure you entered the information properly."
319 1.1 is echo -n "Do you want to retry [y]? "
320 1.1 is getresp "y"
321 1.1 is if [ "$resp" = "n" ]; then
322 1.1 is break
323 1.1 is fi
324 1.1 is continue
325 1.1 is fi
326 1.1 is
327 1.1 is # Copy the kernel
328 1.1 is cp $_filename /mnt
329 1.1 is break
330 1.1 is done
331 1.1 is umount -f /mnt2 > /dev/null 2>&1
332 1.1 is }
333 1.19 mhitch
334 1.19 mhitch md_lib_is_aout() {
335 1.19 mhitch local r
336 1.19 mhitch test -h $1 && return 1
337 1.19 mhitch test -f $1 || return 1
338 1.19 mhitch
339 1.19 mhitch r=`file $1 | sed -n -e '/ELF/p'`
340 1.19 mhitch test -z "$r" || return 1
341 1.19 mhitch return 0
342 1.19 mhitch }
343 1.19 mhitch
344 1.19 mhitch
345 1.19 mhitch md_mv_usr_lib() {
346 1.19 mhitch local root
347 1.19 mhitch root=$1
348 1.19 mhitch for f in $root/usr/lib/lib*.so.[0-9]*.[0-9]* ; do
349 1.19 mhitch md_lib_is_aout $f || continue
350 1.19 mhitch mv -f $f $root/emul/aout/usr/lib || return 1
351 1.19 mhitch done
352 1.19 mhitch return 0
353 1.19 mhitch }
354 1.19 mhitch
355 1.19 mhitch md_x_shlib_set_14=" \
356 1.19 mhitch libICE.so.6.3 \
357 1.19 mhitch libPEX5.so.6.0 \
358 1.19 mhitch libSM.so.6.0 \
359 1.19 mhitch libX11.so.6.1 \
360 1.19 mhitch libXIE.so.6.0 \
361 1.19 mhitch libXaw.so.6.1 \
362 1.19 mhitch libXext.so.6.3 \
363 1.19 mhitch libXi.so.6.0 \
364 1.19 mhitch libXmu.so.6.0 \
365 1.19 mhitch libXp.so.6.2 \
366 1.19 mhitch libXt.so.6.0 \
367 1.19 mhitch libXtst.so.6.1 \
368 1.19 mhitch liboldX.so.6.0"
369 1.19 mhitch
370 1.19 mhitch md_mv_x_lib() {
371 1.19 mhitch local root xlibdir
372 1.19 mhitch root=$1
373 1.19 mhitch xlibdir=$2
374 1.19 mhitch for f in $md_x_shlib_set_14; do
375 1.19 mhitch md_lib_is_aout $root/$xlibdir/$f || continue
376 1.19 mhitch mv -f $root/$xlibdir/$f $root/emul/aout/$xlibdir || return 1
377 1.19 mhitch done
378 1.19 mhitch return 0
379 1.19 mhitch }
380 1.19 mhitch
381 1.19 mhitch md_mv_aout_libs()
382 1.19 mhitch {
383 1.19 mhitch local root xlibdir
384 1.19 mhitch
385 1.19 mhitch root=/mnt # XXX - should be global
386 1.19 mhitch
387 1.19 mhitch if [ -d $root/emul/aout/. ]; then
388 1.19 mhitch echo "Using existing /emul/aout directory"
389 1.19 mhitch else
390 1.19 mhitch echo "Creating /emul/aout hierachy"
391 1.19 mhitch mkdir -p $root/usr/aout || return 1
392 1.19 mhitch
393 1.19 mhitch if [ ! -d $root/emul ]; then
394 1.19 mhitch mkdir $root/emul || return 1
395 1.19 mhitch fi
396 1.19 mhitch
397 1.19 mhitch if [ -h $root/emul/aout ]; then
398 1.19 mhitch echo "Preserving existing symbolic link from /emul/aout"
399 1.19 mhitch mv -f $root/emul/aout $root/emul/aout.old || return 1
400 1.19 mhitch fi
401 1.19 mhitch
402 1.19 mhitch ln -s ../usr/aout $root/emul/aout || return 1
403 1.19 mhitch fi
404 1.19 mhitch
405 1.19 mhitch # Create /emul/aout/etc and /emul/aout/usr/lib
406 1.19 mhitch if [ ! -d $root/emul/aout/etc ]; then
407 1.19 mhitch mkdir $root/emul/aout/etc || return 1
408 1.19 mhitch fi
409 1.19 mhitch if [ ! -d $root/emul/aout/usr/lib ]; then
410 1.19 mhitch mkdir -p $root/emul/aout/usr/lib || return 1
411 1.19 mhitch fi
412 1.19 mhitch
413 1.19 mhitch # Move ld.so.conf
414 1.19 mhitch if [ -f $root/etc/ld.so.conf ]; then
415 1.19 mhitch mv -f $root/etc/ld.so.conf $root/emul/aout/etc || return 1
416 1.19 mhitch fi
417 1.19 mhitch
418 1.19 mhitch # Finally, move the aout shared libraries from /usr/lib
419 1.19 mhitch md_mv_usr_lib $root || return 1
420 1.19 mhitch
421 1.19 mhitch # If X11 is installed, move the those libraries as well
422 1.19 mhitch xlibdir="/usr/X11R6/lib"
423 1.19 mhitch if [ -d $root/$xlibdir/. ]; then
424 1.19 mhitch mkdir -p $root/emul/aout/$xlibdir || return 1
425 1.19 mhitch md_mv_x_lib $root $xlibdir || return 1
426 1.19 mhitch fi
427 1.19 mhitch
428 1.19 mhitch echo "a.out emulation environment setup completed."
429 1.19 mhitch }
430 1.19 mhitch
431 1.19 mhitch md_prepare_upgrade()
432 1.19 mhitch {
433 1.19 mhitch cat << 'EOF'
434 1.19 mhitch This release uses the ELF binary object format. Existing (a.out) binaries
435 1.19 mhitch can still be used on your system after it has been upgraded, provided
436 1.19 mhitch that the shared libraries needed by those binaries are made available
437 1.19 mhitch in the filesystem hierarchy rooted at /emul/aout.
438 1.19 mhitch
439 1.19 mhitch This upgrade procedure will now establish this hierarchy by moving all
440 1.19 mhitch shared libraries in a.out format found in /usr/lib to /emul/aout/usr/lib.
441 1.19 mhitch It will also move the X11 shared libraries in a.out format from previous
442 1.22 mhitch NetBSD/amiga X11 installation sets, if they are installed.
443 1.19 mhitch
444 1.19 mhitch EOF
445 1.19 mhitch md_mv_aout_libs || {
446 1.19 mhitch echo "Failed to setup a.out emulation environment"
447 1.19 mhitch return 1
448 1.19 mhitch }
449 1.19 mhitch return 0
450 1.19 mhitch }
451 1.19 mhitch
452 1.19 mhitch # Flag to notify upgrade.sh of the existence of md_prepare_upgrade()
453 1.19 mhitch md_upgrade_prep_needed=1
454