erofs-utils: fuse: support FUSE 2/3 multi-threading
authorLi Yiyan <lyy0627@sjtu.edu.cn>
Tue, 12 Dec 2023 11:54:27 +0000 (19:54 +0800)
committerGao Xiang <hsiangkao@linux.alibaba.com>
Sun, 14 Jan 2024 09:16:52 +0000 (17:16 +0800)
Support multi-threading for erofsfuse and adjust the configure.ac to
allow users of FUSE 3(> 3.2) to use API version 32, while maintaining
compatibility with API version 30 for FUSE 3 (3.0/3.1) and API version
26 for FUSE 2.

Signed-off-by: Li Yiyan <lyy0627@sjtu.edu.cn>
Link: https://lore.kernel.org/r/20231212115427.2779792-1-lyy0627@sjtu.edu.cn
Signed-off-by: Gao Xiang <hsiangkao@linux.alibaba.com>
configure.ac
fuse/main.c

index 9294e0c3c187678ad1373a6bbc72818b4844867f..bf6e99fea631e77e6ba1fb3537b88743d70df6ef 100644 (file)
@@ -343,7 +343,13 @@ AS_IF([test "x$enable_fuse" != "xno"], [
   saved_LIBS="$LIBS"
   saved_CPPFLAGS=${CPPFLAGS}
   PKG_CHECK_MODULES([libfuse3], [fuse3 >= 3.0], [
-    AC_DEFINE([FUSE_USE_VERSION], [30], [used FUSE API version])
+    PKG_CHECK_MODULES([libfuse3_0], [fuse3 >= 3.0 fuse3 < 3.2], [
+      AC_DEFINE([FUSE_USE_VERSION], [30], [used FUSE API version])
+    ], [
+      PKG_CHECK_MODULES([libfuse3_2], [fuse3 >= 3.2], [
+        AC_DEFINE([FUSE_USE_VERSION], [32], [used FUSE API version])
+      ])
+    ])
     CPPFLAGS="${libfuse3_CFLAGS} ${CPPFLAGS}"
     LIBS="${libfuse3_LIBS} $LIBS"
     AC_CHECK_LIB(fuse3, fuse_session_new, [], [
index f07165c7c34fa620789fdb29af68138008104b55..32f59a35e212ec032b5a151597178922158c9e21 100644 (file)
@@ -699,7 +699,21 @@ int main(int argc, char *argv[])
                EROFSFUSE_MOUNT_MSG
                if (fuse_daemonize(opts.foreground) >= 0) {
                        if (fuse_set_signal_handlers(se) >= 0) {
-                               ret = fuse_session_loop(se);
+                               if (opts.singlethread) {
+                                       ret = fuse_session_loop(se);
+                               } else {
+#if FUSE_USE_VERSION == 30
+                                       ret = fuse_session_loop_mt(se, opts.clone_fd);
+#elif FUSE_USE_VERSION == 32
+                                       struct fuse_loop_config config = {
+                                               .clone_fd = opts.clone_fd,
+                                               .max_idle_threads = opts.max_idle_threads
+                                       };
+                                       ret = fuse_session_loop_mt(se, &config);
+#else
+#error "FUSE_USE_VERSION not supported"
+#endif
+                               }
                                fuse_remove_signal_handlers(se);
                        }
                        fuse_session_unmount(se);
@@ -717,7 +731,10 @@ int main(int argc, char *argv[])
                if (fuse_daemonize(opts.foreground) != -1) {
                        if (fuse_set_signal_handlers(se) != -1) {
                                fuse_session_add_chan(se, ch);
-                               ret = fuse_session_loop(se);
+                               if (opts.mt)
+                                       ret = fuse_session_loop_mt(se);
+                               else
+                                       ret = fuse_session_loop(se);
                                fuse_remove_signal_handlers(se);
                                fuse_session_remove_chan(ch);
                        }