diff options
author | jpaetzel <jpaetzel@FreeBSD.org> | 2011-04-21 06:25:12 +0000 |
---|---|---|
committer | jpaetzel <jpaetzel@FreeBSD.org> | 2011-04-21 06:25:12 +0000 |
commit | 582666352393e5b7a5a00ec55b4c3f44dbedc556 (patch) | |
tree | 1928c68175bbb582e55c99428e2b88df779b80e9 /usr.sbin/pc-sysinstall | |
parent | b6d230d6e1d79f2d8c4821ca274b3ac4ee7cc1eb (diff) | |
download | FreeBSD-src-582666352393e5b7a5a00ec55b4c3f44dbedc556.zip FreeBSD-src-582666352393e5b7a5a00ec55b4c3f44dbedc556.tar.gz |
- Allows using full device name paths, such as /dev/ad0 or /dev/mirror/gm0 in config files
- Fixes some issues creating gmirror devices, including on GPT partitions
- Bugfixes for ZFS mirroring
- Enhanced GELI to work with a passphrase only, or key-file only
- Bugfix to prevent crashing of PC-BSD Live media when checking for upgrade partitions
Submitted by: Kris Moore <kmoore@freebsd.org>
Approved by: kib (mentor)
Sponsored by: iXsystems
Diffstat (limited to 'usr.sbin/pc-sysinstall')
-rwxr-xr-x | usr.sbin/pc-sysinstall/backend-query/update-part-list.sh | 43 | ||||
-rwxr-xr-x | usr.sbin/pc-sysinstall/backend/functions-bsdlabel.sh | 37 | ||||
-rwxr-xr-x | usr.sbin/pc-sysinstall/backend/functions-cleanup.sh | 80 | ||||
-rwxr-xr-x | usr.sbin/pc-sysinstall/backend/functions-disk.sh | 91 | ||||
-rwxr-xr-x | usr.sbin/pc-sysinstall/backend/functions-mountdisk.sh | 48 | ||||
-rwxr-xr-x | usr.sbin/pc-sysinstall/backend/functions-newfs.sh | 71 | ||||
-rwxr-xr-x | usr.sbin/pc-sysinstall/backend/functions-unmount.sh | 53 | ||||
-rwxr-xr-x | usr.sbin/pc-sysinstall/backend/functions.sh | 1 |
8 files changed, 215 insertions, 209 deletions
diff --git a/usr.sbin/pc-sysinstall/backend-query/update-part-list.sh b/usr.sbin/pc-sysinstall/backend-query/update-part-list.sh index 54f28c6..298609b 100755 --- a/usr.sbin/pc-sysinstall/backend-query/update-part-list.sh +++ b/usr.sbin/pc-sysinstall/backend-query/update-part-list.sh @@ -37,16 +37,22 @@ FSMNT="/mnt" # Get the freebsd version on this partition get_fbsd_ver() { - - VER="`file ${FSMNT}/bin/sh | grep 'for FreeBSD' | sed 's|for FreeBSD |;|g' | cut -d ';' -f 2 | cut -d ',' -f 1`" - if [ "$?" = "0" ] ; then - file ${FSMNT}/bin/sh | grep '32-bit' >/dev/null 2>/dev/null - if [ "${?}" = "0" ] ; then - echo "${1}: FreeBSD ${VER} (32bit)" - else - echo "${1}: FreeBSD ${VER} (64bit)" + sFiles="/bin/sh /boot/kernel/kernel" + for file in $sFiles + do + if [ ! -e "${FSMNT}/$file" ] ; then continue ; fi + + VER="`file ${FSMNT}/$file | grep 'for FreeBSD' | sed 's|for FreeBSD |;|g' | cut -d ';' -f 2 | cut -d ',' -f 1`" + if [ "$?" = "0" ] ; then + file ${FSMNT}/$file | grep '32-bit' >/dev/null 2>/dev/null + if [ "${?}" = "0" ] ; then + echo "${1}: FreeBSD ${VER} (32bit)" + else + echo "${1}: FreeBSD ${VER} (64bit)" + fi fi - fi + break + done } @@ -86,25 +92,8 @@ do fi mount -o ro ${_dsk} ${FSMNT} >>${LOGOUT} 2>>${LOGOUT} - if [ "${?}" = "0" -a -e "${FSMNT}/bin/sh" ] ; then + if [ $? -eq 0 ] ; then get_fbsd_ver "`echo ${_dsk} | sed 's|/dev/||g'`" umount -f ${FSMNT} >/dev/null 2>/dev/null fi done - -# Now search for any ZFS root partitions -zpool import -o altroot=${FSMNT} -a - -# Unmount any auto-mounted stuff -umount_all_dir "${FSMNT}" - -# Get pools -_zps="`zpool list | grep -v 'NAME' | cut -d ' ' -f 1`" -for _zpools in ${_zps} -do - mount -o ro -t zfs ${_zpools} ${FSMNT} >>${LOGOUT} 2>>${LOGOUT} - if [ "${?}" = "0" -a -e "${FSMNT}/bin/sh" ] ; then - get_fbsd_ver "${_zpools}" - umount -f ${FSMNT} >/dev/null 2>/dev/null - fi -done diff --git a/usr.sbin/pc-sysinstall/backend/functions-bsdlabel.sh b/usr.sbin/pc-sysinstall/backend/functions-bsdlabel.sh index 2e413be..e819d74 100755 --- a/usr.sbin/pc-sysinstall/backend/functions-bsdlabel.sh +++ b/usr.sbin/pc-sysinstall/backend/functions-bsdlabel.sh @@ -101,7 +101,6 @@ setup_zfs_mirror_parts() if [ $? -eq 0 ] ; then echo "Setting up ZFS mirror disk $_zvars" >>${LOGOUT} init_gpt_full_disk "$_zvars" >/dev/null 2>/dev/null - rc_halt "gpart bootcode -p /boot/gptzfsboot -i 1 ${_zvars}" >/dev/null 2>/dev/null rc_halt "gpart add -t freebsd-zfs ${_zvars}" >/dev/null 2>/dev/null _nZFS="$_nZFS ${_zvars}p2" else @@ -319,7 +318,8 @@ setup_gpart_partitions() # Save this data to our partition config dir if [ "${_pType}" = "gpt" ] ; then - echo "${FS}:${MNT}:${ENC}:${PLABEL}:GPT:${XTRAOPTS}" >${PARTDIR}/${_pDisk}p${CURPART} + _dFile="`echo $_pDisk | sed 's|/|-|g'`" + echo "${FS}:${MNT}:${ENC}:${PLABEL}:GPT:${XTRAOPTS}" >${PARTDIR}/${_dFile}p${CURPART} # Clear out any headers sleep 2 @@ -327,18 +327,19 @@ setup_gpart_partitions() # If we have a enc password, save it as well if [ -n "${ENCPASS}" ] ; then - echo "${ENCPASS}" >${PARTDIR}-enc/${_pDisk}p${CURPART}-encpass + echo "${ENCPASS}" >${PARTDIR}-enc/${_dFile}p${CURPART}-encpass fi else # MBR Partition - echo "${FS}:${MNT}:${ENC}:${PLABEL}:MBR:${XTRAOPTS}:${IMAGE}" >${PARTDIR}/${_wSlice}${PARTLETTER} + _dFile="`echo $_wSlice | sed 's|/|-|g'`" + echo "${FS}:${MNT}:${ENC}:${PLABEL}:MBR:${XTRAOPTS}:${IMAGE}" >${PARTDIR}/${_dFile}${PARTLETTER} # Clear out any headers sleep 2 dd if=/dev/zero of=${_wSlice}${PARTLETTER} count=2048 2>/dev/null # If we have a enc password, save it as well if [ -n "${ENCPASS}" ] ; then - echo "${ENCPASS}" >${PARTDIR}-enc/${_wSlice}${PARTLETTER}-encpass + echo "${ENCPASS}" >${PARTDIR}-enc/${_dFile}${PARTLETTER}-encpass fi fi @@ -404,28 +405,28 @@ populate_disk_label() fi # Set some vars from the given working slice - disk="`echo $1 | cut -d '-' -f 1`" - slicenum="`echo $1 | cut -d '-' -f 2`" - type="`echo $1 | cut -d '-' -f 3`" + diskid="`echo $1 | cut -d ':' -f 1`" + disk="`echo $1 | cut -d ':' -f 1 | sed 's|-|/|g'`" + slicenum="`echo $1 | cut -d ':' -f 2`" + type="`echo $1 | cut -d ':' -f 3`" # Set WRKSLICE based upon format we are using if [ "$type" = "mbr" ] ; then - wrkslice="${disk}s${slicenum}" + wrkslice="${diskid}s${slicenum}" fi if [ "$type" = "gpt" ] ; then - wrkslice="${disk}p${slicenum}" + wrkslice="${diskid}p${slicenum}" fi - if [ -e "${SLICECFGDIR}/${wrkslice}" ] - then - disktag="`cat ${SLICECFGDIR}/${wrkslice}`" - else + if [ ! -e "${SLICECFGDIR}/${wrkslice}" ] ; then exit_err "ERROR: Missing SLICETAG data. This shouldn't happen - please let the developers know" fi - + disktag="`cat ${SLICECFGDIR}/${wrkslice}`" + slicedev="`echo $wrkslice | sed 's|-|/|g'`" + # Setup the partitions with gpart - setup_gpart_partitions "${disktag}" "${disk}" "${wrkslice}" "${slicenum}" "${type}" + setup_gpart_partitions "${disktag}" "${disk}" "${slicedev}" "${slicenum}" "${type}" }; @@ -444,10 +445,10 @@ setup_disk_label() disk="`echo $i | cut -d '-' -f 1`" pnum="`echo $i | cut -d '-' -f 2`" type="`echo $i | cut -d '-' -f 3`" - if [ "$type" = "mbr" -a ! -e "/dev/${disk}s${pnum}" ] ; then + if [ "$type" = "mbr" -a ! -e "${disk}s${pnum}" ] ; then exit_err "ERROR: The partition ${i} doesn't exist! gpart failure!" fi - if [ "$type" = "gpt" -a ! -e "/dev/${disk}p${pnum}" ] ; then + if [ "$type" = "gpt" -a ! -e "${disk}p${pnum}" ] ; then exit_err "ERROR: The partition ${i} doesn't exist! gpart failure!" fi done diff --git a/usr.sbin/pc-sysinstall/backend/functions-cleanup.sh b/usr.sbin/pc-sysinstall/backend/functions-cleanup.sh index ca06cb2..97386f8 100755 --- a/usr.sbin/pc-sysinstall/backend/functions-cleanup.sh +++ b/usr.sbin/pc-sysinstall/backend/functions-cleanup.sh @@ -33,9 +33,10 @@ zfs_cleanup_unmount() # Loop through our FS and see if we have any ZFS partitions to cleanup for PART in `ls ${PARTDIR}` do + PARTDEV=`echo $PART | sed 's|-|/|g'` PARTFS="`cat ${PARTDIR}/${PART} | cut -d ':' -f 1`" PARTMNT="`cat ${PARTDIR}/${PART} | cut -d ':' -f 2`" - ZPOOLNAME=$(get_zpool_name "${PART}") + ZPOOLNAME=$(get_zpool_name "${PARTDEV}") if [ "$PARTFS" = "ZFS" ] then @@ -82,13 +83,21 @@ zfs_cleanup_unmount() # Loop through our FS and see if we have any ZFS partitions to cleanup for PART in `ls ${PARTDIR}` do + PARTDEV=`echo $PART | sed 's|-|/|g'` PARTFS="`cat ${PARTDIR}/${PART} | cut -d ':' -f 1`" PARTMNT="`cat ${PARTDIR}/${PART} | cut -d ':' -f 2`" PARTENC="`cat ${PARTDIR}/${PART} | cut -d ':' -f 3`" - ZPOOLNAME=$(get_zpool_name "${PART}") + ZPOOLNAME=$(get_zpool_name "${PARTDEV}") if [ "$PARTFS" = "ZFS" ] then + + # Create a list of zpool names we can export + echo $ZPOOLEXPORTS | grep -q "$ZPOOLNAME " + if [ $? -ne 0 ] ; then + export ZPOOLEXPORTS="$ZPOOLNAME $ZPOOLEXPORTS" + fi + # Check if we have multiple zfs mounts specified for ZMNT in `echo ${PARTMNT} | sed 's|,| |g'` do @@ -122,8 +131,8 @@ setup_dedicated_boot_part() rc_halt "mkdir -p ${FSMNT}/${BOOTMNT}/boot" rc_halt "mv ${FSMNT}/boot/* ${FSMNT}${BOOTMNT}/boot/" rc_halt "mv ${FSMNT}${BOOTMNT}/boot ${FSMNT}/boot/" - rc_halt "umount /dev/${BOOTFS}" - rc_halt "mount /dev/${BOOTFS} ${FSMNT}${BOOTMNT}" + rc_halt "umount ${BOOTFS}" + rc_halt "mount ${BOOTFS} ${FSMNT}${BOOTMNT}" rc_halt "rmdir ${FSMNT}/boot" # Strip the '/' from BOOTMNT before making symlink @@ -144,22 +153,12 @@ setup_fstab() # Loop through the partitions, and start creating /etc/fstab for PART in `ls ${PARTDIR}` do + PARTDEV=`echo $PART | sed 's|-|/|g'` PARTFS="`cat ${PARTDIR}/${PART} | cut -d ':' -f 1`" PARTMNT="`cat ${PARTDIR}/${PART} | cut -d ':' -f 2`" PARTENC="`cat ${PARTDIR}/${PART} | cut -d ':' -f 3`" PARTLABEL="`cat ${PARTDIR}/${PART} | cut -d ':' -f 4`" - DRIVE="`echo ${PART} | rev | cut -b 4- | rev`" - # Check if this device is being mirrored - if [ -e "${MIRRORCFGDIR}/${DRIVE}" ] - then - # This device is apart of a gmirror, lets reset PART to correct value - MDRIVE="mirror/`cat ${MIRRORCFGDIR}/${DRIVE} | cut -d ':' -f 3`" - TMP="`echo ${PART} | rev | cut -b -3 | rev`" - PART="${MDRIVE}${TMP}" - PARTLABEL="" - fi - # Unset EXT EXT="" @@ -184,7 +183,7 @@ setup_fstab() if [ "${PARTFS}" = "UFS+J" ] ; then EXT="${EXT}.journal" fi - DEVICE="${PART}${EXT}" + DEVICE="${PARTDEV}${EXT}" fi @@ -193,7 +192,7 @@ setup_fstab() if [ $? -eq 0 ] ; then if [ "${PARTFS}" = "ZFS" ] ; then ROOTFSTYPE="zfs" - XPOOLNAME=$(get_zpool_name "${PART}") + XPOOLNAME=$(get_zpool_name "${PARTDEV}") ROOTFS="${ZPOOLNAME}" else ROOTFS="${DEVICE}" @@ -212,7 +211,7 @@ setup_fstab() # Save the BOOTFS for call at the end if [ "${PARTMNT}" = "/boot" ] ; then - BOOTFS="${PART}${EXT}" + BOOTFS="${PARTDEV}${EXT}" BOOTMNT="${BOOT_PART_MOUNT}" PARTMNT="${BOOTMNT}" fi @@ -245,28 +244,6 @@ setup_fstab() # Setup our disk mirroring with gmirror setup_gmirror() { - NUM="0" - - cd ${MIRRORCFGDIR} - for DISK in `ls *` - do - MIRRORDISK="`cat ${DISK} | cut -d ':' -f 1`" - MIRRORBAL="`cat ${DISK} | cut -d ':' -f 2`" - - # Create this mirror device - gmirror label -vb $MIRRORBAL gm${NUM} /dev/${DISK} - - sleep 3 - - # Save the gm<num> device in our config - echo "${MIRRORDISK}:${MIRRORBAL}:gm${NUM}" > ${DISK} - - sleep 3 - - NUM=$((NUM+1)) - done - - cat ${FSMNT}/boot/loader.conf 2>/dev/null | grep -q 'geom_mirror_load="YES"' 2>/dev/null if [ $? -ne 0 ] then @@ -283,24 +260,25 @@ setup_geli_loading() mkdir -p ${FSMNT}/boot/keys >/dev/null 2>/dev/null cd ${GELIKEYDIR} - for KEYFILE in `ls *` + for KEYFILE in `ls` do # Figure out the partition name based on keyfile name removing .key PART="`echo ${KEYFILE} | cut -d '.' -f 1`" + PARTDEV="`echo ${PART} | sed 's|-|/|g'`" + PARTNAME="`echo ${PART} | sed 's|-dev-||g'`" + + rc_halt "geli configure -b ${PARTDEV}" - # Add the entries to loader.conf to start this geli provider at boot - echo "geli_${PART}_keyfile0_load=\"YES\"" >> ${FSMNT}/boot/loader.conf - echo "geli_${PART}_keyfile0_type=\"${PART}:geli_keyfile0\"" >> ${FSMNT}/boot/loader.conf - echo "geli_${PART}_keyfile0_name=\"/boot/keys/${KEYFILE}\"" >> ${FSMNT}/boot/loader.conf + # If no passphrase, setup key files + if [ ! -e "${PARTDIR}-enc/${PART}-encpass" ] ; then + echo "geli_${PARTNAME}_keyfile0_load=\"YES\"" >> ${FSMNT}/boot/loader.conf + echo "geli_${PARTNAME}_keyfile0_type=\"${PARTNAME}:geli_keyfile0\"" >> ${FSMNT}/boot/loader.conf + echo "geli_${PARTNAME}_keyfile0_name=\"/boot/keys/${PARTNAME}.key\"" >> ${FSMNT}/boot/loader.conf - # If we have a passphrase, set it up now - if [ -e "${PARTDIR}-enc/${PART}-encpass" ] ; then - geli setkey -J ${PARTDIR}-enc/${PART}-encpass -n 0 -p -k ${KEYFILE} -K ${KEYFILE} ${PART} - geli configure -b ${PART} + # Copy the key to the disk + rc_halt "cp ${GELIKEYDIR}/${KEYFILE} ${FSMNT}/boot/keys/${PARTNAME}.key" fi - # Copy the key to the disk - cp ${KEYFILE} ${FSMNT}/boot/keys/${KEYFILE} done # Make sure we have geom_eli set to load at boot diff --git a/usr.sbin/pc-sysinstall/backend/functions-disk.sh b/usr.sbin/pc-sysinstall/backend/functions-disk.sh index faeab0d..94fb436 100755 --- a/usr.sbin/pc-sysinstall/backend/functions-disk.sh +++ b/usr.sbin/pc-sysinstall/backend/functions-disk.sh @@ -241,16 +241,15 @@ delete_all_gpart() local DISK="$1" # Check for any swaps to stop - for i in `gpart show ${DISK} 2>/dev/null | grep 'freebsd-swap' | tr -s ' ' | cut -d ' ' -f 4` + for i in `swapctl -l | grep "$DISK" | awk '{print $1}'` do - swapoff /dev/${DISK}s${i}b >/dev/null 2>/dev/null - swapoff /dev/${DISK}p${i} >/dev/null 2>/dev/null + swapoff ${i} >/dev/null 2>/dev/null done # Delete the gparts now for i in `gpart show ${DISK} 2>/dev/null | tr -s ' ' | cut -d ' ' -f 4` do - if [ "${i}" != "${DISK}" -a "${i}" != "-" ] ; then + if [ "/dev/${i}" != "${DISK}" -a "${i}" != "-" ] ; then rc_nohalt "gpart delete -i ${i} ${DISK}" fi done @@ -262,7 +261,7 @@ delete_all_gpart() clear_backup_gpt_table "${DISK}" # Wipe out front of disk - rc_nohalt "dd if=/dev/zero of=/dev/${DISK} count=3000" + rc_nohalt "dd if=/dev/zero of=${DISK} count=3000" }; @@ -279,7 +278,7 @@ stop_all_zfs() # Function which stops all gmirrors before doing any disk manipulation stop_all_gmirror() { - DISK="${1}" + local DISK="`echo ${1} | sed 's|/dev/||g'`" GPROV="`gmirror list | grep ". Name: mirror/" | cut -d '/' -f 2`" for gprov in $GPROV do @@ -296,7 +295,7 @@ stop_all_gmirror() # Make sure we don't have any geli providers active on this disk stop_all_geli() { - _geld="${1}" + local _geld="`echo ${1} | sed 's|/dev/||g'`" cd /dev for i in `ls ${_geld}*` @@ -321,8 +320,9 @@ setup_disk_slice() rm -rf ${MIRRORCFGDIR} >/dev/null 2>/dev/null mkdir ${MIRRORCFGDIR} - # Start with disk0 + # Start with disk0 and gm0 disknum="0" + gmnum="0" # Make sure all zpools are exported export_all_zpools @@ -338,10 +338,12 @@ setup_disk_slice() get_value_from_string "${line}" strip_white_space "$VAL" DISK="$VAL" + + echo "${DISK}" | grep -q '^/dev/' + if [ $? -ne 0 ] ; then DISK="/dev/$DISK" ; fi # Before we go further, lets confirm this disk really exists - if [ ! -e "/dev/${DISK}" ] - then + if [ ! -e "${DISK}" ] ; then exit_err "ERROR: The disk ${DISK} does not exist!" fi @@ -354,7 +356,7 @@ setup_disk_slice() # Make sure we don't have any zpools loaded stop_all_zfs - fi + fi # Lets look if this device will be mirrored on another disk echo $line | grep -q "^mirror=" 2>/dev/null @@ -365,9 +367,11 @@ setup_disk_slice() get_value_from_string "${line}" strip_white_space "$VAL" MIRRORDISK="$VAL" + echo "${MIRRORDISK}" | grep -q '^/dev/' + if [ $? -ne 0 ] ; then MIRRORDISK="/dev/$MIRRORDISK" ; fi # Before we go further, lets confirm this disk really exists - if [ ! -e "/dev/${MIRRORDISK}" ] + if [ ! -e "${MIRRORDISK}" ] then exit_err "ERROR: The mirror disk ${MIRRORDISK} does not exist!" fi @@ -458,8 +462,22 @@ setup_disk_slice() # Found our flag to commit this disk setup / lets do sanity check and do it if [ ! -z "${DISK}" -a ! -z "${PTYPE}" ] then + case ${PTYPE} in all) + # If we have a gmirror, lets set it up + if [ -n "$MIRRORDISK" ]; then + # Default to round-robin if the user didn't specify + if [ -z "$MIRRORBAL" ]; then MIRRORBAL="round-robin" ; fi + + echo "$MIRRORDISK:$MIRRORBAL:gm${gmnum}" >${MIRRORCFGDIR}/$DISK + init_gmirror "$gmnum" "$MIRRORBAL" "$DISK" "$MIRRORDISK" + + # Reset DISK to the gmirror device + DISK="/dev/mirror/gm${gmnum}" + gmnum=$((gmknum+1)) + fi + if [ "$PSCHEME" = "MBR" -o -z "$PSCHEME" ] ; then PSCHEME="MBR" tmpSLICE="${DISK}s1" @@ -511,18 +529,8 @@ setup_disk_slice() # Now save which disk<num> this is, so we can parse it later during slice partition setup if [ -z "${IMAGE}" ] then - echo "disk${disknum}" >${SLICECFGDIR}/$tmpSLICE - fi - - # Save any mirror config - if [ -n "$MIRRORDISK" ] - then - # Default to round-robin if the user didn't specify - if [ -z "$MIRRORBAL" ] - then - MIRRORBAL="round-robin" - fi - echo "$MIRRORDISK:$MIRRORBAL" >${MIRRORCFGDIR}/$DISK + _sFile=`echo $tmpSLICE | sed 's|/|-|g'` + echo "disk${disknum}" >${SLICECFGDIR}/$_sFile fi # Increment our disk counter to look for next disk and unset @@ -537,10 +545,25 @@ setup_disk_slice() }; + +# Init the gmirror device +init_gmirror() +{ + local _mNum=$1 + local _mBal=$2 + local _mDisk=$3 + + # Create this mirror device + rc_halt "gmirror label -vb ${_mBal} gm${_mNum} /dev/${_mDisk}" + + sleep 3 + +} + # Stop all gjournals on disk / slice stop_gjournal() { - _gdsk="$1" + _gdsk="`echo $1 | sed 's|/dev/||g'`" # Check if we need to shutdown any journals on this drive ls /dev/${_gdsk}*.journal >/dev/null 2>/dev/null if [ $? -eq 0 ] @@ -634,8 +657,8 @@ init_mbr_full_disk() sec="${VAL}" # Multiply them all together to get our total blocks - totalblocks="`expr ${cyl} \* ${head}`" - totalblocks="`expr ${totalblocks} \* ${sec}`" + totalblocks="`expr ${cyl} \* ${head} 2>/dev/null`" + totalblocks="`expr ${totalblocks} \* ${sec} 2>/dev/null`" if [ -z "${totalblocks}" ] then totalblocks=`gpart show "${_intDISK}"|tail -2|head -1|awk '{ print $2 }'` @@ -650,7 +673,7 @@ init_mbr_full_disk() sleep 2 echo_log "Cleaning up ${_intDISK}s1" - rc_halt "dd if=/dev/zero of=/dev/${_intDISK}s1 count=1024" + rc_halt "dd if=/dev/zero of=${_intDISK}s1 count=1024" if [ "$_intBOOT" = "bsd" ] ; then echo_log "Stamping boot0 on ${_intDISK}" @@ -671,10 +694,10 @@ run_gpart_full() if [ "$SCHEME" = "MBR" ] ; then init_mbr_full_disk "$DISK" "$BOOT" - slice="${DISK}-1-mbr" + slice=`echo "${DISK}:1:mbr" | sed 's|/|-|g'` else init_gpt_full_disk "$DISK" - slice="${DISK}-1-gpt" + slice=`echo "${DISK}:1:gpt" | sed 's|/|-|g'` fi # Lets save our slice, so we know what to look for in the config file later on @@ -723,7 +746,7 @@ run_gpart_slice() # Clean up old partition echo_log "Cleaning up $slice" - rc_halt "dd if=/dev/zero of=/dev/${DISK}s${slicenum} count=1024" + rc_halt "dd if=/dev/zero of=${DISK}s${slicenum} count=1024" sleep 1 @@ -734,7 +757,7 @@ run_gpart_slice() fi # Set the slice to the format we'll be using for gpart later - slice="${1}-${3}-mbr" + slice=`echo "${1}:${3}:mbr" | sed 's|/|-|g'` # Lets save our slice, so we know what to look for in the config file later on if [ -z "$WORKINGSLICES" ] @@ -811,7 +834,7 @@ run_gpart_free() sleep 2 echo_log "Cleaning up $slice" - rc_halt "dd if=/dev/zero of=/dev/${slice} count=1024" + rc_halt "dd if=/dev/zero of=${slice} count=1024" sleep 1 @@ -821,7 +844,7 @@ run_gpart_free() rc_halt "gpart bootcode -b /boot/boot0 ${DISK}" fi - slice="${DISK}-${SLICENUM}-mbr" + slice=`echo "${DISK}:${SLICENUM}:mbr" | sed 's|/|-|g'` # Lets save our slice, so we know what to look for in the config file later on if [ -z "$WORKINGSLICES" ] then diff --git a/usr.sbin/pc-sysinstall/backend/functions-mountdisk.sh b/usr.sbin/pc-sysinstall/backend/functions-mountdisk.sh index 5aa7a2b..9ca9df6 100755 --- a/usr.sbin/pc-sysinstall/backend/functions-mountdisk.sh +++ b/usr.sbin/pc-sysinstall/backend/functions-mountdisk.sh @@ -84,9 +84,9 @@ mount_partition() mkdir -p ${FSMNT}${MNTPOINT} >>${LOGOUT} 2>>${LOGOUT} fi - echo_log "mount ${MNTFLAGS} /dev/${PART} -> ${FSMNT}${MNTPOINT}" + echo_log "mount ${MNTFLAGS} ${PART} -> ${FSMNT}${MNTPOINT}" sleep 2 - rc_halt "mount ${MNTFLAGS} /dev/${PART} ${FSMNT}${MNTPOINT}" + rc_halt "mount ${MNTFLAGS} ${PART} ${FSMNT}${MNTPOINT}" fi }; @@ -101,9 +101,10 @@ mount_all_filesystems() ######################################################### for PART in `ls ${PARTDIR}` do - if [ ! -e "/dev/${PART}" ] + PARTDEV=`echo $PART | sed 's|-|/|g'` + if [ ! -e "${PARTDEV}" ] then - exit_err "ERROR: The partition ${PART} does not exist. Failure in bsdlabel?" + exit_err "ERROR: The partition ${PARTDEV} does not exist. Failure in bsdlabel?" fi PARTFS="`cat ${PARTDIR}/${PART} | cut -d ':' -f 1`" @@ -122,12 +123,12 @@ mount_all_filesystems() if [ "$?" = "0" -o "$PARTMNT" = "/" ] then case ${PARTFS} in - UFS) mount_partition ${PART}${EXT} ${PARTFS} ${PARTMNT} "noatime" ;; - UFS+S) mount_partition ${PART}${EXT} ${PARTFS} ${PARTMNT} "noatime" ;; - UFS+SUJ) mount_partition ${PART}${EXT} ${PARTFS} ${PARTMNT} "noatime" ;; - UFS+J) mount_partition ${PART}${EXT}.journal ${PARTFS} ${PARTMNT} "async,noatime" ;; - ZFS) mount_partition ${PART} ${PARTFS} ${PARTMNT} ;; - IMAGE) mount_partition ${PART} ${PARTFS} ${PARTMNT} ;; + UFS) mount_partition ${PARTDEV}${EXT} ${PARTFS} ${PARTMNT} "noatime" ;; + UFS+S) mount_partition ${PARTDEV}${EXT} ${PARTFS} ${PARTMNT} "noatime" ;; + UFS+SUJ) mount_partition ${PARTDEV}${EXT} ${PARTFS} ${PARTMNT} "noatime" ;; + UFS+J) mount_partition ${PARTDEV}${EXT}.journal ${PARTFS} ${PARTMNT} "async,noatime" ;; + ZFS) mount_partition ${PARTDEV} ${PARTFS} ${PARTMNT} ;; + IMAGE) mount_partition ${PARTDEV} ${PARTFS} ${PARTMNT} ;; *) exit_err "ERROR: Got unknown file-system type $PARTFS" ;; esac fi @@ -137,9 +138,10 @@ mount_all_filesystems() ################################################################## for PART in `ls ${PARTDIR}` do - if [ ! -e "/dev/${PART}" ] + PARTDEV=`echo $PART | sed 's|-|/|g'` + if [ ! -e "${PARTDEV}" ] then - exit_err "ERROR: The partition ${PART} does not exist. Failure in bsdlabel?" + exit_err "ERROR: The partition ${PARTDEV} does not exist. Failure in bsdlabel?" fi PARTFS="`cat ${PARTDIR}/${PART} | cut -d ':' -f 1`" @@ -158,23 +160,23 @@ mount_all_filesystems() if [ "$?" != "0" -a "$PARTMNT" != "/" ] then case ${PARTFS} in - UFS) mount_partition ${PART}${EXT} ${PARTFS} ${PARTMNT} "noatime" ;; - UFS+S) mount_partition ${PART}${EXT} ${PARTFS} ${PARTMNT} "noatime" ;; - UFS+SUJ) mount_partition ${PART}${EXT} ${PARTFS} ${PARTMNT} "noatime" ;; - UFS+J) mount_partition ${PART}${EXT}.journal ${PARTFS} ${PARTMNT} "async,noatime" ;; - ZFS) mount_partition ${PART} ${PARTFS} ${PARTMNT} ;; + UFS) mount_partition ${PARTDEV}${EXT} ${PARTFS} ${PARTMNT} "noatime" ;; + UFS+S) mount_partition ${PARTDEV}${EXT} ${PARTFS} ${PARTMNT} "noatime" ;; + UFS+SUJ) mount_partition ${PARTDEV}${EXT} ${PARTFS} ${PARTMNT} "noatime" ;; + UFS+J) mount_partition ${PARTDEV}${EXT}.journal ${PARTFS} ${PARTMNT} "async,noatime" ;; + ZFS) mount_partition ${PARTDEV} ${PARTFS} ${PARTMNT} ;; SWAP) # Lets enable this swap now if [ "$PARTENC" = "ON" ] then - echo_log "Enabling encrypted swap on /dev/${PART}" - rc_halt "geli onetime -d -e 3des ${PART}" + echo_log "Enabling encrypted swap on ${PARTDEV}" + rc_halt "geli onetime -d -e 3des ${PARTDEV}" sleep 5 - rc_halt "swapon /dev/${PART}.eli" + rc_halt "swapon ${PARTDEV}.eli" else - echo_log "swapon ${PART}" + echo_log "swapon ${PARTDEV}" sleep 5 - rc_halt "swapon /dev/${PART}" + rc_halt "swapon ${PARTDEV}" fi ;; IMAGE) @@ -182,7 +184,7 @@ mount_all_filesystems() then mkdir -p "${PARTMNT}" fi - mount_partition ${PART} ${PARTFS} ${PARTMNT} + mount_partition ${PARTDEV} ${PARTFS} ${PARTMNT} ;; *) exit_err "ERROR: Got unknown file-system type $PARTFS" ;; esac diff --git a/usr.sbin/pc-sysinstall/backend/functions-newfs.sh b/usr.sbin/pc-sysinstall/backend/functions-newfs.sh index 1c2b023..96ca49b 100755 --- a/usr.sbin/pc-sysinstall/backend/functions-newfs.sh +++ b/usr.sbin/pc-sysinstall/backend/functions-newfs.sh @@ -68,8 +68,8 @@ setup_zfs_filesystem() echo_log "Setting up ZFS boot loader support" rc_halt "zpool set bootfs=${ZPOOLNAME} ${ZPOOLNAME}" rc_halt "zpool export ${ZPOOLNAME}" - rc_halt "dd if=/boot/zfsboot of=/dev/${ROOTSLICE} count=1" - rc_halt "dd if=/boot/zfsboot of=/dev/${PART}${EXT} skip=1 seek=1024" + rc_halt "dd if=/boot/zfsboot of=${ROOTSLICE} count=1" + rc_halt "dd if=/boot/zfsboot of=${PART}${EXT} skip=1 seek=1024" rc_halt "zpool import ${ZPOOLNAME}" fi fi @@ -89,9 +89,10 @@ setup_filesystems() # newfs on any of them for PART in `ls ${PARTDIR}` do - if [ ! -e "/dev/${PART}" ] + PARTDEV="`echo $PART | sed 's|-|/|g'`" + if [ ! -e "${PARTDEV}" ] then - exit_err "ERROR: The partition ${PART} does not exist. Failure in bsdlabel?" + exit_err "ERROR: The partition ${PARTDEV} does not exist. Failure in bsdlabel?" fi PARTFS="`cat ${PARTDIR}/${PART} | cut -d ':' -f 1`" @@ -103,19 +104,29 @@ setup_filesystems() PARTIMAGE="`cat ${PARTDIR}/${PART} | cut -d ':' -f 7`" # Make sure journaling isn't enabled on this device - if [ -e "/dev/${PART}.journal" ] + if [ -e "${PARTDEV}.journal" ] then - rc_nohalt "gjournal stop -f ${PART}.journal" - rc_nohalt "gjournal clear ${PART}" + rc_nohalt "gjournal stop -f ${PARTDEV}.journal" + rc_nohalt "gjournal clear ${PARTDEV}" fi # Setup encryption if necessary if [ "${PARTENC}" = "ON" -a "${PARTFS}" != "SWAP" ] then - echo_log "Creating geli provider for ${PART}" - rc_halt "dd if=/dev/random of=${GELIKEYDIR}/${PART}.key bs=64 count=1" - rc_halt "geli init -b -s 4096 -P -K ${GELIKEYDIR}/${PART}.key /dev/${PART}" - rc_halt "geli attach -p -k ${GELIKEYDIR}/${PART}.key /dev/${PART}" + echo_log "Creating geli provider for ${PARTDEV}" + + if [ -e "${PARTDIR}-enc/${PART}-encpass" ] ; then + # Using a passphrase + rc_halt "dd if=/dev/random of=${GELIKEYDIR}/${PART}.key bs=64 count=1" + rc_halt "geli init -J ${PARTDIR}-enc/${PART}-encpass ${PARTDEV}" + rc_halt "geli attach -j ${PARTDIR}-enc/${PART}-encpass ${PARTDEV}" + else + # No Encryption password, use key file + rc_halt "dd if=/dev/random of=${GELIKEYDIR}/${PART}.key bs=64 count=1" + rc_halt "geli init -b -s 4096 -P -K ${GELIKEYDIR}/${PART}.key ${PARTDEV}" + rc_halt "geli attach -p -k ${GELIKEYDIR}/${PART}.key ${PARTDEV}" + + fi EXT=".eli" else @@ -125,12 +136,12 @@ setup_filesystems() case ${PARTFS} in UFS) - echo_log "NEWFS: /dev/${PART} - ${PARTFS}" + echo_log "NEWFS: ${PARTDEV} - ${PARTFS}" sleep 2 - rc_halt "newfs /dev/${PART}${EXT}" + rc_halt "newfs ${PARTDEV}${EXT}" sleep 2 rc_halt "sync" - rc_halt "glabel label ${PARTLABEL} /dev/${PART}${EXT}" + rc_halt "glabel label ${PARTLABEL} ${PARTDEV}${EXT}" rc_halt "sync" # Set flag that we've found a boot partition @@ -141,12 +152,12 @@ setup_filesystems() ;; UFS+S) - echo_log "NEWFS: /dev/${PART} - ${PARTFS}" + echo_log "NEWFS: ${PARTDEV} - ${PARTFS}" sleep 2 - rc_halt "newfs -U /dev/${PART}${EXT}" + rc_halt "newfs -U ${PARTDEV}${EXT}" sleep 2 rc_halt "sync" - rc_halt "glabel label ${PARTLABEL} /dev/${PART}${EXT}" + rc_halt "glabel label ${PARTLABEL} ${PARTDEV}${EXT}" rc_halt "sync" # Set flag that we've found a boot partition if [ "$PARTMNT" = "/boot" -o "${PARTMNT}" = "/" ] ; then @@ -156,15 +167,15 @@ setup_filesystems() ;; UFS+SUJ) - echo_log "NEWFS: /dev/${PART} - ${PARTFS}" + echo_log "NEWFS: ${PARTDEV} - ${PARTFS}" sleep 2 - rc_halt "newfs -U /dev/${PART}${EXT}" + rc_halt "newfs -U ${PARTDEV}${EXT}" sleep 2 rc_halt "sync" - rc_halt "tunefs -j enable /dev/${PART}${EXT}" + rc_halt "tunefs -j enable ${PARTDEV}${EXT}" sleep 2 rc_halt "sync" - rc_halt "glabel label ${PARTLABEL} /dev/${PART}${EXT}" + rc_halt "glabel label ${PARTLABEL} ${PARTDEV}${EXT}" rc_halt "sync" # Set flag that we've found a boot partition if [ "$PARTMNT" = "/boot" -o "${PARTMNT}" = "/" ] ; then @@ -175,16 +186,16 @@ setup_filesystems() UFS+J) - echo_log "NEWFS: /dev/${PART} - ${PARTFS}" + echo_log "NEWFS: ${PARTDEV} - ${PARTFS}" sleep 2 - rc_halt "newfs /dev/${PART}${EXT}" + rc_halt "newfs ${PARTDEV}${EXT}" sleep 2 - rc_halt "gjournal label -f /dev/${PART}${EXT}" + rc_halt "gjournal label -f ${PARTDEV}${EXT}" sleep 2 - rc_halt "newfs -O 2 -J /dev/${PART}${EXT}.journal" + rc_halt "newfs -O 2 -J ${PARTDEV}${EXT}.journal" sleep 2 rc_halt "sync" - rc_halt "glabel label ${PARTLABEL} /dev/${PART}${EXT}.journal" + rc_halt "glabel label ${PARTLABEL} ${PARTDEV}${EXT}.journal" rc_halt "sync" # Set flag that we've found a boot partition if [ "$PARTMNT" = "/boot" -o "${PARTMNT}" = "/" ] ; then @@ -194,19 +205,19 @@ setup_filesystems() ;; ZFS) - echo_log "NEWFS: /dev/${PART} - ${PARTFS}" - setup_zfs_filesystem "${PART}" "${PARTFS}" "${PARTMNT}" "${EXT}" "${PARTGEOM}" "${PARTXTRAOPTS}" + echo_log "NEWFS: ${PARTDEV} - ${PARTFS}" + setup_zfs_filesystem "${PARTDEV}" "${PARTFS}" "${PARTMNT}" "${EXT}" "${PARTGEOM}" "${PARTXTRAOPTS}" ;; SWAP) rc_halt "sync" - rc_halt "glabel label ${PARTLABEL} /dev/${PART}${EXT}" + rc_halt "glabel label ${PARTLABEL} ${PARTDEV}${EXT}" rc_halt "sync" sleep 2 ;; IMAGE) - write_image "${PARTIMAGE}" "${PART}" + write_image "${PARTIMAGE}" "${PARTDEV}" sleep 2 ;; diff --git a/usr.sbin/pc-sysinstall/backend/functions-unmount.sh b/usr.sbin/pc-sysinstall/backend/functions-unmount.sh index 5e80985..ce0db9b 100755 --- a/usr.sbin/pc-sysinstall/backend/functions-unmount.sh +++ b/usr.sbin/pc-sysinstall/backend/functions-unmount.sh @@ -42,7 +42,7 @@ umount_all_dir() start_gmirror_sync() { - cd ${MIRRORCFGDIR} + cd ${MIRRORCFGDIR} for DISK in `ls *` do MIRRORDISK="`cat ${DISK} | cut -d ':' -f 1`" @@ -50,6 +50,7 @@ start_gmirror_sync() MIRRORNAME="`cat ${DISK} | cut -d ':' -f 3`" # Start the mirroring service + rc_nohalt "gmirror forget ${MIRRORNAME}" rc_halt "gmirror insert ${MIRRORNAME} /dev/${MIRRORDISK}" done @@ -70,7 +71,7 @@ unmount_all_filesystems() ################################################################## for PART in `ls ${PARTDIR}` do - + PARTDEV=`echo $PART | sed 's|-|/|g'` PARTFS="`cat ${PARTDIR}/${PART} | cut -d ':' -f 1`" PARTMNT="`cat ${PARTDIR}/${PART} | cut -d ':' -f 2`" PARTENC="`cat ${PARTDIR}/${PART} | cut -d ':' -f 3`" @@ -83,24 +84,24 @@ unmount_all_filesystems() EXT="" fi - #if [ "${PARTFS}" = "SWAP" ] - #then - # rc_nohalt "swapoff /dev/${PART}${EXT}" - #fi + if [ "${PARTFS}" = "SWAP" ] + then + rc_nohalt "swapoff ${PARTDEV}${EXT}" + fi # Check if we've found "/", and unmount that last if [ "$PARTMNT" != "/" -a "${PARTMNT}" != "none" -a "${PARTFS}" != "ZFS" ] then - rc_halt "umount -f /dev/${PART}${EXT}" + rc_halt "umount -f ${PARTDEV}${EXT}" # Re-check if we are missing a label for this device and create it again if so if [ ! -e "/dev/label/${PARTLABEL}" ] then case ${PARTFS} in - UFS) glabel label ${PARTLABEL} /dev/${PART}${EXT} ;; - UFS+S) glabel label ${PARTLABEL} /dev/${PART}${EXT} ;; - UFS+SUJ) glabel label ${PARTLABEL} /dev/${PART}${EXT} ;; - UFS+J) glabel label ${PARTLABEL} /dev/${PART}${EXT}.journal ;; + UFS) glabel label ${PARTLABEL} ${PARTDEV}${EXT} ;; + UFS+S) glabel label ${PARTLABEL} ${PARTDEV}${EXT} ;; + UFS+SUJ) glabel label ${PARTLABEL} ${PARTDEV}${EXT} ;; + UFS+J) glabel label ${PARTLABEL} ${PARTDEV}${EXT}.journal ;; *) ;; esac fi @@ -112,10 +113,10 @@ unmount_all_filesystems() if [ ! -e "/dev/label/${PARTLABEL}" ] then case ${PARTFS} in - UFS) ROOTRELABEL="glabel label ${PARTLABEL} /dev/${PART}${EXT}" ;; - UFS+S) ROOTRELABEL="glabel label ${PARTLABEL} /dev/${PART}${EXT}" ;; - UFS+SUJ) ROOTRELABEL="glabel label ${PARTLABEL} /dev/${PART}${EXT}" ;; - UFS+J) ROOTRELABEL="glabel label ${PARTLABEL} /dev/${PART}${EXT}.journal" ;; + UFS) ROOTRELABEL="glabel label ${PARTLABEL} ${PARTDEV}${EXT}" ;; + UFS+S) ROOTRELABEL="glabel label ${PARTLABEL} ${PARTDEV}${EXT}" ;; + UFS+SUJ) ROOTRELABEL="glabel label ${PARTLABEL} ${PARTDEV}${EXT}" ;; + UFS+J) ROOTRELABEL="glabel label ${PARTLABEL} ${PARTDEV}${EXT}.journal" ;; *) ;; esac fi @@ -166,25 +167,25 @@ unmount_all_filesystems_failure() then for PART in `ls ${PARTDIR}` do - + PARTDEV=`echo $PART | sed 's|-|/|g'` PARTFS="`cat ${PARTDIR}/${PART} | cut -d ':' -f 1`" PARTMNT="`cat ${PARTDIR}/${PART} | cut -d ':' -f 2`" PARTENC="`cat ${PARTDIR}/${PART} | cut -d ':' -f 3`" - #if [ "${PARTFS}" = "SWAP" ] - #then - # if [ "${PARTENC}" = "ON" ] - # then - # rc_nohalt "swapoff /dev/${PART}.eli" - # else - # rc_nohalt "swapoff /dev/${PART}" - # fi - #fi + if [ "${PARTFS}" = "SWAP" ] + then + if [ "${PARTENC}" = "ON" ] + then + rc_nohalt "swapoff ${PARTDEV}.eli" + else + rc_nohalt "swapoff ${PARTDEV}" + fi + fi # Check if we've found "/" again, don't need to mount it twice if [ "$PARTMNT" != "/" -a "${PARTMNT}" != "none" -a "${PARTFS}" != "ZFS" ] then - rc_nohalt "umount -f /dev/${PART}" + rc_nohalt "umount -f ${PARTDEV}" rc_nohalt "umount -f ${FSMNT}${PARTMNT}" fi done diff --git a/usr.sbin/pc-sysinstall/backend/functions.sh b/usr.sbin/pc-sysinstall/backend/functions.sh index 56ffa86..4987bf4 100755 --- a/usr.sbin/pc-sysinstall/backend/functions.sh +++ b/usr.sbin/pc-sysinstall/backend/functions.sh @@ -277,6 +277,7 @@ get_zpool_name() # Need to generate a zpool name for this device NUM=`ls ${TMPDIR}/.zpools/ | wc -l | sed 's| ||g'` NEWNAME="${BASENAME}${NUM}" + mkdir -p ${TMPDIR}/.zpools/`dirname $DEVICE` echo "$NEWNAME" >${TMPDIR}/.zpools/${DEVICE} echo "${NEWNAME}" return |