Re: [PATCH v2] gfs2: fix freeze error handling
From: Andreas Gruenbacher
Date: Mon Nov 17 2025 - 07:12:48 EST
On Mon, Nov 17, 2025 at 10:06 AM Alexey Velichayshiy
<a.velichayshiy@xxxxxxxxx> wrote:
> 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.
>
> Signed-off-by: Alexey Velichayshiy <a.velichayshiy@xxxxxxxxx>
> ---
> fs/gfs2/super.c | 4 +---
> 1 file changed, 1 insertion(+), 3 deletions(-)
>
> diff --git a/fs/gfs2/super.c b/fs/gfs2/super.c
> index 644b2d1e7276..54c6f2098f01 100644
> --- a/fs/gfs2/super.c
> +++ b/fs/gfs2/super.c
> @@ -749,9 +749,7 @@ static int gfs2_freeze_super(struct super_block *sb, enum freeze_holder who,
> break;
> }
>
> - error = gfs2_do_thaw(sdp, who, freeze_owner);
> - if (error)
> - goto out;
> + (void)gfs2_do_thaw(sdp, who, freeze_owner);
>
> if (error == -EBUSY)
> fs_err(sdp, "waiting for recovery before freeze\n");
> --
> 2.43.0
>
Applied to for-next, thank you.
Andreas