summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorThorsten Lockert <tholo@cvs.openbsd.org>1997-05-03 07:50:17 +0000
committerThorsten Lockert <tholo@cvs.openbsd.org>1997-05-03 07:50:17 +0000
commit90649cdd4bbf3ba18c138570649f321c120f45c9 (patch)
tree063d2533e86d5d230b38ad4073e01f3e3ff5cdbb
parent852ef82bd6f0c5acf1e2c79d870d4ca158713810 (diff)
Almost complete install script that uses the machine-independant code from
the miniroot; not quite ready for prime-time yet but getting closer
-rw-r--r--distrib/i386/floppies/ramdisk/Makefile19
-rw-r--r--distrib/i386/floppies/ramdisk/dot.hdprofile59
-rw-r--r--distrib/i386/floppies/ramdisk/dot.profile8
-rw-r--r--distrib/i386/floppies/ramdisk/install.md929
-rw-r--r--distrib/i386/floppies/ramdisk/list8
5 files changed, 297 insertions, 726 deletions
diff --git a/distrib/i386/floppies/ramdisk/Makefile b/distrib/i386/floppies/ramdisk/Makefile
index a5d89a12c41..e1d1f31172d 100644
--- a/distrib/i386/floppies/ramdisk/Makefile
+++ b/distrib/i386/floppies/ramdisk/Makefile
@@ -1,4 +1,7 @@
-# $OpenBSD: Makefile,v 1.7 1997/04/17 02:10:42 niklas Exp $
+# $OpenBSD: Makefile,v 1.8 1997/05/03 07:50:14 tholo Exp $
+
+# Revision is 2.1
+REV= 21
TOP= ${.CURDIR}/..
@@ -15,7 +18,7 @@ VND_DEV= /dev/${VND}a
VND_RDEV= /dev/r${VND}a
VND_CRDEV= /dev/r${VND}c
PID!= echo $$$$
-REALIMAGE!= echo /tmp/image.${PID}
+REALIMAGE!= echo /var/tmp/image.${PID}
LISTFLOPPY= ${.CURDIR}/list_floppy
.include "Makefile.inc"
@@ -36,7 +39,7 @@ ${FS}: bsd.gz
.endif
mount ${VND_DEV} ${MOUNT_POINT}
TOPDIR=${TOP} CURDIR=${.CURDIR} OBJDIR=${.OBJDIR} \
- TARGDIR=${MOUNT_POINT} sh ${TOP}/runlist.sh ${LISTFLOPPY}
+ REV=${REV} TARGDIR=${MOUNT_POINT} sh ${TOP}/runlist.sh ${LISTFLOPPY}
sync
cat /*bin/* > /dev/null
sync
@@ -64,12 +67,14 @@ bsd.rd: ${IMAGE} bsd rdsetroot
cp bsd bsd.rd
${.CURDIR}/${__objdir}/rdsetroot bsd.rd < ${IMAGE}
-bsd:
- cd ${.CURDIR}/../../../../sys/arch/i386/conf && config RAMDISK
- cd ${.CURDIR}/../../../../sys/arch/i386/compile/RAMDISK && \
- make clean && make depend && make
+bsd: ${.CURDIR}/../../../../sys/arch/i386/compile/RAMDISK/bsd
cp ${.CURDIR}/../../../../sys/arch/i386/compile/RAMDISK/bsd bsd
+# cd ${.CURDIR}/../../../../sys/arch/i386/conf && config RAMDISK
+# cd ${.CURDIR}/../../../../sys/arch/i386/compile/RAMDISK && \
+# make clean && make depend && make
+# cp ${.CURDIR}/../../../../sys/arch/i386/compile/RAMDISK/bsd bsd
+
${IMAGE}: ${CBIN} rd_setup do_files rd_teardown
rd_setup: ${CBIN}
diff --git a/distrib/i386/floppies/ramdisk/dot.hdprofile b/distrib/i386/floppies/ramdisk/dot.hdprofile
deleted file mode 100644
index 047adae43a8..00000000000
--- a/distrib/i386/floppies/ramdisk/dot.hdprofile
+++ /dev/null
@@ -1,59 +0,0 @@
-# $OpenBSD: dot.hdprofile,v 1.1 1997/04/13 17:17:53 mickey Exp $
-#
-# Copyright (c) 1994 Christopher G. Demetriou
-# All rights reserved.
-#
-# Redistribution and use in source and binary forms, with or without
-# modification, are permitted provided that the following conditions
-# are met:
-# 1. Redistributions of source code must retain the above copyright
-# notice, this list of conditions and the following disclaimer.
-# 2. Redistributions in binary form must reproduce the above copyright
-# notice, this list of conditions and the following disclaimer in the
-# documentation and/or other materials provided with the distribution.
-# 3. All advertising materials mentioning features or use of this software
-# must display the following acknowledgement:
-# This product includes software developed by Christopher G. Demetriou.
-# 4. The name of the author may not be used to endorse or promote products
-# derived from this software without specific prior written permission
-#
-# THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
-# IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
-# OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
-# IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
-# INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
-# NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
-# THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-
-PATH=/sbin:/bin:/usr/bin:/usr/sbin:/
-export PATH
-TERM=pc3
-export TERM
-
-umask 022
-
-if [ "X${DONEPROFILE}" = "X" ]; then
- DONEPROFILE=YES
-
- echo "Checking filesystems..."
- fsck -y
-
- echo "Mounting filesystems..."
- mount -a
- mount -t kernfs /kern /kern
-
- # set up some sane defaults
- echo 'erase ^?, werase ^W, kill ^U, intr ^C'
- stty newcrt werase ^W intr ^C kill ^U erase ^? 9600
- echo ''
-
- # pull in the functions that people will use from the shell prompt.
- . /.commonutils
- . /.instutils
-
- echo "Follow the installation directions to install the OpenBSD"
- echo "distribution sets."
-fi
diff --git a/distrib/i386/floppies/ramdisk/dot.profile b/distrib/i386/floppies/ramdisk/dot.profile
index 7dc5eee25ca..13e93aa0812 100644
--- a/distrib/i386/floppies/ramdisk/dot.profile
+++ b/distrib/i386/floppies/ramdisk/dot.profile
@@ -1,4 +1,4 @@
-# $OpenBSD: dot.profile,v 1.3 1997/04/17 10:02:03 deraadt Exp $
+# $OpenBSD: dot.profile,v 1.4 1997/05/03 07:50:15 tholo Exp $
#
# Copyright (c) 1994 Christopher G. Demetriou
# All rights reserved.
@@ -31,8 +31,6 @@
PATH=/sbin:/bin:/usr/bin:/usr/sbin:/
export PATH
-TERM=pc3
-export TERM
HOME=/
export HOME
@@ -55,6 +53,6 @@ if [ "X${DONEPROFILE}" = "X" ]; then
. /.commonutils
. /.instutils
- # run the installation script.
- install
+ echo "Follow the installation directions to install or upgrade"
+ echo "the OpenBSD distribution sets."
fi
diff --git a/distrib/i386/floppies/ramdisk/install.md b/distrib/i386/floppies/ramdisk/install.md
index 8b8b02bdcc9..d278c963419 100644
--- a/distrib/i386/floppies/ramdisk/install.md
+++ b/distrib/i386/floppies/ramdisk/install.md
@@ -1,9 +1,12 @@
-#!/bin/sh
-# $OpenBSD: install.md,v 1.6 1997/04/30 06:32:05 tholo Exp $
+# $OpenBSD: install.md,v 1.7 1997/05/03 07:50:15 tholo Exp $
#
-# Copyright (c) 1994 Christopher G. Demetriou
+#
+# Copyright rc) 1996 The NetBSD Foundation, Inc.
# All rights reserved.
#
+# This code is derived from software contributed to The NetBSD Foundation
+# by Jason R. Thorpe.
+#
# Redistribution and use in source and binary forms, with or without
# modification, are permitted provided that the following conditions
# are met:
@@ -14,667 +17,289 @@
# documentation and/or other materials provided with the distribution.
# 3. All advertising materials mentioning features or use of this software
# must display the following acknowledgement:
-# This product includes software developed by Christopher G. Demetriou.
-# 4. The name of the author may not be used to endorse or promote products
-# derived from this software without specific prior written permission
+# This product includes software developed by the NetBSD
+# Foundation, Inc. and its contributors.
+# 4. Neither the name of The NetBSD Foundation nor the names of its
+# contributors may be used to endorse or promote products derived
+# from this software without specific prior written permission.
+#
+# THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
+# ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
+# TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
+# PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE
+# LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+# CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+# SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
+# INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
+# CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
+# ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
+# POSSIBILITY OF SUCH DAMAGE.
+#
+
+#
+# machine dependent section of installation/upgrade script.
#
-# THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
-# IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
-# OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
-# IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
-# INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
-# NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
-# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
-# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
-# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
-# THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-
-# OpenBSD installation script.
-# In a perfect world, this would be a nice C program, with a reasonable
-# user interface.
-
-DT=/etc/disktab # /etc/disktab
-FSTABDIR=/mnt/etc # /mnt/etc
-#DONTDOIT=echo
-
-VERSION=2.1
-FSTAB=${FSTABDIR}/fstab
-
-# XXX turn into a loop which understands ! for a subshell. Also,
-# XXX is it possible to detect ^Z in a prompt and re-prompt when sh
-# XXX is unsuspended?
-getresp() {
- read resp
- if [ "X$resp" = "X" ]; then
- resp=$1
+
+# Machine-dependent install sets
+MDSETS=""
+
+md_set_term() {
+ if [ ! -z "$TERM" ]; then
+ return
fi
+ echo -n "Specify terminal type [pc3]: "
+ getresp "pc3"
+ TERM="$resp"
+ export TERM
}
-echo "Welcome to the OpenBSD ${VERSION} installation program."
-echo ""
-echo "This program is will put OpenBSD on your hard disk. It is not painless"
-echo "but it could be worse. You'll be asked several questions, and it would"
-echo "probably be useful to have your disk's hardware manual, the installation"
-echo "notes, and a calculator handy."
-echo ""
-echo "In particular, you will need to know some reasonably detailed information"
-echo "about your disk's geometry, because this program does not know everything."
-echo ""
-echo "As with anything which modifies your hard drive's contents, this program"
-echo "can cause SIGNIFICANT data loss, and you are advised to make sure your"
-echo "hard drive is backed up before beginning the installation process."
-echo ""
-echo "Default answers are displyed in brackets after the questions. You can"
-echo "hit Control-C at any time to quit. Also, quitting towards the latter"
-echo "part of the installation may leave your system in an inconsistent state."
-echo ""
-echo -n "Proceed with installation? [n] "
-getresp "n"
-case "$resp" in
-y*|Y*)
- echo "Cool! Let's get to it..."
- ;;
-*)
- echo "OK, simply reset the machine at any time."
- exit
- ;;
-esac
-
-echo ""
-echo "To do the installation, you'll need to provide some information about"
-echo "your disk."
-
-echo "OpenBSD can be installed on ST506, ESDI, IDE, or SCSI disks."
-echo -n "What kind of disk will you be installing on? [SCSI] "
-getresp "SCSI"
-case "$resp" in
-esdi|ESDI|st506|ST506)
- drivetype=wd
- echo -n "Does it support _automatic_ sector remapping? [y] "
- getresp "y"
- case "$resp" in
- n*|N*)
- sect_fwd="sf:"
- ;;
- *)
- sect_fwd=""
- ;;
- esac
-;;
-ide|IDE)
- drivetype=wd
- sect_fwd=""
- type=ST506
- ;;
-scsi|SCSI)
- drivetype=sd
- sect_fwd=""
- type=SCSI
- ;;
-esac
-
-# find out what units are possible for that disk, and query the user.
-driveunits=`ls /dev/${drivetype}?a | sed -e 's,/dev/\(...\)a,\1,g'`
-if [ "X${driveunits}" = "X" ]; then
- echo "FATAL ERROR:"
- echo "No devices for disks of type '${drivetype}'."
- echo "This is probably a bug in the install disks."
- echo "Exiting install program."
- exit
-fi
-prefdrive=${drivetype}0
-
-echo "The following ${drivetype}-type disks are supported by this"
-echo "installation procedure:"
-echo "${driveunits}"
-echo "Note that they may not exist in _your_ machine; the list of"
-echo "disks in your machine was printed when the system was booting."
-while [ "X${drivename}" = "X" ]; do
- echo -n "Which disk would like to install on? [${prefdrive}] "
- getresp ${prefdrive}
- otherdrives=`echo "${driveunits}" | sed -e s,${resp},,`
- if [ "X${driveunits}" = "X${otherdrives}" ]; then
- echo "\"${resp}\" is an invalid drive name. Valid choices"
- echo "are: "${driveunits}
+md_makerootwritable() {
+}
+
+md_get_diskdevs() {
+ # return available disk devices
+ cat /kern/msgbuf | egrep "^[sw]d[0-9] " | cut -d" " -f1 | sort -u
+}
+
+md_get_cddevs() {
+ # return available CDROM devices
+ cat /kern/msgbuf | egrep "^a?cd[0-9] " | cut -d" " -f1 | sort -u
+}
+
+md_get_ifdevs() {
+ # return available network devices
+ cat /kern/msgbuf | egrep "^(e[dglp][0-9] |[dil]e[0-9] |f[ep]a[0-9] )" | cut -d" " -f1 | sort -u
+}
+
+md_get_partition_range() {
+ # return range of valid partition letters
+ echo "[a-p]"
+}
+
+md_installboot() {
+ echo "Installing boot block..."
+ disklabel -B $1
+}
+
+md_native_fstype() {
+ echo "msdos"
+}
+
+md_native_fsopts() {
+ echo "-r"
+}
+
+md_checkfordisklabel() {
+ # $1 is the disk to check
+ local rval
+
+ disklabel -r $1 > /dev/null 2> /tmp/checkfordisklabel
+ if grep "no disk label" /tmp/checkfordisklabel; then
+ rval=1
+ elif grep "disk label corrupted" /tmp/checkfordisklabel; then
+ rval=2
else
- drivename=${resp}
+ rval=0
fi
-done
-
-echo "Using disk ${drivename}."
-echo -n "What kind of disk is it? (one word please) [my${drivetype}] "
-getresp "my${drivetype}"
-labelname=$resp
-
-echo ""
-echo "You will now need to provide some information about your disk's geometry."
-echo "This should either be in the User's Manual for your disk, or you should"
-echo "have written down what OpenBSD printed when booting. Note that the"
-echo "geometry that's printed at boot time is preferred.) You may choose to"
-echo "view the initial boot messages for your system again right now if you like."
-echo -n "View the boot messages again? [n] "
-getresp "n"
-case "$resp" in
-y*|Y*)
- less -rsS /kern/msgbuf
- ;;
-*)
- echo ""
- ;;
-esac
-
-echo "You will now enter the disk geometry information:"
-
-bytes_per_sect=`cat /kern/msgbuf |\
- sed -n -e /^${drivename}:/p -e /^${drivename}:/q |\
- sed 's/\([^ ]*[ ]*\)\{8\}\([^ ]*\).*$/\2/'`
-echo -n "Number of bytes per disk sector? [$bytes_per_sect] "
-getresp $bytes_per_sect
-bytes_per_sect="$resp"
-
-cyls_per_disk=`cat /kern/msgbuf |\
- sed -n -e /^${drivename}:/p -e /^${drivename}:/q |\
- sed 's/\([^ ]*[ ]*\)\{2\}\([^ ]*\).*$/\2/'`
-echo -n "Number of disk cylinders? [$cyls_per_disk]"
-getresp $cyls_per_disk
-cyls_per_disk="$resp"
-
-tracks_per_cyl=`cat /kern/msgbuf |\
- sed -n -e /^${drivename}:/p -e /^${drivename}:/q |\
- sed 's/\([^ ]*[ ]*\)\{4\}\([^ ]*\).*$/\2/'`
-echo -n "Number of disk tracks (heads) per disk cylinder? [$tracks_per_cyl]"
-getresp $tracks_per_cyl
-tracks_per_cyl="$resp"
-
-sects_per_track=`cat /kern/msgbuf |\
- sed -n -e /^${drivename}:/p -e /^${drivename}:/q |\
- sed 's/\([^ ]*[ ]*\)\{6\}\([^ ]*\).*$/\2/'`
-echo -n "Number of disk sectors per disk track? [$sects_per_track]"
-getresp $sects_per_track
-sects_per_track="$resp"
-
-cylindersize=`expr $sects_per_track \* $tracks_per_cyl`
-cylbytes=`expr $cylindersize \* $bytes_per_sect`
-disksize=`expr $cylindersize \* $cyls_per_disk`
-
-echo ""
-echo "Your disk has a total of $disksize $bytes_per_sect byte sectors,"
-echo "arranged as $cyls_per_disk cylinders which contain $cylindersize "
-echo "sectors ($cylbytes bytes) each."
-echo "You can specify partition sizes in cylinders ('c') or sectors ('s')."
-while [ "X${sizemult}" = "X" ]; do
- echo -n "What units would you like to use? [cylinders] "
- getresp cylinders
+
+ rm -f /tmp/checkfordisklabel
+ return $rval
+}
+
+md_prep_fdisk()
+{
+ local _disk
+ local _done
+
+ _disk=$1
+ echo "This disk has not previously been used with OpenBSD. Do you wish"
+ echo "to share this disk with other operating systems (such as Windows"
+ echo -n "95, MS-DOS, Linux etc.)? [y]"
+ getresp "y"
case "$resp" in
- c*|C*)
- sizemult=$cylindersize
- sizeunit="cylinders"
- maxdisk=$cyls_per_disk
- ;;
- s*|S*)
- sizemult=1
- sizeunit="sectors"
- maxdisk=$disksize;
- ;;
- *)
- echo "Enter cylinders ('c') or sectors ('s')."
- ;;
- esac
-done
-
-if [ $sizeunit = "sectors" ]; then
- echo "For best disk performance or workable CHS-translating IDE systems,"
- echo "partitions should begin and end on cylinder boundaries. Wherever"
- echo "possible, use multiples of the cylinder size ($cylindersize sectors)."
-fi
-
-echo -n ""
-echo -n "Size of OpenBSD portion of disk (in $sizeunit) ? [$maxdisk] "
-getresp "$maxdisk"
-partition=$resp
-partition_sects=`expr $resp \* $sizemult`
-part_offset=0
-if [ $partition_sects -lt $disksize ]; then
- echo -n "Offset of OpenBSD portion of disk (in $sizeunit)? [0]"
- getresp '0'
- part_offset=$resp
-fi
-badspacesec=0
-if [ "$sect_fwd" = "sf:" ]; then
- badspacecyl=`expr $sects_per_track + 126`
- badspacecyl=`expr $badspacecyl + $cylindersize - 1`
- badspacecyl=`expr $badspacecyl / $cylindersize`
- badspacesec=`expr $badspacecyl \* $cylindersize`
- echo ""
- echo -n "Using $badspacesec sectors ($badspacecyl cylinders) for the "
- echo "bad144 bad block table"
-fi
-
-sects_left=`expr $partition_sects - $badspacesec`
-units_left=`expr $sects_left / $sizemult`
-echo ""
-echo "There are $units_left $sizeunit left to allocate."
-echo ""
-root=0
-while [ $root -eq 0 ]; do
- echo -n "Root partition size (in $sizeunit)? "
- getresp
- case $resp in
- [1-9]*)
- total=$resp
- if [ $total -gt $units_left ]; then
- echo -n "Root size is greater than remaining "
- echo "free space on disk."
- else
- root=$resp
- fi
- ;;
+ n*|N*) return ;;
+ *) ;;
esac
-done
-root_offset=$part_offset
-part_used=`expr $root + $badspacesec / $sizemult`
-units_left=`expr $partition - $part_used`
-echo ""
-
-swap=0
-while [ $swap -eq 0 ]; do
- echo "$units_left $sizeunit remaining in OpenBSD portion of disk."
- echo -n "Swap partition size (in $sizeunit)? "
- getresp
- case $resp in
- [1-9]*)
- if [ $swap -gt $units_left ]; then
- echo -n "Swap size is greater than remaining "
- echo "free space on disk."
- else
- swap=$resp
- fi
- ;;
- esac
-done
-swap_offset=`expr $root_offset + $root`
-part_used=`expr $part_used + $swap`
-echo ""
-
-fragsize=1024
-blocksize=8192
-cat /etc/disktab.preinstall > $DT
-echo "" >> $DT
-echo "$labelname|OpenBSD installation generated:\\" >> $DT
-echo " :dt=${type}:ty=winchester:\\" >> $DT
-echo -n " :nc#${cyls_per_disk}:ns#${sects_per_track}" >> $DT
-echo ":nt#${tracks_per_cyl}:\\" >> $DT
-echo " :se#${bytes_per_sect}:${sect_fwd}\\" >> $DT
-_size=`expr $root \* $sizemult`
-_offset=`expr $root_offset \* $sizemult`
-echo -n " :pa#${_size}:oa#${_offset}" >> $DT
-echo ":ta=4.2BSD:ba#${blocksize}:fa#${fragsize}:\\" >> $DT
-_size=`expr $swap \* $sizemult`
-_offset=`expr $swap_offset \* $sizemult`
-echo " :pb#${_size}:ob#${_offset}:tb=swap:\\" >> $DT
-echo " :pc#${disksize}:oc#0:\\" >> $DT
-
-echo "You now must enter information about any other partitions to be created in"
-echo "the OpenBSD portion of the disk. This process will be complete when you've"
-echo "filled up all remaining space in the OpenBSD portion of the disk."
-
-while [ $part_used -lt $partition ]; do
- part_size=0
- units_left=`expr $partition - $part_used`
- while [ $part_size -eq 0 ]; do
- echo ""
- echo -n "$units_left $sizeunit remaining in OpenBSD portion of "
- echo "the disk"
- echo -n "Next partition size (in $sizeunit) [$units_left] ? "
- getresp "$units_left"
- case $resp in
- [1-9]*)
- total=`expr $part_used + $resp`
- if [ $total -gt $partition ]; then
- echo "That would make the parition too large to fit!"
- else
- part_size=$resp
- part_used=$total
- part_name=""
- while [ "$part_name" = "" ]; do
- echo -n "Mount point? "
- getresp
- part_name=$resp
- done
- fi
- ;;
+
+ echo "WARNING: Wrong information in the BIOS partition table might"
+ echo "render the disk unusable."
+
+ echo
+ echo "Current partition information is:"
+ fdisk ${_disk}
+ echo -n "Press [Enter] to continue "
+ getresp ""
+
+ _done=0
+ while [ $_done eq 0 ]; do
+ echo
+ cat << \__md_prep_fdisk_1
+
+An OpenBSD partition should have type 166 (A6), and should be the only
+partition marked as active. Furthermore, the partitions must NOT
+overlap each others. fdisk will be started in update mode, and you
+will be able to add this information as needed. If you make a mistake,
+exit fdisk without storing the new information, and you will be allowed
+to start over.
+__md_prep_fdisk_1
+ echo -n "Press [Enter] to continue "
+ getresp ""
+
+ fdisk -u ${_disk}
+
+ echo
+ echo "The new partition information is:"
+ fdisk ${_disk}
+
+ echo
+ echo "Is this information correct (if not, you will be permitted to "
+ echo -n "edit it again)? [n] "
+ getresp "n"
+
+ case "$resp" in
+ n*|N*) ;;
+ *) _done=1 ;;
esac
done
- if [ "$ename" = "" ]; then
- ename=$part_name
- offset=`expr $part_offset + $root + $swap`
- _size=`expr $part_size \* $sizemult`
- _offset=`expr $offset \* $sizemult`
- echo -n " :pe#${_size}:oe#${_offset}" >> $DT
- echo ":te=4.2BSD:be#${blocksize}:fe#${fragsize}:\\" >> $DT
- offset=`expr $offset + $part_size`
- elif [ "$fname" = "" ]; then
- fname=$part_name
- _size=`expr $part_size \* $sizemult`
- _offset=`expr $offset \* $sizemult`
- echo -n " :pf#${_size}:of#${_offset}" >> $DT
- echo ":tf=4.2BSD:bf#${blocksize}:ff#${fragsize}:\\" >> $DT
- offset=`expr $offset + $part_size`
- elif [ "$gname" = "" ]; then
- gname=$part_name
- _size=`expr $part_size \* $sizemult`
- _offset=`expr $offset \* $sizemult`
- echo -n " :pg#${_size}:og#${_offset}" >> $DT
- echo ":tg=4.2BSD:bg#${blocksize}:fg#${fragsize}:\\" >> $DT
- offset=`expr $offset + $part_size`
- elif [ "$hname" = "" ]; then
- hname=$part_name
- _size=`expr $part_size \* $sizemult`
- _offset=`expr $offset \* $sizemult`
- echo -n " :ph#${_size}:oh#${_offset}" >> $DT
- echo ":th=4.2BSD:bh#${blocksize}:fh#${fragsize}:\\" >> $DT
- part_used=$partition
- elif [ "$iname" = "" ]; then
- iname=$part_name
- _size=`expr $part_size \* $sizemult`
- _offset=`expr $offset \* $sizemult`
- echo -n " :pi#${_size}:oi#${_offset}" >> $DT
- echo ":ti=4.2BSD:bi#${blocksize}:fi#${fragsize}:\\" >> $DT
- part_used=$partition
- elif [ "$jname" = "" ]; then
- jname=$part_name
- _size=`expr $part_size \* $sizemult`
- _offset=`expr $offset \* $sizemult`
- echo -n " :pj#${_size}:oj#${_offset}" >> $DT
- echo ":tj=4.2BSD:bj#${blocksize}:fj#${fragsize}:\\" >> $DT
- part_used=$partition
- elif [ "$kname" = "" ]; then
- kname=$part_name
- _size=`expr $part_size \* $sizemult`
- _offset=`expr $offset \* $sizemult`
- echo -n " :pk#${_size}:ok#${_offset}" >> $DT
- echo ":tk=4.2BSD:bk#${blocksize}:fk#${fragsize}:\\" >> $DT
- part_used=$partition
- elif [ "$lname" = "" ]; then
- lname=$part_name
- _size=`expr $part_size \* $sizemult`
- _offset=`expr $offset \* $sizemult`
- echo -n " :pl#${_size}:ol#${_offset}" >> $DT
- echo ":tl=4.2BSD:bl#${blocksize}:fl#${fragsize}:\\" >> $DT
- part_used=$partition
- elif [ "$mname" = "" ]; then
- mname=$part_name
- _size=`expr $part_size \* $sizemult`
- _offset=`expr $offset \* $sizemult`
- echo -n " :pm#${_size}:om#${_offset}" >> $DT
- echo ":tm=4.2BSD:bm#${blocksize}:fm#${fragsize}:\\" >> $DT
- part_used=$partition
- elif [ "$nname" = "" ]; then
- nname=$part_name
- _size=`expr $part_size \* $sizemult`
- _offset=`expr $offset \* $sizemult`
- echo -n " :pn#${_size}:on#${_offset}" >> $DT
- echo ":tn=4.2BSD:bn#${blocksize}:fn#${fragsize}:\\" >> $DT
- part_used=$partition
- elif [ "$oname" = "" ]; then
- oname=$part_name
- _size=`expr $part_size \* $sizemult`
- _offset=`expr $offset \* $sizemult`
- echo -n " :po#${_size}:oo#${_offset}" >> $DT
- echo ":to=4.2BSD:bo#${blocksize}:fo#${fragsize}:\\" >> $DT
- part_used=$partition
- elif [ "$pname" = "" ]; then
- pname=$part_name
- _size=`expr $part_size \* $sizemult`
- _offset=`expr $offset \* $sizemult`
- echo -n " :pp#${_size}:op#${_offset}" >> $DT
- echo ":tp=4.2BSD:bp#${blocksize}:fp#${fragsize}:\\" >> $DT
- part_used=$partition
- fi
-done
-echo "" >> $DT
-sync
-
-echo ""
-echo "THIS IS YOUR LAST CHANCE!!!"
-echo -n "Are you SURE you want OpenBSD installed on your hard drive? (yes/no) "
-answer=""
-while [ "$answer" = "" ]; do
- getresp
- case $resp in
- yes|YES)
- answer=yes
+
+ echo "Please take note of the offset and size of the OpenBSD partition"
+ echo "of the disk, as you will need that for the BSD disk label."
+ echo -n "Press [Enter] to continue "
+ getresp ""
+}
+
+md_prep_disklabel()
+{
+ local _disk
+
+ _disk=$1
+ md_checkfordisklabel $_disk
+ case $? in
+ 0)
+ echo -n "Do you wish to edit the disklabel on $_disk? [y]"
;;
- no|NO)
- echo "OK, then. Simply reset your machine at any time."
- exit
+ 1)
+ md_prep_fdisk ${_disk}
+ echo "WARNING: Disk $_disk has no label"
+ echo -n "Do you want to create one with the disklabel editor? [y]"
;;
- *)
- echo -n "I want a yes or no answer... well? "
+ 2)
+ echo "WARNING: Label on disk $_disk is corrupted"
+ echo -n "Do you want to try and repair the damage using the disklabel editor? [y]"
;;
esac
-done
-
-umount -f /mnt > /dev/null 2>&1
-umount -f /mnt2 > /dev/null 2>&1
-
-echo ""
-echo "Labeling disk $drivename..."
-# XXX add fdisk support
-$DONTDOIT disklabel -w -B $drivename $labelname
-
-if [ "$sect_fwd" = "sf:" ]; then
- echo "Initializing bad144 badblock table..."
- $DONTDOIT bad144 $drivename 0
-fi
-
-echo "Initializing root filesystem, and mounting..."
-$DONTDOIT newfs /dev/r${drivename}a $name
-$DONTDOIT mount -v /dev/${drivename}a /mnt
-if [ "$ename" != "" ]; then
- echo "Initializing $ename filesystem, and mounting..."
- $DONTDOIT newfs /dev/r${drivename}e $name
- $DONTDOIT mkdir -p /mnt/$ename
- $DONTDOIT mount -v /dev/${drivename}e /mnt/$ename
-fi
-if [ "$fname" != "" ]; then
- echo "Initializing $fname filesystem, and mounting..."
- $DONTDOIT newfs /dev/r${drivename}f $name
- $DONTDOIT mkdir -p /mnt/$fname
- $DONTDOIT mount -v /dev/${drivename}f /mnt/$fname
-fi
-if [ "$gname" != "" ]; then
- echo "Initializing $gname filesystem, and mounting..."
- $DONTDOIT newfs /dev/r${drivename}g $name
- $DONTDOIT mkdir -p /mnt/$gname
- $DONTDOIT mount -v /dev/${drivename}g /mnt/$gname
-fi
-if [ "$hname" != "" ]; then
- echo "Initializing $hname filesystem, and mounting..."
- $DONTDOIT newfs /dev/r${drivename}h $name
- $DONTDOIT mkdir -p /mnt/$hname
- $DONTDOIT mount -v /dev/${drivename}h /mnt/$hname
-fi
-if [ "$iname" != "" ]; then
- echo "Initializing $iname filesystem, and mounting..."
- $DONTDOIT newfs /dev/r${drivename}i $name
- $DONTDOIT mkdir -p /mnt/$iname
- $DONTDOIT mount -v /dev/${drivename}i /mnt/$iname
-fi
-if [ "$jname" != "" ]; then
- echo "Initializing $jname filesystem, and mounting..."
- $DONTDOIT newfs /dev/r${drivename}j $name
- $DONTDOIT mkdir -p /mnt/$jname
- $DONTDOIT mount -v /dev/${drivename}j /mnt/$jname
-fi
-if [ "$kname" != "" ]; then
- echo "Initializing $kname filesystem, and mounting..."
- $DONTDOIT newfs /dev/r${drivename}k $name
- $DONTDOIT mkdir -p /mnt/$kname
- $DONTDOIT mount -v /dev/${drivename}k /mnt/$kname
-fi
-if [ "$lname" != "" ]; then
- echo "Initializing $lname filesystem, and mounting..."
- $DONTDOIT newfs /dev/r${drivename}l $name
- $DONTDOIT mkdir -p /mnt/$lname
- $DONTDOIT mount -v /dev/${drivename}l /mnt/$lname
-fi
-if [ "$mname" != "" ]; then
- echo "Initializing $mname filesystem, and mounting..."
- $DONTDOIT newfs /dev/r${drivename}m $name
- $DONTDOIT mkdir -p /mnt/$mname
- $DONTDOIT mount -v /dev/${drivename}m /mnt/$mname
-fi
-if [ "$nname" != "" ]; then
- echo "Initializing $nname filesystem, and mounting..."
- $DONTDOIT newfs /dev/r${drivename}n $name
- $DONTDOIT mkdir -p /mnt/$nname
- $DONTDOIT mount -v /dev/${drivename}n /mnt/$nname
-fi
-if [ "$oname" != "" ]; then
- echo "Initializing $oname filesystem, and mounting..."
- $DONTDOIT newfs /dev/r${drivename}o $name
- $DONTDOIT mkdir -p /mnt/$oname
- $DONTDOIT mount -v /dev/${drivename}o /mnt/$oname
-fi
-if [ "$pname" != "" ]; then
- echo "Initializing $pname filesystem, and mounting..."
- $DONTDOIT newfs /dev/r${drivename}p $name
- $DONTDOIT mkdir -p /mnt/$pname
- $DONTDOIT mount -v /dev/${drivename}p /mnt/$pname
-fi
-
-echo "Populating filesystems with bootstrapping binaries and config files"
-$DONTDOIT tar -cXf - . | (cd /mnt ; tar -xpf - )
-
-echo -n "Creating an fstab..."
-echo /dev/${drivename}a / ffs rw 1 1 | sed -e s,//,/, > $FSTAB
-if [ "$ename" != "" ]; then
- echo /dev/${drivename}e /$ename ffs rw 1 2 | sed -e s,//,/, >> $FSTAB
-fi
-if [ "$fname" != "" ]; then
- echo /dev/${drivename}f /$fname ffs rw 1 3 | sed -e s,//,/, >> $FSTAB
-fi
-if [ "$gname" != "" ]; then
- echo /dev/${drivename}g /$gname ffs rw 1 4 | sed -e s,//,/, >> $FSTAB
-fi
-if [ "$hname" != "" ]; then
- echo /dev/${drivename}h /$hname ffs rw 1 5 | sed -e s,//,/, >> $FSTAB
-fi
-if [ "$iname" != "" ]; then
- echo /dev/${drivename}i /$iname ffs rw 1 5 | sed -e s,//,/, >> $FSTAB
-fi
-if [ "$jname" != "" ]; then
- echo /dev/${drivename}j /$jname ffs rw 1 5 | sed -e s,//,/, >> $FSTAB
-fi
-if [ "$kname" != "" ]; then
- echo /dev/${drivename}k /$kname ffs rw 1 5 | sed -e s,//,/, >> $FSTAB
-fi
-if [ "$lname" != "" ]; then
- echo /dev/${drivename}l /$lname ffs rw 1 5 | sed -e s,//,/, >> $FSTAB
-fi
-if [ "$mname" != "" ]; then
- echo /dev/${drivename}m /$mname ffs rw 1 5 | sed -e s,//,/, >> $FSTAB
-fi
-if [ "$nname" != "" ]; then
- echo /dev/${drivename}n /$nname ffs rw 1 5 | sed -e s,//,/, >> $FSTAB
-fi
-if [ "$oname" != "" ]; then
- echo /dev/${drivename}o /$oname ffs rw 1 5 | sed -e s,//,/, >> $FSTAB
-fi
-if [ "$pname" != "" ]; then
- echo /dev/${drivename}p /$pname ffs rw 1 5 | sed -e s,//,/, >> $FSTAB
-fi
-
-sync
-
-echo "OK! The preliminary work of setting up your disk is now complete."
-echo "Currently the hard drive's root filesystem is mounted on /mnt"
-
-echo ""
-echo "How would you like to install the distribution and kernels?"
-echo -n "ftp, http, msdos, ext2fs, tape, nfs, cd9660, local? [ftp] "
-getresp "ftp"
-method=${resp}
-case "${method}" in
-ftp|http|nfs)
- echo -n "What is your ethernet interface name? [ep0] "
- getresp "ep0"
- intf=${resp}
- echo -n "Does your ethernet interface need special flags like -link0? [] "
+
+ getresp "y"
+ case "$resp" in
+ y*|Y*) ;;
+ *) return ;;
+ esac
+
+ # display example
+ cat << \__md_prep_disklabel_1
+
+Here is an example of what the partition information will look like once
+you have entered the disklabel editor. Disk partition sizes and offsets
+are in sector (most likely 512 bytes) units. Make sure these size/offset
+pairs are on cylinder boundaries (the number of sector per cylinder is
+given in the `sectors/cylinder' entry, which is not shown here).
+
+Also, if this disk is shared with other operating systems and have a BIOS
+partition table, make sure all file systems reserved for OpenBSD are within
+the offset and size specified in the BIOS partition table.
+
+Do not change any parameters except the partition layout and the label name.
+
+[Example]
+16 partitions:
+# size offset fstype [fsize bsize cpg]
+ a: 50176 0 4.2BSD 1024 8192 16 # (Cyl. 0 - 111)
+ b: 64512 50176 swap # (Cyl. 112 - 255)
+ c: 640192 0 unknown # (Cyl. 0 - 1428)
+ d: 525504 114688 4.2BSD 1024 8192 16 # (Cyl. 256 - 1428)
+[End of example]
+
+__md_prep_disklabel_1
+ echo -n "Press [Enter] to continue "
getresp ""
- intflags=${resp}
- echo -n "What is your IP address? [199.185.137.99] "
- getresp "199.185.137.99"
- myip=${resp}
- echo -n "What is your IP netmask? [255.255.255.0] "
- getresp "255.255.255.0"
- mymask=${resp}
- $DONTDOIT ifconfig ${intf} inet ${myip} netmask ${mymask} ${intflags} up
- echo -n "What is your default IP router? [199.185.137.128] "
- getresp "199.185.137.128"
- myrouter=${resp}
- $DONTDOIT route add default ${myrouter}
- ftp -V -a ftp://cvs.openbsd.org/pub/OpenBSD/ftplist | cat
- echo -n "What is the remote machine to fetch from? [ftp3.usa.openbsd.org] "
- getresp "ftp3.usa.openbsd.org"
- tohost=${resp}
- #ping -c 1 ${resp}
- echo -n "What is the path to fetch from? [pub/OpenBSD/snapshots/i386] "
- getresp "pub/OpenBSD/snapshots/i386"
- # XXX add proxy support?
- topath="${resp}"
- ;;
-
-msdos|ext2fs|cd9660)
- echo -n "which disk? [$drivename] "
- getresp "$drivename"
- $DONTDOIT disklabel "${resp}"
- drive=${resp}
- echo -n "which partition? [c] "
- getresp c
- part=${drive}${resp}
- $DONTDOIT mount -t $method /dev/$part /mnt2
- echo "We pray this has not bailed, ok?"
- echo -n "enter path on the device? [/] "
- getresp "/"
- fetch="cat /mnt2/${resp}"
- ;;
-local)
- echo -n "enter path on the device? [/] "
- getresp "/"
- fetch="cat /${resp}"
- ;;
-esac
-
-case "$method" in
-nfs)
- echo "XXX"
- echo "XXX should do the NFS mount here"
- echo "XXX"
- fetch="echo"
- ;;
-ftp)
- fetch="ftp -a ftp://${tohost}/${topath}"
- ;;
-http)
- fetch="ftp -a http://${tohost}/${topath}"
- ;;
-
-esac
-
-cd /mnt
-for i in bsd; do
- $DONTDOIT eval ${fetch}/${i} > $i
-done
-for i in bin.tar.gz dev.tar.gz etc.tar.gz sbin.tar.gz usr.bin.tar.gz \
- usr.games.tar.gz usr.include.tar.gz usr.lib.tar.gz usr.libexec.tar.gz \
- usr.misc.tar.gz usr.sbin.tar.gz usr.share.tar.gz var.tar.gz; do
- $DONTDOIT eval ${fetch}/${i} | tar xvfzp -
-done
-cd /
-
-Configure
-echo ""
-echo "Your hard drive is still mounted. Be sure to halt or reboot the"
-echo "machine instead of simply turning it off."
+ disklabel -W ${_disk}
+ disklabel ${_disk} >/tmp/label.$$
+ disklabel -r -R ${_disk} /tmp/label.$$
+ rm -f /tmp/label.$$
+ disklabel -e ${_disk}
+}
+
+md_copy_kernel() {
+ echo -n "Copying kernel..."
+ cp -p /bsd /mnt/bsd
+ echo "done."
+}
+
+md_welcome_banner() {
+{
+ if [ "$MODE" = "install" ]; then
+ echo ""
+ echo "Welcome to the OpenBSD/i386 ${VERSION} installation program."
+ cat << \__welcome_banner_1
+
+This program is designed to help you put OpenBSD on your disk,
+in a simple and rational way. You'll be asked several questions,
+and it would probably be useful to have your disk's hardware
+manual, the installation notes, and a calculator handy.
+__welcome_banner_1
+
+ else
+ echo ""
+ echo "Welcome to the OpenBSD/i386 ${VERSION} upgrade program."
+ cat << \__welcome_banner_2
+
+This program is designed to help you upgrade your OpenBSD system in a
+simple and rational way.
+
+As a reminder, installing the `etc' binary set is NOT recommended.
+Once the rest of your system has been upgraded, you should manually
+merge any changes to files in the `etc' set into those files which
+already exist on your system.
+__welcome_banner_2
+ fi
+
+cat << \__welcome_banner_3
+
+As with anything which modifies your disk's contents, this
+program can cause SIGNIFICANT data loss, and you are advised
+to make sure your data is backed up before beginning the
+installation process.
+
+Default answers are displayed in brackets after the questions.
+You can hit Control-C at any time to quit, but if you do so at a
+prompt, you may have to hit return. Also, quitting in the middle of
+installation may leave your system in an inconsistent state.
+
+__welcome_banner_3
+} | more
+}
+
+md_not_going_to_install() {
+ cat << \__not_going_to_install_1
+
+OK, then. Enter `halt' at the prompt to halt the machine. Once the
+machine has halted, power-cycle the system to load new boot code.
+
+__not_going_to_install_1
+}
+
+md_congrats() {
+ local what;
+ if [ "$MODE" = "install" ]; then
+ what="installed";
+ else
+ what="upgraded";
+ fi
+ cat << __congratulations_1
+
+CONGRATULATIONS! You have successfully $what OpenBSD!
+To boot the installed system, enter halt at the command prompt. Once the
+system has halted, reset the machine and boot from the disk.
+
+__congratulations_1
+}
diff --git a/distrib/i386/floppies/ramdisk/list b/distrib/i386/floppies/ramdisk/list
index 05e8d087bba..13a1b1f3d19 100644
--- a/distrib/i386/floppies/ramdisk/list
+++ b/distrib/i386/floppies/ramdisk/list
@@ -1,4 +1,4 @@
-# $OpenBSD: list,v 1.3 1997/04/22 00:35:10 deraadt Exp $
+# $OpenBSD: list,v 1.4 1997/05/03 07:50:16 tholo Exp $
# the disktab explanation file
COPY disktab.preinstall etc/disktab.preinstall
@@ -6,7 +6,9 @@ COPY disktab.preinstall etc/disktab.preinstall
# and the installation tools
COPY dot.profile .profile
COPY dot.instutils .instutils
-COPY install.md install
-COPY dot.hdprofile tmp/.hdprofile
COPY resolv.conf etc/resolv.conf
+COPY install.md install.md
+COPY ${CURDIR}/../../../miniroot/install.sh install
+COPY ${CURDIR}/../../../miniroot/upgrade.sh upgrade
+SPECIAL sed "/^VERSION=/s/=.*/=${REV}/" < ${CURDIR}/../../../miniroot/install.sub > install.sub
SPECIAL chmod 755 install