[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-Id: <20240124070512.52207-1-jefflexu@linux.alibaba.com>
Date: Wed, 24 Jan 2024 15:05:12 +0800
From: Jingbo Xu <jefflexu@...ux.alibaba.com>
To: miklos@...redi.hu,
linux-fsdevel@...r.kernel.org
Cc: linux-kernel@...r.kernel.org,
zhangjiachen.jaycee@...edance.com
Subject: [PATCH] fuse: increase FUSE_MAX_MAX_PAGES limit
From: Xu Ji <laoji.jx@...baba-inc.com>
Increase FUSE_MAX_MAX_PAGES limit, so that the maximum data size of a
single request is increased.
This optimizes the write performance especially when the optimal IO size
of the backend store at the fuse daemon side is greater than the original
maximum request size (i.e. 1MB with 256 FUSE_MAX_MAX_PAGES and
4096 PAGE_SIZE).
Be noted that this only increases the upper limit of the maximum request
size, while the real maximum request size relies on the FUSE_INIT
negotiation with the fuse daemon.
Signed-off-by: Xu Ji <laoji.jx@...baba-inc.com>
Signed-off-by: Jingbo Xu <jefflexu@...ux.alibaba.com>
---
I'm not sure if 1024 is adequate for FUSE_MAX_MAX_PAGES, as the
Bytedance floks seems to had increased the maximum request size to 8M
and saw a ~20% performance boost.
---
fs/fuse/fuse_i.h | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/fs/fuse/fuse_i.h b/fs/fuse/fuse_i.h
index 1df83eebda92..6bd2cf0b42e1 100644
--- a/fs/fuse/fuse_i.h
+++ b/fs/fuse/fuse_i.h
@@ -36,7 +36,7 @@
#define FUSE_DEFAULT_MAX_PAGES_PER_REQ 32
/** Maximum of max_pages received in init_out */
-#define FUSE_MAX_MAX_PAGES 256
+#define FUSE_MAX_MAX_PAGES 1024
/** Bias for fi->writectr, meaning new writepages must not be sent */
#define FUSE_NOWRITE INT_MIN
--
2.19.1.6.gb485710b
Powered by blists - more mailing lists