Only write rd.luks.uuid if dracut is present and leave other initramfs generators clean (#266)

* add rd.luks.uuid to GRUB_CMDLINE (fixes unbootable system with dracut --nohostonly, and doesn't affect any other initramfs generators)

* typo

* only write rd.luks.uuid line if dracut is present, and leave other initramfs generators alone :D

* add missing = operator
This commit is contained in:
V3n3RiX 2016-10-19 16:41:35 +01:00 committed by Teo Mrnjavac
parent 7d46109cc2
commit 0bde162a9c

View File

@ -34,6 +34,7 @@ def modify_grub_default(partitions, root_mount_point, distributor):
default_dir = os.path.join(root_mount_point, "etc/default") default_dir = os.path.join(root_mount_point, "etc/default")
default_grub = os.path.join(default_dir, "grub") default_grub = os.path.join(default_dir, "grub")
distributor_replace = distributor.replace("'", "'\\''") distributor_replace = distributor.replace("'", "'\\''")
dracut_bin = libcalamares.utils.target_env_call(["sh", "-c", "which dracut"])
use_splash = "" use_splash = ""
swap_uuid = "" swap_uuid = ""
@ -43,17 +44,23 @@ def modify_grub_default(partitions, root_mount_point, distributor):
cryptdevice_params = [] cryptdevice_params = []
for partition in partitions: if dracut_bin == 0:
if partition["fs"] == "linuxswap": for partition in partitions:
swap_uuid = partition["uuid"] if partition["fs"] == "linuxswap":
swap_uuid = partition["uuid"]
if partition["mountPoint"] == "/" and "luksMapperName" in partition: if partition["mountPoint"] == "/" and "luksMapperName" in partition:
cryptdevice_params = [ cryptdevice_params = ["rd.luks.uuid={!s}".format(partition["luksUuid"])]
"cryptdevice=UUID={!s}:{!s}".format(partition["luksUuid"], else:
partition["luksMapperName"]), for partition in partitions:
"root=/dev/mapper/{!s}".format(partition["luksMapperName"]), if partition["fs"] == "linuxswap":
# Fix for unbootable system with dracut --nohostonly swap_uuid = partition["uuid"]
"rd.luks.uuid={!s}".format(partition["luksUuid"])
if partition["mountPoint"] == "/" and "luksMapperName" in partition:
cryptdevice_params = [
"cryptdevice=UUID={!s}:{!s}".format(partition["luksUuid"],
partition["luksMapperName"]),
"root=/dev/mapper/{!s}".format(partition["luksMapperName"])
] ]
kernel_params = ["quiet"] kernel_params = ["quiet"]