Home | History | Annotate | Line # | Download | only in sparc
install.md revision 1.19
      1 #	$NetBSD: install.md,v 1.19 2004/01/17 05:30:01 lukem Exp $
      2 #
      3 #
      4 # Copyright (c) 1996 The NetBSD Foundation, Inc.
      5 # All rights reserved.
      6 #
      7 # This code is derived from software contributed to The NetBSD Foundation
      8 # by Jason R. Thorpe.
      9 #
     10 # Redistribution and use in source and binary forms, with or without
     11 # modification, are permitted provided that the following conditions
     12 # are met:
     13 # 1. Redistributions of source code must retain the above copyright
     14 #    notice, this list of conditions and the following disclaimer.
     15 # 2. Redistributions in binary form must reproduce the above copyright
     16 #    notice, this list of conditions and the following disclaimer in the
     17 #    documentation and/or other materials provided with the distribution.
     18 # 3. All advertising materials mentioning features or use of this software
     19 #    must display the following acknowledgement:
     20 #        This product includes software developed by the NetBSD
     21 #        Foundation, Inc. and its contributors.
     22 # 4. Neither the name of The NetBSD Foundation nor the names of its
     23 #    contributors may be used to endorse or promote products derived
     24 #    from this software without specific prior written permission.
     25 #
     26 # THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
     27 # ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
     28 # TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
     29 # PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
     30 # BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
     31 # CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
     32 # SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
     33 # INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
     34 # CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
     35 # ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
     36 # POSSIBILITY OF SUCH DAMAGE.
     37 #
     38 
     39 #
     40 # machine dependent section of installation/upgrade script.
     41 #
     42 
     43 # Machine-dependent install sets
     44 MDSETS="kern xbase xcomp xfont xserver"
     45 
     46 if [ "$MODE" = upgrade ]; then
     47 	RELOCATED_FILES_13="${RELOCATED_FILES_13} /usr/sbin/installboot /usr/mdec/installboot"
     48 fi
     49 
     50 md_set_term() {
     51 	if [ ! -z "$TERM" ]; then
     52 		return
     53 	fi
     54 	echo -n "Specify terminal type [sun]: "
     55 	getresp "sun"
     56 	TERM="$resp"
     57 	export TERM
     58 }
     59 
     60 md_makerootwritable() {
     61 	# Was: do_mfs_mount "/tmp" "2048"
     62 	# /tmp is the mount point
     63 	# 2048 is the size in DEV_BIZE blocks
     64 
     65 	umount /tmp > /dev/null 2>&1
     66 	if ! mount_mfs -s 2048 swap /tmp ; then
     67 		cat << \__mfs_failed_1
     68 
     69 FATAL ERROR: Can't mount the memory filesystem.
     70 
     71 __mfs_failed_1
     72 		exit
     73 	fi
     74 
     75 	# Bleh.  Give mount_mfs a chance to DTRT.
     76 	sleep 2
     77 }
     78 
     79 md_get_diskdevs() {
     80 	# return available disk devices
     81 	dmesg | sed -n -e 's/^\(sd[0-9]\) .*/\1/p' -e 's/^\(x[dy][0-9]\) .*/\1/p' | sort -u
     82 }
     83 
     84 md_get_cddevs() {
     85 	# return available CDROM devices
     86 	dmesg | sed -n -e 's/^\(cd[0-9]\) .*/\1/p' | sort -u
     87 }
     88 
     89 md_get_ifdevs() {
     90 	# return available network devices
     91 	dmesg | sed -n -e 's/^\(le[0-9]\) .*/\1/p' -e 's/^\(ie[0-9]\) .*/\1/p' | sort -u
     92 }
     93 
     94 md_get_partition_range() {
     95     # return range of valid partition letters
     96     echo "[a-h]"
     97 }
     98 
     99 md_installboot() {
    100 	# $1 is the boot disk
    101 	echo "Installing boot block..."
    102 	cp -p /usr/mdec/boot /mnt/boot
    103 	/usr/sbin/installboot -v /dev/r${1}a /usr/mdec/bootxx /boot
    104 }
    105 
    106 md_native_fstype() {
    107 }
    108 
    109 md_native_fsopts() {
    110 }
    111 
    112 md_checkfordisklabel() {
    113 	# $1 is the disk to check
    114 	local rval
    115 	local cfdl
    116 
    117 	cfdl=`disklabel $1 2>&1 > /dev/null | \
    118 	    sed -n -e '/no disk label/{s/.*/ndl/p;q;}; \
    119 		 /disk label corrupted/{s/.*/dlc/p;q;}; \
    120 		 $s/.*/no/p'`
    121 	if [ x$cfdl = xndl ]; then
    122 		rval=1
    123 	elif [ x$cfdl = xdlc ]; then
    124 		rval=2
    125 	else
    126 		rval=0
    127 	fi
    128 
    129 	return $rval
    130 }
    131 
    132 md_prep_disklabel()
    133 {
    134 	local _disk
    135 
    136 	_disk=$1
    137 	md_checkfordisklabel $_disk
    138 	case $? in
    139 	0)
    140 		echo -n "Do you wish to edit the disklabel on $_disk? [y]"
    141 		;;
    142 	1)
    143 		echo "WARNING: Disk $_disk has no label"
    144 		echo -n "Do you want to create one with the disklabel editor? [y]"
    145 		;;
    146 	2)
    147 		echo "WARNING: Label on disk $_disk is corrupted"
    148 		echo -n "Do you want to try and repair the damage using the disklabel editor? [y]"
    149 		;;
    150 	esac
    151 
    152 	getresp "y"
    153 	case "$resp" in
    154 	y*|Y*) ;;
    155 	*)	return ;;
    156 	esac
    157 
    158 	# display example
    159 	cat << \__md_prep_disklabel_1
    160 
    161 Here is an example of what the partition information will look like once
    162 you have entered the disklabel editor. Disk partition sizes and offsets
    163 are in sector (most likely 512 bytes) units. Make sure these size/offset
    164 pairs are on cylinder boundaries (the number of sector per cylinder is
    165 given in the `sectors/cylinder' entry, which is not shown here).
    166 
    167 Do not change any parameters except the partition layout and the label name.
    168 It's probably also wisest not to touch the `8 partitions:' line, even
    169 in case you have defined less than eight partitions.
    170 
    171 [Example]
    172 8 partitions:
    173 #        size   offset    fstype   [fsize bsize   cpg]
    174   a:    50176        0    4.2BSD     1024  8192    16   # (Cyl.    0 - 111)
    175   b:    64512    50176      swap                        # (Cyl.  112 - 255)
    176   c:   640192        0   unknown                        # (Cyl.    0 - 1428)
    177   d:   525504   114688    4.2BSD     1024  8192    16   # (Cyl.  256 - 1428)
    178 [End of example]
    179 
    180 __md_prep_disklabel_1
    181 	echo -n "Press [Enter] to continue "
    182 	getresp ""
    183 	disklabel -W ${_disk}
    184 	if [ -f /usr/bin/vi ]; then 
    185 		disklabel -e ${_disk}
    186 	else
    187 		disklabel -i ${_disk}
    188 	fi
    189 }
    190 
    191 md_copy_kernel() {
    192 	if [ ! -f /mnt/netbsd ]; then
    193 		echo -n "WARNING: No kernel installed; "
    194 		if [ -f /netbsd ]; then
    195 			echo -n "copying miniroot kernel... "
    196 			cp -p /netbsd /mnt/netbsd
    197 			echo "done."
    198 		else
    199 			echo -n "install a kernel manually."
    200 		fi
    201 	fi
    202 }
    203 
    204 md_welcome_banner() {
    205 {
    206 	if [ "$MODE" = "install" ]; then
    207 		echo ""
    208 		echo "Welcome to the NetBSD/sparc ${VERSION} installation program."
    209 		cat << \__welcome_banner_1
    210 
    211 This program is designed to help you put NetBSD on your disk,
    212 in a simple and rational way.  You'll be asked several questions,
    213 and it would probably be useful to have your disk's hardware
    214 manual, the installation notes, and a calculator handy.
    215 __welcome_banner_1
    216 
    217 	else
    218 		echo ""
    219 		echo "Welcome to the NetBSD/sparc ${VERSION} upgrade program."
    220 		cat << \__welcome_banner_2
    221 
    222 This program is designed to help you upgrade your NetBSD system in a
    223 simple and rational way.
    224 
    225 As a reminder, installing the `etc' binary set is NOT recommended.
    226 Once the rest of your system has been upgraded, you should manually
    227 merge any changes to files in the `etc' set into those files which
    228 already exist on your system.
    229 __welcome_banner_2
    230 	fi
    231 
    232 cat << \__welcome_banner_3
    233 
    234 As with anything which modifies your disk's contents, this
    235 program can cause SIGNIFICANT data loss, and you are advised
    236 to make sure your data is backed up before beginning the
    237 installation process.
    238 
    239 Default answers are displayed in brackets after the questions.
    240 You can hit Control-C at any time to quit, but if you do so at a
    241 prompt, you may have to hit return.  Also, quitting in the middle of
    242 installation may leave your system in an inconsistent state.
    243 
    244 __welcome_banner_3
    245 } | more
    246 }
    247 
    248 md_not_going_to_install() {
    249 	cat << \__not_going_to_install_1
    250 
    251 OK, then.  Enter `halt' at the prompt to halt the machine.  Once the
    252 machine has halted, power-cycle the system to load new boot code.
    253 
    254 __not_going_to_install_1
    255 }
    256 
    257 md_congrats() {
    258 	local what;
    259 	if [ "$MODE" = "install" ]; then
    260 		what="installed";
    261 	else
    262 		what="upgraded";
    263 	fi
    264 	cat << __congratulations_1
    265 
    266 CONGRATULATIONS!  You have successfully $what NetBSD!
    267 To boot the installed system, enter halt at the command prompt. Once the
    268 system has halted, reset the machine and boot from the disk.
    269 
    270 __congratulations_1
    271 }
    272 
    273 md_lib_is_aout() {
    274 	local r
    275 	test -h $1 && return 1
    276 	test -f $1 || return 1
    277 
    278 	r=`file $1 | sed -n -e '/ELF/p'`
    279 	test -z "$r" || return 1
    280 	return 0
    281 }
    282 
    283 
    284 md_mv_usr_lib() {
    285 	local root
    286 	root=$1
    287 	for f in $root/usr/lib/lib*.so.[0-9]*.[0-9]* ; do
    288 		md_lib_is_aout $f || continue
    289 		mv -f $f $root/emul/aout/usr/lib || return 1
    290 	done
    291 	return 0
    292 }
    293 
    294 md_x_shlib_set_14=" \
    295 	libICE.so.6.3 \
    296 	libPEX5.so.6.0 \
    297 	libSM.so.6.0 \
    298 	libX11.so.6.1 \
    299 	libXIE.so.6.0 \
    300 	libXaw.so.6.1 \
    301 	libXext.so.6.3 \
    302 	libXi.so.6.0 \
    303 	libXmu.so.6.0 \
    304 	libXp.so.6.2 \
    305 	libXt.so.6.0 \
    306 	libXtst.so.6.1 \
    307 	liboldX.so.6.0"
    308 
    309 md_mv_x_lib() {
    310 	local root xlibdir
    311 	root=$1
    312 	xlibdir=$2
    313 	for f in $md_x_shlib_set_14; do
    314 		md_lib_is_aout $root/$xlibdir/$f || continue
    315 		mv -f $root/$xlibdir/$f $root/emul/aout/$xlibdir || return 1
    316 	done
    317 	return 0
    318 }
    319 
    320 md_mv_aout_libs()
    321 {
    322 	local root xlibdir
    323 
    324 	root=/mnt	# XXX - should be global
    325 
    326 	if [ -d $root/emul/aout/. ]; then
    327 		echo "Using existing /emul/aout directory"
    328 	else
    329 		echo "Creating /emul/aout hierachy"
    330 		mkdir -p $root/usr/aout || return 1
    331 
    332 		if [ ! -d $root/emul ]; then
    333 			mkdir $root/emul || return 1
    334 		fi
    335 
    336 		if [ -h $root/emul/aout ]; then
    337 			echo "Preserving existing symbolic link from /emul/aout"
    338 			mv -f $root/emul/aout $root/emul/aout.old || return 1
    339 		fi
    340 
    341 		ln -s ../usr/aout $root/emul/aout || return 1
    342 	fi
    343 
    344 	# Create /emul/aout/etc and /emul/aout/usr/lib
    345 	if [ ! -d $root/emul/aout/etc ]; then
    346 		mkdir $root/emul/aout/etc || return 1
    347 	fi
    348 	if [ ! -d $root/emul/aout/usr/lib ]; then
    349 		mkdir -p $root/emul/aout/usr/lib || return 1
    350 	fi
    351 
    352 	# Move ld.so.conf
    353 	if [ -f $root/etc/ld.so.conf ]; then
    354 		mv -f $root/etc/ld.so.conf $root/emul/aout/etc || return 1
    355 	fi
    356 
    357 	# Finally, move the aout shared libraries from /usr/lib
    358 	md_mv_usr_lib $root || return 1
    359 
    360 	# If X11 is installed, move the those libraries as well
    361 	xlibdir="/usr/X11R6/lib"
    362 	if [ -d $root/$xlibdir/. ]; then
    363 		mkdir -p $root/emul/aout/$xlibdir || return 1
    364 		md_mv_x_lib $root $xlibdir || return 1
    365 	fi
    366 
    367 	echo "a.out emulation environment setup completed."
    368 }
    369 
    370 md_prepare_upgrade()  
    371 {
    372 cat << 'EOF'
    373 This release uses the ELF binary object format. Existing (a.out) binaries
    374 can still be used on your system after it has been upgraded, provided
    375 that the shared libraries needed by those binaries are made available
    376 in the filesystem hierarchy rooted at /emul/aout.
    377 
    378 This upgrade procedure will now establish this hierarchy by moving all
    379 shared libraries in a.out format found in /usr/lib to /emul/aout/usr/lib.
    380 It will also move the X11 shared libraries in a.out format from previous
    381 NetBSD/sparc X11 installation sets, if they are installed.
    382 
    383 EOF
    384 	md_mv_aout_libs || {
    385 		echo "Failed to setup a.out emulation environment"
    386 		return 1
    387 	}
    388 	return 0
    389 }
    390 
    391 # Flag to notify upgrade.sh of the existence of md_prepare_upgrade()
    392 md_upgrade_prep_needed=1
    393