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:
parent
6f7bc75825
commit
c350e62309
|
@ -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"
|
||||||
|
|
Loading…
Reference in New Issue