Fix logic error in setpartition function

Reviewed by: John Kennedy <john.kennedy@delphix.com>
Reviewed-by: Giuseppe Di Natale <guss80@gmail.com>
Reviewed-by: Tony Hutter <hutter2@llnl.gov>
Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov>
Signed-off-by: Richard Elling <Richard.Elling@RichardElling.com>
Closes #8839
This commit is contained in:
Richard Elling 2019-06-05 16:13:57 -07:00 committed by Tony Hutter
parent 6f7bc75825
commit c350e62309
1 changed files with 13 additions and 9 deletions

View File

@ -861,7 +861,8 @@ function zero_partitions #<whole_disk_name>
# best to retire this interface and replace it with something more flexible. # best to retire this interface and replace it with something more flexible.
# At the moment a best effort is made. # At the moment a best effort is made.
# #
function set_partition #<slice_num> <slice_start> <size_plus_units> <whole_disk_name> # arguments: <slice_num> <slice_start> <size_plus_units> <whole_disk_name>
function set_partition
{ {
typeset -i slicenum=$1 typeset -i slicenum=$1
typeset start=$2 typeset start=$2
@ -872,6 +873,7 @@ function set_partition #<slice_num> <slice_start> <size_plus_units> <whole_disk
if [[ -z $size || -z $disk ]]; then if [[ -z $size || -z $disk ]]; then
log_fail "The size or disk name is unspecified." log_fail "The size or disk name is unspecified."
fi fi
[[ -n $DEV_DSKDIR ]] && disk=$DEV_DSKDIR/$disk
typeset size_mb=${size%%[mMgG]} typeset size_mb=${size%%[mMgG]}
size_mb=${size_mb%%[mMgG][bB]} size_mb=${size_mb%%[mMgG][bB]}
@ -881,10 +883,10 @@ function set_partition #<slice_num> <slice_start> <size_plus_units> <whole_disk
# Create GPT partition table when setting slice 0 or # Create GPT partition table when setting slice 0 or
# when the device doesn't already contain a GPT label. # when the device doesn't already contain a GPT label.
parted $DEV_DSKDIR/$disk -s -- print 1 >/dev/null parted $disk -s -- print 1 >/dev/null
typeset ret_val=$? typeset ret_val=$?
if [[ $slicenum -eq 0 || $ret_val -ne 0 ]]; then if [[ $slicenum -eq 0 || $ret_val -ne 0 ]]; then
parted $DEV_DSKDIR/$disk -s -- mklabel gpt parted $disk -s -- mklabel gpt
if [[ $? -ne 0 ]]; then if [[ $? -ne 0 ]]; then
log_note "Failed to create GPT partition table on $disk" log_note "Failed to create GPT partition table on $disk"
return 1 return 1
@ -899,20 +901,21 @@ function set_partition #<slice_num> <slice_start> <size_plus_units> <whole_disk
# Determine the cylinder size for the device and using # Determine the cylinder size for the device and using
# that calculate the end offset in cylinders. # that calculate the end offset in cylinders.
typeset -i cly_size_kb=0 typeset -i cly_size_kb=0
cly_size_kb=$(parted -m $DEV_DSKDIR/$disk -s -- \ cly_size_kb=$(parted -m $disk -s -- \
unit cyl print | head -3 | tail -1 | \ unit cyl print | head -3 | tail -1 | \
awk -F '[:k.]' '{print $4}') awk -F '[:k.]' '{print $4}')
((end = (size_mb * 1024 / cly_size_kb) + start)) ((end = (size_mb * 1024 / cly_size_kb) + start))
parted $DEV_DSKDIR/$disk -s -- \ parted $disk -s -- \
mkpart part$slicenum ${start}cyl ${end}cyl mkpart part$slicenum ${start}cyl ${end}cyl
if [[ $? -ne 0 ]]; then typeset ret_val=$?
if [[ $ret_val -ne 0 ]]; then
log_note "Failed to create partition $slicenum on $disk" log_note "Failed to create partition $slicenum on $disk"
return 1 return 1
fi fi
blockdev --rereadpt $DEV_DSKDIR/$disk 2>/dev/null blockdev --rereadpt $disk 2>/dev/null
block_device_wait block_device_wait $disk
else else
if [[ -z $slicenum || -z $size || -z $disk ]]; then if [[ -z $slicenum || -z $size || -z $disk ]]; then
log_fail "The slice, size or disk name is unspecified." log_fail "The slice, size or disk name is unspecified."
@ -932,9 +935,10 @@ function set_partition #<slice_num> <slice_start> <size_plus_units> <whole_disk
echo "q" >> $format_file echo "q" >> $format_file
format -e -s -d $disk -f $format_file format -e -s -d $disk -f $format_file
typeset ret_val=$?
rm -f $format_file
fi fi
typeset ret_val=$?
rm -f $format_file rm -f $format_file
if [[ $ret_val -ne 0 ]]; then if [[ $ret_val -ne 0 ]]; then
log_note "Unable to format $disk slice $slicenum to $size" log_note "Unable to format $disk slice $slicenum to $size"