From 3c544f9a0601ec7e4238a70b81e76ab32a8a9538 Mon Sep 17 00:00:00 2001 From: Marius Vollmer Date: Mon, 23 Oct 2023 14:21:57 +0300 Subject: [PATCH] storage: Always resize filesystems and LUKS to the maximum possible This is always the right thing to do, since Cockpit will first resize the block device (which is a logical volume or partition) and then resize the content to match. This will cover the case where the block device resizing ended up with something different from what we asked for. --- pkg/storaged/resize.jsx | 18 +++++++++++++++--- 1 file changed, 15 insertions(+), 3 deletions(-) diff --git a/pkg/storaged/resize.jsx b/pkg/storaged/resize.jsx index 734a97b1789d..ac63faa8ad11 100644 --- a/pkg/storaged/resize.jsx +++ b/pkg/storaged/resize.jsx @@ -70,6 +70,12 @@ function lvol_or_part_and_fsys_resize(client, lvol_or_part, size, offline, passp function fsys_resize() { if (fsys) { + // When growing a filesystem, always grow it to fill its + // block device. This is always the right thing to do in + // Cockpit. + // + const resize_size = (size > orig_size) ? 0 : size - crypto_overhead; + // HACK - https://bugzilla.redhat.com/show_bug.cgi?id=1934567 // // block_fsys.MountedAt might be out of synch with reality @@ -87,9 +93,9 @@ function lvol_or_part_and_fsys_resize(client, lvol_or_part, size, offline, passp // When doing an offline resize, we need to first repair the filesystem. if (!is_mounted) { return (fsys.Repair({ }) - .then(function () { return fsys.Resize(size - crypto_overhead, { }) })); + .then(() => fsys.Resize(resize_size, { }))); } else { - return fsys.Resize(size - crypto_overhead, { }); + return fsys.Resize(resize_size, { }); } })); } else if (vdo) { @@ -119,11 +125,17 @@ function lvol_or_part_and_fsys_resize(client, lvol_or_part, size, offline, passp } function crypto_resize() { + // When growing a LUKS device, always grow it to fill its + // block device. This is always the right thing to do in + // Cockpit. + // + const resize_size = (size > orig_size) ? 0 : size - crypto_overhead; + if (crypto) { const opts = { }; if (passphrase) opts.passphrase = { t: "s", v: passphrase }; - return crypto.Resize(size - crypto_overhead, opts); + return crypto.Resize(resize_size, opts); } else { return Promise.resolve(); }