[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <175798064444.349669.1767392407737387794.stgit@frogsfrogsfrogs>
Date: Mon, 15 Sep 2025 17:02:10 -0700
From: "Darrick J. Wong" <djwong@...nel.org>
To: tytso@....edu
Cc: linux-ext4@...r.kernel.org
Subject: [PATCH 3/3] fuse2fs: hoist unmount code from main
From: Darrick J. Wong <djwong@...nel.org>
Hoist the unmount code into a separate function so that we can reduce
the complexity of main(). This also sets us up for unmounting the
filesystem from op_destroy, which we'll need for fuse2fs+iomap mode to
maintain the expected behavior that the block device is free when
umount(8) returns.
Signed-off-by: "Darrick J. Wong" <djwong@...nel.org>
---
misc/fuse2fs.c | 30 ++++++++++++++++++++----------
1 file changed, 20 insertions(+), 10 deletions(-)
diff --git a/misc/fuse2fs.c b/misc/fuse2fs.c
index a66c0496e66dcf..23a1cd8d5d5d0a 100644
--- a/misc/fuse2fs.c
+++ b/misc/fuse2fs.c
@@ -907,6 +907,25 @@ static void fuse2fs_release_lockfile(struct fuse2fs *ff)
free(ff->lockfile);
}
+static void fuse2fs_unmount(struct fuse2fs *ff)
+{
+ errcode_t err;
+
+ if (!ff->fs)
+ return;
+
+ err = ext2fs_close(ff->fs);
+ if (err) {
+ err_printf(ff, "%s: %s\n", _("while closing fs"),
+ error_message(err));
+ ext2fs_free(ff->fs);
+ }
+ ff->fs = NULL;
+
+ if (ff->lockfile)
+ fuse2fs_release_lockfile(ff);
+}
+
static void op_destroy(void *p EXT2FS_ATTR((unused)))
{
struct fuse2fs *ff = fuse2fs_get();
@@ -5235,16 +5254,7 @@ int main(int argc, char *argv[])
_("Mount failed while opening filesystem. Check dmesg(1) for details."));
fflush(orig_stderr);
}
- if (fctx.fs) {
- err = ext2fs_close(fctx.fs);
- if (err) {
- com_err(argv[0], err, "while closing fs");
- ext2fs_free(fctx.fs);
- }
- fctx.fs = NULL;
- }
- if (fctx.lockfile)
- fuse2fs_release_lockfile(&fctx);
+ fuse2fs_unmount(&fctx);
if (fctx.device)
free(fctx.device);
fuse_opt_free_args(&args);
Powered by blists - more mailing lists