Backports: Implement bpool datasets, with Debian required GRUB change

This commit is contained in:
Saverio Miroddi 2021-06-14 18:35:49 +02:00
parent 89298495fe
commit 8950eeedab

View File

@ -1178,7 +1178,7 @@ function create_pools_and_datasets {
"$v_rpool_name" "${v_pools_raid_type[@]}" "${rpool_disks_partitions[@]}" \ "$v_rpool_name" "${v_pools_raid_type[@]}" "${rpool_disks_partitions[@]}" \
< "$c_passphrase_named_pipe" < "$c_passphrase_named_pipe"
# DATASETS CREATION ################## # RPOOL DATASETS CREATION ############
local interpolated_dataset_create_options local interpolated_dataset_create_options
interpolated_dataset_create_options=$(eval echo \""$v_dataset_create_options"\") interpolated_dataset_create_options=$(eval echo \""$v_dataset_create_options"\")
@ -1209,15 +1209,19 @@ function create_pools_and_datasets {
# In case of changes, don't forget that the destination layout may be empty, at this point, due to # In case of changes, don't forget that the destination layout may be empty, at this point, due to
# the user's ZFS filesystems configuration! # the user's ZFS filesystems configuration!
# BOOT POOL CREATION ################# # BOOT POOL/DATASETS CREATION ########
# We can't create the datasets with the old procedure; on boot, the `bpool` dataset is attempted to be mounted. # Creating the datasets is not necessary, however, it avoids the annoying GRUB warning when updating
# Possibly, this can be fixed in configure_boot_pool_import()->ExecStart. # (`cannot open 'bpool/BOOT/ROOT': dataset does not exist`).
zpool create \ zpool create \
-o cachefile=/etc/zfs/zpool.cache \
"${v_bpool_create_options[@]}" \ "${v_bpool_create_options[@]}" \
-O mountpoint=/boot -R "$c_zfs_mount_dir" -f \ -O mountpoint=/boot -O canmount=off -R "$c_zfs_mount_dir" -f \
"$c_bpool_name" "${v_pools_raid_type[@]}" "${bpool_disks_partitions[@]}" "$c_bpool_name" "${v_pools_raid_type[@]}" "${bpool_disks_partitions[@]}"
zfs create -o canmount=off "$c_bpool_name/BOOT"
zfs create -o mountpoint=/boot "$c_bpool_name/BOOT/ROOT"
} }
function create_swap_volume { function create_swap_volume {
@ -1428,6 +1432,12 @@ function configure_and_update_grub {
chroot_execute "update-grub" chroot_execute "update-grub"
} }
function configure_and_update_grub_Debian {
chroot_execute "perl -i -pe 's|GRUB_CMDLINE_LINUX=\"\K|bootfs=$c_bpool_name/BOOT/ROOT |' /etc/default/grub"
configure_and_update_grub
}
function sync_efi_partitions { function sync_efi_partitions {
for ((i = 1; i < ${#v_selected_disks[@]}; i++)); do for ((i = 1; i < ${#v_selected_disks[@]}; i++)); do
local synced_efi_partition_path="/boot/efi$((i + 1))" local synced_efi_partition_path="/boot/efi$((i + 1))"