Fix nvme auto_partition()

This commit is contained in:
Smoke King 2018-08-21 17:28:19 +00:00 committed by natemaia
parent 63fac78577
commit 6acc34d429

View File

@ -15,7 +15,7 @@
# immutable variables { # immutable variables {
readonly DIST="Archlabs" # Linux distributor readonly DIST="Archlabs" # Linux distributor
readonly VER="1.6.36" # Installer version readonly VER="1.6.37" # Installer version
readonly LIVE="liveuser" # Live session user readonly LIVE="liveuser" # Live session user
readonly TRN="/usr/share/archlabs-installer" # Translation path readonly TRN="/usr/share/archlabs-installer" # Translation path
readonly MNT="/mnt/install" # Install mountpoint readonly MNT="/mnt/install" # Install mountpoint
@ -881,9 +881,10 @@ auto_partition() {
# confirm or bail # confirm or bail
yesno "$_PrepParts" "$_PartBody1 $device $_PartBody2" || return 0 yesno "$_PrepParts" "$_PartBody1 $device $_PartBody2" || return 0
infobox "$_PrepParts" "\nAuto partitioning device: $device\n" infobox "$_PrepParts" "\nAuto partitioning device: $device\n"
swapoff -a # make sure swap is disabled
# partition number of each partition on the device in reverse order swapoff -a # make sure swap is disabled in case the device was used for swap
# walk the partitions on the device in reverse order and delete them
local dev_info="$(parted -s $device print)" local dev_info="$(parted -s $device print)"
for i in $(awk '/^ [1-9][0-9]?/ {print $1}' <<< "$dev_info" | sort -r); do for i in $(awk '/^ [1-9][0-9]?/ {print $1}' <<< "$dev_info" | sort -r); do
parted -s $device rm $i 2>$ERR parted -s $device rm $i 2>$ERR
@ -892,11 +893,8 @@ auto_partition() {
# make sure we have the correct device table for the system type, gpt or msdos # make sure we have the correct device table for the system type, gpt or msdos
local table="$(awk '/Table:/ {print $3}' <<< "$dev_info")" local table="$(awk '/Table:/ {print $3}' <<< "$dev_info")"
if [[ $SYS == BIOS ]]; then local newtable="gpt"
local newtable="msdos" [[ $SYS == BIOS ]] && newtable="msdos"
else
local newtable="gpt"
fi
# if the current device table isn't correct run mklabel # if the current device table isn't correct run mklabel
if [[ $table != "$newtable" ]]; then if [[ $table != "$newtable" ]]; then
@ -904,40 +902,43 @@ auto_partition() {
check_for_errors "parted -s $device mklabel $newtable" || return 1 check_for_errors "parted -s $device mklabel $newtable" || return 1
fi fi
# when device contains the string 'nvme' then add 'p' before the part number
local nvme=""
[[ $device =~ nvme ]] && nvme="p"
local part_num=1 local part_num=1
BOOT_PART="${device}$part_num" BOOT_PART="$device${nvme}$part_num" # set the boot partition label to the first partition
if [[ $SYS == "BIOS" ]]; then if [[ $SYS == "BIOS" ]]; then
parted -s $device mkpart primary ext4 1MiB 513MiB 2>$ERR parted -s $device mkpart primary ext4 1MiB 513MiB 2>$ERR
check_for_errors "parted -s $device mkpart primary ext4 1MiB 513MiB" || { BOOT_PART=""; return 1; } check_for_errors "parted -s $device mkpart primary ext4 1MiB 513MiB" || return 1
mkfs.ext4 -q $BOOT_PART >/dev/null 2>$ERR mkfs.ext4 -q $BOOT_PART >/dev/null 2>$ERR
check_for_errors "mkfs.ext4 -q $BOOT_PART" || { BOOT_PART=""; return 1; } check_for_errors "mkfs.ext4 -q $BOOT_PART" || return 1
else else
parted -s $device mkpart ESP fat32 1MiB 513MiB 2>$ERR parted -s $device mkpart ESP fat32 1MiB 513MiB 2>$ERR
check_for_errors "parted -s $device mkpart ESP fat32 1MiB 513MiB" || { BOOT_PART=""; return 1; } check_for_errors "parted -s $device mkpart ESP fat32 1MiB 513MiB" || return 1
mkfs.vfat -F32 $BOOT_PART >/dev/null 2>$ERR mkfs.vfat -F32 $BOOT_PART >/dev/null 2>$ERR
check_for_errors "mkfs.vfat -F32 $BOOT_PART" || { BOOT_PART=""; return 1; } check_for_errors "mkfs.vfat -F32 $BOOT_PART" || return 1
parted -s $device set 1 esp on 2>$ERR parted -s $device set $part_num esp on 2>$ERR
check_for_errors "parted -s $device set 1 esp on" || { BOOT_PART=""; return 1; } check_for_errors "parted -s $device set $part_num esp on" || return 1
fi fi
parted -s $device set 1 boot on 2>$ERR parted -s $device set $part_num boot on 2>$ERR
check_for_errors "parted -s $device set 1 boot on" || return 1 check_for_errors "parted -s $device set $part_num boot on" || return 1
BOOT_DEVICE="$device" # only grub on BIOS systems uses this (( part_num++ )) # increment the partition number
ROOT_PART="${device}$((part_num + 1))" BOOT_DEVICE="$device" # only grub on BIOS systems uses this
ROOT_PART="${device}${nvme}$part_num" # set root partition label to the second partition
parted -s $device mkpart primary ext4 514MiB 100% 2>$ERR parted -s $device mkpart primary ext4 514MiB 100% 2>$ERR
check_for_errors "parted -s $device mkpart primary ext4 514MiB 100%" || return 1 check_for_errors "parted -s $device mkpart primary ext4 514MiB 100%" || return 1
mkfs.ext4 -q $ROOT_PART >/dev/null 2>$ERR mkfs.ext4 -q $ROOT_PART >/dev/null 2>$ERR
check_for_errors "mkfs.ext4 -q $ROOT_PART" || { ROOT_PART=""; return 1; } check_for_errors "mkfs.ext4 -q $ROOT_PART" || return 1
tput civis tput civis; sleep 0.5
sleep 0.5
echo -e "\nAuto partitioning complete.\n" > /tmp/.devlist echo -e "\nAuto partitioning complete.\n" > /tmp/.devlist
lsblk $device -o NAME,MODEL,TYPE,FSTYPE,SIZE >> /tmp/.devlist lsblk $device -o NAME,MODEL,TYPE,FSTYPE,SIZE >> /tmp/.devlist
dialog --cr-wrap --backtitle "$BT" --title " $_PrepParts " --textbox /tmp/.devlist 0 0 dialog --cr-wrap --backtitle "$BT" --title " $_PrepParts " --textbox /tmp/.devlist 0 0
return 0 return 0
} }