summaryrefslogtreecommitdiff
path: root/app-admin/calamares
diff options
context:
space:
mode:
authorV3n3RiX <venerix@redcorelinux.org>2017-06-02 13:48:20 +0100
committerV3n3RiX <venerix@redcorelinux.org>2017-06-02 13:48:20 +0100
commit8291928ec4539303bffd07ee96c87f7ce2a63a47 (patch)
treee8d6437c71589e405932ba62b8a8dc9aa14f0775 /app-admin/calamares
parent63fa236a7c452e9819a1e937e69847b2f8696a09 (diff)
fix broken luks, patch by frugalware
Diffstat (limited to 'app-admin/calamares')
-rw-r--r--app-admin/calamares/calamares-3.1.0.ebuild2
-rw-r--r--app-admin/calamares/files/calamares-3.1.0-luksfix.patch87
2 files changed, 89 insertions, 0 deletions
diff --git a/app-admin/calamares/calamares-3.1.0.ebuild b/app-admin/calamares/calamares-3.1.0.ebuild
index cd5d803e..615ec380 100644
--- a/app-admin/calamares/calamares-3.1.0.ebuild
+++ b/app-admin/calamares/calamares-3.1.0.ebuild
@@ -48,6 +48,8 @@ DEPEND="
RDEPEND=">=app-misc/calamares-runtime-1.0[branding]"
src_prepare() {
+ # luksfix (master) by frugalware, backported to stable
+ epatch "${FILESDIR}"/${P}-luksfix.patch
# replace calamares installer desktop icon
sed -i "s/Icon=calamares/Icon=redcore-logo/g" "${S}/calamares.desktop"
# fix installer doesn't start from desktop launcher (IMPROVE THIS UGLY THINGY)
diff --git a/app-admin/calamares/files/calamares-3.1.0-luksfix.patch b/app-admin/calamares/files/calamares-3.1.0-luksfix.patch
new file mode 100644
index 00000000..af9a79bf
--- /dev/null
+++ b/app-admin/calamares/files/calamares-3.1.0-luksfix.patch
@@ -0,0 +1,87 @@
+diff -Nur a/src/modules/bootloader/main.py b/src/modules/bootloader/main.py
+--- a/src/modules/bootloader/main.py 2017-02-17 15:21:02.000000000 +0000
++++ b/src/modules/bootloader/main.py 2017-06-02 13:38:49.275348324 +0100
+@@ -98,14 +98,15 @@
+ cryptdevice_params = []
+
+ for partition in partitions:
+- if partition["fs"] == "linuxswap":
++ if partition["fs"] == "linuxswap" and not "luksMapperName" in partition:
+ swap_uuid = partition["uuid"]
+
+ 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"])
++ "root=/dev/mapper/{!s}".format(partition["luksMapperName"]),
++ "resume=/dev/mapper/{!s}".format(partition["luksMapperName"])
+ ]
+
+ if cryptdevice_params:
+diff -Nur a/src/modules/fstab/main.py b/src/modules/fstab/main.py
+--- a/src/modules/fstab/main.py 2016-11-25 17:38:49.000000000 +0000
++++ b/src/modules/fstab/main.py 2017-06-02 13:28:53.792308347 +0100
+@@ -257,8 +257,23 @@
+ check=check,
+ )
+
++ if filesystem == "swap" and "luksMapperName" in partition:
++ return dict(device="/dev/mapper/" + partition["luksMapperName"],
++ mount_point=mount_point or "swap",
++ fs=filesystem,
++ options=options,
++ check=check,
++ )
++ else:
++ return dict(device="UUID=" + partition["uuid"],
++ mount_point=mount_point or "swap",
++ fs=filesystem,
++ options=options,
++ check=check,
++ )
++
+ return dict(device="UUID=" + partition["uuid"],
+- mount_point=mount_point or "swap",
++ mount_point=mount_point,
+ fs=filesystem,
+ options=options,
+ check=check,
+diff -Nur a/src/modules/grubcfg/main.py b/src/modules/grubcfg/main.py
+--- a/src/modules/grubcfg/main.py 2017-02-17 15:21:02.000000000 +0000
++++ b/src/modules/grubcfg/main.py 2017-06-02 13:36:55.032340654 +0100
+@@ -48,7 +48,7 @@
+
+ if dracut_bin == 0:
+ for partition in partitions:
+- if partition["fs"] == "linuxswap":
++ if partition["fs"] == "linuxswap" and not "luksMapperName" in partition:
+ swap_uuid = partition["uuid"]
+
+ if partition["fs"] == "linuxswap" and "luksMapperName" in partition:
+@@ -58,14 +58,15 @@
+ cryptdevice_params = ["rd.luks.uuid={!s}".format(partition["luksUuid"])]
+ else:
+ for partition in partitions:
+- if partition["fs"] == "linuxswap":
++ if partition["fs"] == "linuxswap" and not "luksMapperName" in partition:
+ swap_uuid = partition["uuid"]
+
+ 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"])
++ "root=/dev/mapper/{!s}".format(partition["luksMapperName"]),
++ "resume=/dev/mapper/{!s}".format(partition["luksMapperName"])
+ ]
+
+ kernel_params = ["quiet"]
+@@ -80,6 +81,7 @@
+ kernel_params.append("resume=UUID={!s}".format(swap_uuid))
+
+ if dracut_bin == 0 and swap_outer_uuid:
++ kernel_params.append("resume=/dev/mapper/{!s}".format(partition["luksMapperName"]))
+ kernel_params.append("rd.luks.uuid={!s}".format(swap_outer_uuid))
+
+ distributor_line = "GRUB_DISTRIBUTOR='{!s}'".format(distributor_replace)