diff options
author | Kenneth R Westerback <krw@cvs.openbsd.org> | 2009-04-10 23:11:18 +0000 |
---|---|---|
committer | Kenneth R Westerback <krw@cvs.openbsd.org> | 2009-04-10 23:11:18 +0000 |
commit | 664b5db5ab97bf86e785bf264ffbb25ce4e39488 (patch) | |
tree | b4add2cf99648fb8a6bbcb784ad539ea86cff3b0 /distrib/macppc | |
parent | 02f596d16fd8670c56e195ef0393b82a09b3e9dc (diff) |
Where appropriate display the auto-allocation layout of the root
disk and ask if the installee wants to use it, edit it, or create
their own custom disklabel. Most one-disk installs will not need
to see fdisk or disklabel.
i386 and macppc by me, adapted for others by deraadt@.
ok deraadt@
Diffstat (limited to 'distrib/macppc')
-rw-r--r-- | distrib/macppc/ramdisk/install.md | 35 |
1 files changed, 25 insertions, 10 deletions
diff --git a/distrib/macppc/ramdisk/install.md b/distrib/macppc/ramdisk/install.md index 1c55eff41a5..d93f7b3a8eb 100644 --- a/distrib/macppc/ramdisk/install.md +++ b/distrib/macppc/ramdisk/install.md @@ -1,4 +1,4 @@ -# $OpenBSD: install.md,v 1.35 2009/01/15 17:53:57 todd Exp $ +# $OpenBSD: install.md,v 1.36 2009/04/10 23:11:17 krw Exp $ # # # Copyright (c) 1996 The NetBSD Foundation, Inc. @@ -138,13 +138,17 @@ __EOT } md_prep_disklabel() { - local _disk=$1 _q + local _disk=$1 _f _op md_prep_disk $_disk case $disklabeltype in - HFS) ;; - MBR) cat <<__EOT + HFS) return ;; + MBR) ;; + *) echo "$_disk has no HFS or MBR partition table." ; exit ;; + esac + + cat <<__EOT You *MUST* setup the OpenBSD disklabel to include the MSDOS-formatted boot partition as the 'i' partition. If the 'i' partition is missing or not the @@ -152,14 +156,25 @@ MSDOS-formatted boot partition, then the 'ofwboot' file required to boot OpenBSD cannot be installed. __EOT - ;; - *) echo "Disk label type ('$disklabeltype') is not 'HFS' or 'MBR'." - exit - ;; - esac disklabel -W $_disk >/dev/null 2>&1 - disklabel -c -f /tmp/fstab.$_disk -E $_disk + _f=/tmp/fstab.$_disk + if [[ $_disk == $ROOTDISK ]]; then + while :; do + echo "The auto-allocated layout for $_disk is:" + disklabel -f $_f -p g -A $_disk | egrep "^#|^ [a-p]:" + ask "Use (A)uto layout, (E)dit auto layout, or create (C)ustom layout?" a + case $resp in + a*|A*) _op=-w ; AUTOROOT=y ;; + e*|E*) _op=-E ;; + c*|C*) break ;; + *) continue ;; + esac + disklabel -f $_f $_op -A $_disk + return + done + fi + disklabel -f $_f -E $_disk } md_congrats() { |