From 39d73e18829779203594d96f49144edd26d60903 Mon Sep 17 00:00:00 2001 From: Philip Date: Tue, 12 Sep 2017 07:10:59 -0400 Subject: [PATCH] [fstab] fix btrfs with LUKS and systemd - see also #730 - credit goes to @abucodonosor --- src/modules/fstab/main.py | 32 ++++++++++++++++++++++---------- 1 file changed, 22 insertions(+), 10 deletions(-) diff --git a/src/modules/fstab/main.py b/src/modules/fstab/main.py index aa4914e2f..0c9dbbbdb 100644 --- a/src/modules/fstab/main.py +++ b/src/modules/fstab/main.py @@ -226,6 +226,7 @@ class FstabGenerator(object): def generate_fstab_line_info(self, partition): """ Generates information for each fstab entry. """ filesystem = partition["fs"].lower() + has_luks = "luksMapperName" in partition mount_point = partition["mountPoint"] disk_name = disk_name_for_partition(partition) is_ssd = disk_name in self.ssd_disks @@ -253,17 +254,28 @@ class FstabGenerator(object): self.root_is_ssd = is_ssd if filesystem == "btrfs" and "subvol" in partition: - return dict( - device="UUID=" + partition["uuid"], - mount_point=mount_point, - fs=filesystem, - options=",".join( - ["subvol={}".format(partition["subvol"]), options] - ), - check=check, - ) + if has_luks: + return dict( + device="/dev/mapper/" + partition["luksMapperName"], + mount_point=mount_point, + fs=filesystem, + options=",".join( + ["subvol={}".format(partition["subvol"]), options] + ), + check=check, + ) + else: + return dict( + device="UUID=" + partition["uuid"], + mount_point=mount_point, + fs=filesystem, + options=",".join( + ["subvol={}".format(partition["subvol"]), options] + ), + check=check, + ) - if "luksMapperName" in partition: + if has_luks: return dict(device="/dev/mapper/" + partition["luksMapperName"], mount_point=mount_point or "swap", fs=filesystem,