[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <175798163116.392148.11424841429013808910.stgit@frogsfrogsfrogs>
Date: Mon, 15 Sep 2025 18:08:39 -0700
From: "Darrick J. Wong" <djwong@...nel.org>
To: tytso@....edu
Cc: miklos@...redi.hu, neal@...pa.dev, linux-fsdevel@...r.kernel.org,
linux-ext4@...r.kernel.org, John@...ves.net, bernd@...ernd.com,
joannelkoong@...il.com
Subject: [PATCH 1/4] libext2fs: fix MMP code to work with unixfd IO manager
From: Darrick J. Wong <djwong@...nel.org>
The MMP code assumes that it can (re)open() the filesystem via
fs->device_name. However, if the Unix FD IO manager is in use the path
will be the string representation of the fd number. This is a horrible
layering violation, but let's take the easy route and reroute the open()
call to dup() if desirable.
Signed-off-by: "Darrick J. Wong" <djwong@...nel.org>
---
lib/ext2fs/mmp.c | 46 +++++++++++++++++++++++++++++++++++++++++++++-
1 file changed, 45 insertions(+), 1 deletion(-)
diff --git a/lib/ext2fs/mmp.c b/lib/ext2fs/mmp.c
index eb9417020e6d3f..936ae920563fc5 100644
--- a/lib/ext2fs/mmp.c
+++ b/lib/ext2fs/mmp.c
@@ -26,6 +26,7 @@
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
+#include <limits.h>
#include "ext2fs/ext2_fs.h"
#include "ext2fs/ext2fs.h"
@@ -41,6 +42,49 @@
#endif
#endif
+static int ext2fs_mmp_open_device(ext2_filsys fs, int flags)
+{
+ struct stat st;
+ char *endptr = NULL;
+ long maybe_fd;
+ int new_fd;
+ int want_directio = 1;
+ int ret;
+
+ /*
+ * If the device name is only a number, then most likely the unixfd IO
+ * manager is in use here. Try to extract the fd number; if we can't,
+ * then fall back to regular open.
+ */
+ errno = 0;
+ maybe_fd = strtol(fs->device_name, &endptr, 10);
+ if (errno || endptr != fs->device_name + strlen(fs->device_name))
+ return open(fs->device_name, flags);
+
+ if (maybe_fd < 0 || maybe_fd > INT_MAX)
+ return -1;
+
+ /* Skip directio if this is a regular file, just like below */
+ ret = fstat(maybe_fd, &st);
+ if (ret == 0 && S_ISREG(st.st_mode))
+ want_directio = 0;
+
+ /* Duplicate the fd so that the MMP code can close it later */
+ new_fd = dup(maybe_fd);
+ if (new_fd < 0)
+ return -1;
+
+ if (want_directio) {
+ ret = fcntl(new_fd, F_SETFL, O_DIRECT);
+ if (ret) {
+ close(new_fd);
+ return -1;
+ }
+ }
+
+ return new_fd;
+}
+
errcode_t ext2fs_mmp_read(ext2_filsys fs, blk64_t mmp_blk, void *buf)
{
#ifdef CONFIG_MMP
@@ -70,7 +114,7 @@ errcode_t ext2fs_mmp_read(ext2_filsys fs, blk64_t mmp_blk, void *buf)
S_ISREG(st.st_mode))
flags &= ~O_DIRECT;
- fs->mmp_fd = open(fs->device_name, flags);
+ fs->mmp_fd = ext2fs_mmp_open_device(fs, flags);
if (fs->mmp_fd < 0) {
retval = EXT2_ET_MMP_OPEN_DIRECT;
goto out;
Powered by blists - more mailing lists