]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
gfs2: fix freeze error handling
authorAlexey Velichayshiy <a.velichayshiy@ispras.ru>
Mon, 29 Dec 2025 22:33:32 +0000 (17:33 -0500)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 8 Jan 2026 09:14:56 +0000 (10:14 +0100)
[ Upstream commit 4cfc7d5a4a01d2133b278cdbb1371fba1b419174 ]

After commit b77b4a4815a9 ("gfs2: Rework freeze / thaw logic"),
the freeze error handling is broken because gfs2_do_thaw()
overwrites the 'error' variable, causing incorrect processing
of the original freeze error.

Fix this by calling gfs2_do_thaw() when gfs2_lock_fs_check_clean()
fails but ignoring its return value to preserve the original
freeze error for proper reporting.

Found by Linux Verification Center (linuxtesting.org) with SVACE.

Fixes: b77b4a4815a9 ("gfs2: Rework freeze / thaw logic")
Cc: stable@vger.kernel.org # v6.5+
Signed-off-by: Alexey Velichayshiy <a.velichayshiy@ispras.ru>
Signed-off-by: Andreas Gruenbacher <agruenba@redhat.com>
[ gfs2_do_thaw() only takes 2 params ]
Signed-off-by: Sasha Levin <sashal@kernel.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
fs/gfs2/super.c

index 3b1303f97a3bc633ee00991d384ec8e9bda4d1c6..e6f8be03190c44a8444a56fedddc52f7c1ef3cf7 100644 (file)
@@ -759,9 +759,7 @@ static int gfs2_freeze_super(struct super_block *sb, enum freeze_holder who)
                        break;
                }
 
-               error = gfs2_do_thaw(sdp, who);
-               if (error)
-                       goto out;
+               (void)gfs2_do_thaw(sdp, who);
 
                if (error == -EBUSY)
                        fs_err(sdp, "waiting for recovery before freeze\n");