From: "Darrick J. Wong" <djwong@kernel.org>
To: miklos@szeredi.hu, djwong@kernel.org
Cc: joannelkoong@gmail.com, bpf@vger.kernel.org, john@groves.net,
bernd@bsbernd.com, neal@gompa.dev, linux-fsdevel@vger.kernel.org,
linux-ext4@vger.kernel.org
Subject: [PATCH 1/5] fuse: enable fuse servers to upload BPF programs to handle iomap requests
Date: Mon, 23 Feb 2026 15:24:19 -0800 [thread overview]
Message-ID: <177188736816.3938194.8820121397606069778.stgit@frogsfrogsfrogs> (raw)
In-Reply-To: <177188736765.3938194.6770791688236041940.stgit@frogsfrogsfrogs>
From: Darrick J. Wong <djwong@kernel.org>
There are certain fuse servers that might benefit from the ability to
upload a BPF program into the kernel to respond to ->iomap_begin
requests instead of upcalling the fuse server itself.
For example, consider a fuse server that abstracts a large amount of
storage for use as intermediate storage by programs. If the storage is
striped across hardware devices (e.g. RAID0 or interleaved memory
controllers) then the iomapping pattern will be completely regular
but the mappings themselves might be very small.
Performance for large IOs will suck if it is necessary to upcall the
fuse server every time we cross a mapping boundary. The fuse server can
try to mitigate that hit by upserting mappings ahead of time, but
there's a better solution for this usecase: BPF programs.
In this case, the fuse server can compile a BPF program that will
compute the mapping data for a given request and upload the program.
This avoids the overhead of cache lookups and server upcalls. Note that
the BPF verifier still imposes instruction count and complexity limits
on the uploaded programs.
Note that I embraced and extended some code from Joanne, but at this
point I've modified it so heavily that it's not really the original
anymore. But she still gets credit for coming up with the idea and
engaging me in flinging prototypes around.
Link: https://lore.kernel.org/linux-ext4/CAJnrk1ag3ffQC=U1ZXVLTipDyo1VBQBM3MYNB6=6d4ywLOEieA@mail.gmail.com/
Co-authored-by: Joanne Koong <joannelkoong@gmail.com>
Signed-off-by: "Darrick J. Wong" <djwong@kernel.org>
---
fs/fuse/fuse_i.h | 5 +
fs/fuse/fuse_iomap_bpf.h | 88 +++++++++++++
fs/fuse/Makefile | 4 +
fs/fuse/fuse_iomap.c | 13 +-
fs/fuse/fuse_iomap_bpf.c | 309 ++++++++++++++++++++++++++++++++++++++++++++++
fs/fuse/inode.c | 7 +
6 files changed, 423 insertions(+), 3 deletions(-)
create mode 100644 fs/fuse/fuse_iomap_bpf.h
create mode 100644 fs/fuse/fuse_iomap_bpf.c
diff --git a/fs/fuse/fuse_i.h b/fs/fuse/fuse_i.h
index 5f2e7755e3e4e4..677e1fa4c8586c 100644
--- a/fs/fuse/fuse_i.h
+++ b/fs/fuse/fuse_i.h
@@ -686,6 +686,11 @@ struct fuse_iomap_conn {
/* maximum mapping cache size */
unsigned int cache_maxbytes;
+
+#ifdef CONFIG_BPF_SYSCALL
+ /* bpf iomap overrides for this fs */
+ struct fuse_iomap_bpf_ops __rcu *bpf_ops;
+#endif
};
#endif
diff --git a/fs/fuse/fuse_iomap_bpf.h b/fs/fuse/fuse_iomap_bpf.h
new file mode 100644
index 00000000000000..f6bfd2133bf2bb
--- /dev/null
+++ b/fs/fuse/fuse_iomap_bpf.h
@@ -0,0 +1,88 @@
+// SPDX-License-Identifier: GPL-2.0
+/*
+ * Copyright (C) 2026 Oracle. All Rights Reserved.
+ * Author: Darrick J. Wong <djwong@kernel.org>
+ * Copied from: Joanne Koong <joannelkoong@gmail.com>
+ */
+#ifndef _FS_FUSE_IOMAP_BPF_H
+#define _FS_FUSE_IOMAP_BPF_H
+
+#if IS_ENABLED(CONFIG_FUSE_IOMAP) && IS_ENABLED(CONFIG_BPF_SYSCALL)
+enum fuse_iomap_bpf_ret {
+ /* fall back to fuse server upcall */
+ FIB_FALLBACK = 0,
+ /* bpf function handled event completely */
+ FIB_HANDLED = 1,
+};
+
+struct fuse_iomap_bpf_ops {
+ /**
+ * @iomap_begin: override iomap_begin. See FUSE_IOMAP_BEGIN for
+ * details.
+ */
+ enum fuse_iomap_bpf_ret (*iomap_begin)(struct fuse_inode *fi,
+ uint64_t pos, uint64_t count, uint32_t opflags,
+ struct fuse_iomap_begin_out *outarg);
+
+ /**
+ * @iomap_end: override iomap_end. See FUSE_IOMAP_END for
+ * details.
+ */
+ enum fuse_iomap_bpf_ret (*iomap_end)(struct fuse_inode *fi,
+ uint64_t pos, uint64_t count, int64_t written,
+ uint32_t opflags);
+
+ /**
+ * @iomap_ioend: override iomap_ioend. See FUSE_IOMAP_IOEND for
+ * details.
+ */
+ enum fuse_iomap_bpf_ret (*iomap_ioend)(struct fuse_inode *fi,
+ uint64_t pos, int64_t written, uint32_t ioendflags,
+ int error, uint32_t dev, uint64_t new_addr,
+ struct fuse_iomap_ioend_out *outarg);
+
+ /**
+ * @fuse_fd: file descriptor of the open fuse device
+ */
+ int fuse_fd;
+
+ /**
+ * @zeropad: Explicitly pad to zero.
+ */
+ unsigned int zeropad;
+
+ /**
+ * @name: string describing the fuse iomap bpf operations
+ */
+ char name[16];
+
+ /* private: don't show fuse connection to the world */
+ struct fuse_conn *fc;
+
+ /*
+ * private: number of iomap operations in progress, biased by one for
+ * the fuse connection
+ */
+ atomic_t users;
+};
+
+int fuse_iomap_init_bpf(void);
+void fuse_iomap_unmount_bpf(struct fuse_conn *fc);
+
+int fuse_iomap_begin_bpf(struct inode *inode,
+ const struct fuse_iomap_begin_in *inarg,
+ struct fuse_iomap_begin_out *outarg);
+int fuse_iomap_end_bpf(struct inode *inode,
+ const struct fuse_iomap_end_in *inarg);
+int fuse_iomap_ioend_bpf(struct inode *inode,
+ const struct fuse_iomap_ioend_in *inarg,
+ struct fuse_iomap_ioend_out *outarg);
+#else
+# define fuse_iomap_init_bpf() (0)
+# define fuse_iomap_unmount_bpf(...) ((void)0)
+# define fuse_iomap_begin_bpf(...) (-ENOSYS)
+# define fuse_iomap_end_bpf(...) (-ENOSYS)
+# define fuse_iomap_ioend_bpf(...) (-ENOSYS)
+#endif /* CONFIG_FUSE_IOMAP && CONFIG_BPF_SYSCALL */
+
+#endif /* _FS_FUSE_IOMAP_BPF_H */
diff --git a/fs/fuse/Makefile b/fs/fuse/Makefile
index c672503da7bcbd..43ba967db197b1 100644
--- a/fs/fuse/Makefile
+++ b/fs/fuse/Makefile
@@ -20,4 +20,8 @@ fuse-$(CONFIG_SYSCTL) += sysctl.o
fuse-$(CONFIG_FUSE_IO_URING) += dev_uring.o
fuse-$(CONFIG_FUSE_IOMAP) += fuse_iomap.o fuse_iomap_cache.o
+ifeq ($(CONFIG_BPF_SYSCALL),y)
+fuse-$(CONFIG_FUSE_IOMAP) += fuse_iomap_bpf.o
+endif
+
virtiofs-y := virtio_fs.o
diff --git a/fs/fuse/fuse_iomap.c b/fs/fuse/fuse_iomap.c
index 7bc938cd859fae..2e0c35e879ffcc 100644
--- a/fs/fuse/fuse_iomap.c
+++ b/fs/fuse/fuse_iomap.c
@@ -16,6 +16,7 @@
#include "fuse_iomap_i.h"
#include "fuse_dev_i.h"
#include "fuse_iomap_cache.h"
+#include "fuse_iomap_bpf.h"
static bool __read_mostly enable_iomap =
#if IS_ENABLED(CONFIG_FUSE_IOMAP_BY_DEFAULT)
@@ -783,7 +784,9 @@ static int fuse_iomap_begin(struct inode *inode, loff_t pos, loff_t count,
args.out_numargs = 1;
args.out_args[0].size = sizeof(outarg);
args.out_args[0].value = &outarg;
- err = fuse_simple_request(fm, &args);
+ err = fuse_iomap_begin_bpf(inode, &inarg, &outarg);
+ if (err == -ENOSYS)
+ err = fuse_simple_request(fm, &args);
if (err) {
trace_fuse_iomap_begin_error(inode, pos, count, opflags, err);
return err;
@@ -938,7 +941,9 @@ static int fuse_iomap_end(struct inode *inode, loff_t pos, loff_t count,
args.in_numargs = 1;
args.in_args[0].size = sizeof(inarg);
args.in_args[0].value = &inarg;
- err = fuse_simple_request(fm, &args);
+ err = fuse_iomap_end_bpf(inode, &inarg);
+ if (err == -ENOSYS)
+ err = fuse_simple_request(fm, &args);
if (err == -ENOSYS) {
/*
* libfuse returns ENOSYS for servers that don't
@@ -1047,7 +1052,9 @@ static int fuse_iomap_ioend(struct inode *inode, loff_t pos, size_t written,
args.out_numargs = 1;
args.out_args[0].size = sizeof(outarg);
args.out_args[0].value = &outarg;
- iomap_error = fuse_simple_request(fm, &args);
+ iomap_error = fuse_iomap_ioend_bpf(inode, &inarg, &outarg);
+ if (iomap_error == -ENOSYS)
+ iomap_error = fuse_simple_request(fm, &args);
switch (iomap_error) {
case -ENOSYS:
/*
diff --git a/fs/fuse/fuse_iomap_bpf.c b/fs/fuse/fuse_iomap_bpf.c
new file mode 100644
index 00000000000000..b104f3961721b2
--- /dev/null
+++ b/fs/fuse/fuse_iomap_bpf.c
@@ -0,0 +1,309 @@
+// SPDX-License-Identifier: GPL-2.0
+/*
+ * Copyright (C) 2026 Oracle. All Rights Reserved.
+ * Author: Darrick J. Wong <djwong@kernel.org>
+ * Copied from: Joanne Koong <joannelkoong@gmail.com>
+ */
+#include <linux/bpf.h>
+
+#include "fuse_i.h"
+#include "fuse_dev_i.h"
+#include "fuse_iomap_bpf.h"
+#include "fuse_iomap_i.h"
+#include "fuse_trace.h"
+
+/* spinlock for atomically updating fuse_conn <-> bpf_ops pointers */
+static DEFINE_SPINLOCK(fuse_iomap_bpf_ops_lock);
+
+/*
+ * The only structures that we provide to the BPF program are outparams, so
+ * they can write anything they want to it.
+ */
+static bool fuse_iomap_bpf_ops_is_valid_access(int off, int size,
+ enum bpf_access_type type,
+ const struct bpf_prog *prog,
+ struct bpf_insn_access_aux *info)
+{
+ return bpf_tracing_btf_ctx_access(off, size, type, prog, info);
+}
+
+static int fuse_iomap_bpf_ops_check_member(const struct btf_type *t,
+ const struct btf_member *member,
+ const struct bpf_prog *prog)
+{
+ return 0;
+}
+
+static int fuse_iomap_bpf_ops_btf_struct_access(struct bpf_verifier_log *log,
+ const struct bpf_reg_state *reg,
+ int off, int size)
+{
+ return 0;
+}
+
+static const struct bpf_verifier_ops fuse_iomap_bpf_verifier_ops = {
+ .get_func_proto = bpf_base_func_proto,
+ .is_valid_access = fuse_iomap_bpf_ops_is_valid_access,
+ .btf_struct_access = fuse_iomap_bpf_ops_btf_struct_access,
+};
+
+static int fuse_iomap_bpf_ops_init(struct btf *btf)
+{
+ return 0;
+}
+
+/* Copy data from userspace bpf ops to the kernel */
+static int fuse_iomap_bpf_ops_init_member(const struct btf_type *t,
+ const struct btf_member *member,
+ void *kdata, const void *udata)
+{
+ const struct fuse_iomap_bpf_ops *u_ops = udata;
+ struct fuse_iomap_bpf_ops *ops = kdata;
+ u32 moff;
+
+ /*
+ * This function must copy all non-function-pointers by itself and
+ * return 1 to indicate that the data has been handled by the
+ * struct_ops type, or the verifier will reject the map if the value of
+ * those fields is not zero.
+ */
+ moff = __btf_member_bit_offset(t, member) / 8;
+ switch (moff) {
+ case offsetof(struct fuse_iomap_bpf_ops, fuse_fd):
+ ops->fuse_fd = u_ops->fuse_fd;
+ return 1;
+ case offsetof(struct fuse_iomap_bpf_ops, users):
+ ASSERT(atomic_read(&ops->users) == 0);
+ atomic_set(&ops->users, 1);
+ return 1;
+ case offsetof(struct fuse_iomap_bpf_ops, name):
+ if (bpf_obj_name_cpy(ops->name, u_ops->name,
+ sizeof(ops->name)) <= 0)
+ return -EINVAL;
+ return 1; /* Handled */
+ }
+
+ /* Not handled, use default */
+ return 0;
+}
+
+/* Register an iomap bpf program with a fuse connection */
+static int fuse_iomap_bpf_reg(void *kdata, struct bpf_link *link)
+{
+ struct fuse_iomap_bpf_ops *ops = kdata;
+ struct file *fusedev_file;
+ struct fuse_dev *fud;
+ struct fuse_conn *fc;
+
+ CLASS(fd, fusedev_fd)(ops->fuse_fd);
+ if (fd_empty(fusedev_fd))
+ return -EBADF;
+
+ fusedev_file = fd_file(fusedev_fd);
+ if (fusedev_file->f_op != &fuse_dev_operations)
+ return -EBADF;
+
+ fud = fuse_get_dev(fusedev_file);
+ fc = fud->fc;
+
+ if (!fc->iomap)
+ return -EOPNOTSUPP;
+
+ spin_lock(&fuse_iomap_bpf_ops_lock);
+ if (fc->iomap_conn.bpf_ops) {
+ spin_unlock(&fuse_iomap_bpf_ops_lock);
+ return -EBUSY;
+ }
+
+ /*
+ * The initial ops user count bias is transferred to fc so that we only
+ * initiate wakeup events when someone tries to unregister the BPF.
+ */
+ rcu_assign_pointer(fc->iomap_conn.bpf_ops, ops);
+ ops->fc = fc;
+ spin_unlock(&fuse_iomap_bpf_ops_lock);
+
+ return 0;
+}
+
+static inline struct fuse_iomap_bpf_ops *
+fuse_iomap_get_bpf_ops(struct inode *inode)
+{
+ struct fuse_conn *fc = get_fuse_conn(inode);
+ struct fuse_iomap_bpf_ops *ops;
+
+ rcu_read_lock();
+ ops = rcu_dereference(fc->iomap_conn.bpf_ops);
+ if (ops && !atomic_inc_not_zero(&ops->users))
+ ops = NULL;
+ rcu_read_unlock();
+
+ return ops;
+}
+
+static inline void
+fuse_iomap_put_bpf_ops(struct fuse_iomap_bpf_ops *ops)
+{
+ if (ops)
+ atomic_dec_and_wake_up(&ops->users);
+}
+
+DEFINE_CLASS(iomap_bpf_ops, struct fuse_iomap_bpf_ops *,
+ fuse_iomap_put_bpf_ops(_T), fuse_iomap_get_bpf_ops(inode),
+ struct inode *inode);
+
+static void __fuse_iomap_detach_bpf(struct fuse_conn *fc,
+ struct fuse_iomap_bpf_ops *ops)
+{
+ ops->fc = NULL;
+ rcu_assign_pointer(fc->iomap_conn.bpf_ops, NULL);
+ fuse_iomap_put_bpf_ops(ops);
+}
+
+/* Detach any iomap bpf programs from the fuse connection */
+void fuse_iomap_unmount_bpf(struct fuse_conn *fc)
+{
+ spin_lock(&fuse_iomap_bpf_ops_lock);
+ if (fc->iomap_conn.bpf_ops) {
+ /*
+ * This should only be called from unmount, so there won't be
+ * anybody trying to call the BPF iomap functions.
+ */
+ ASSERT(atomic_read(&fc->iomap_conn.bpf_ops->users) == 1);
+
+ __fuse_iomap_detach_bpf(fc, fc->iomap_conn.bpf_ops);
+ }
+ spin_unlock(&fuse_iomap_bpf_ops_lock);
+}
+
+/* Detach the fuse connection from this iomap bpf program */
+static void fuse_iomap_bpf_unreg(void *kdata, struct bpf_link *link)
+{
+ struct fuse_iomap_bpf_ops *ops = kdata;
+
+ spin_lock(&fuse_iomap_bpf_ops_lock);
+ if (ops->fc && ops->fc->iomap_conn.bpf_ops == ops)
+ __fuse_iomap_detach_bpf(ops->fc, ops);
+ spin_unlock(&fuse_iomap_bpf_ops_lock);
+
+ /* wait until nobody's trying to call into the bpf iomap program */
+ wait_var_event(&ops->users, atomic_read(&ops->users) == 0);
+}
+
+/* Dummy function stubs for control flow integrity hashes */
+static enum fuse_iomap_bpf_ret
+__iomap_begin(struct fuse_inode *fi, uint64_t pos, uint64_t count,
+ uint32_t opflags, struct fuse_iomap_begin_out *outarg)
+{
+ return FIB_FALLBACK;
+}
+
+static enum fuse_iomap_bpf_ret
+__iomap_end(struct fuse_inode *fi, uint64_t pos, uint64_t count,
+ int64_t written, uint32_t opflags)
+{
+ return FIB_FALLBACK;
+}
+
+static enum fuse_iomap_bpf_ret
+__iomap_ioend(struct fuse_inode *fi, uint64_t pos, int64_t written,
+ uint32_t ioendflags, int error, uint32_t dev, uint64_t new_addr,
+ struct fuse_iomap_ioend_out *outarg)
+{
+ return FIB_FALLBACK;
+}
+
+static struct fuse_iomap_bpf_ops __fuse_iomap_bpf_ops = {
+ .iomap_begin = __iomap_begin,
+ .iomap_end = __iomap_end,
+ .iomap_ioend = __iomap_ioend,
+};
+
+static struct bpf_struct_ops fuse_iomap_bpf_struct_ops = {
+ .verifier_ops = &fuse_iomap_bpf_verifier_ops,
+ .init = fuse_iomap_bpf_ops_init,
+ .check_member = fuse_iomap_bpf_ops_check_member,
+ .init_member = fuse_iomap_bpf_ops_init_member,
+ .reg = fuse_iomap_bpf_reg,
+ .unreg = fuse_iomap_bpf_unreg,
+ .name = "fuse_iomap_bpf_ops",
+ .cfi_stubs = &__fuse_iomap_bpf_ops,
+ .owner = THIS_MODULE,
+};
+
+/* Register the iomap bpf ops so that fuse servers can attach to it */
+int __init fuse_iomap_init_bpf(void)
+{
+ return register_bpf_struct_ops(&fuse_iomap_bpf_struct_ops,
+ fuse_iomap_bpf_ops);
+}
+
+/* Register key structures with BTF so that BPF programs can use structs */
+BTF_ID_LIST_GLOBAL_SINGLE(btf_fuse_iomap_bpf_ops_id,
+ struct, fuse_iomap_bpf_ops)
+BTF_ID_LIST_GLOBAL_SINGLE(btf_fuse_iomap_begin_out_id,
+ struct, fuse_iomap_begin_out)
+BTF_ID_LIST_GLOBAL_SINGLE(btf_fuse_iomap_ioend_out_id,
+ struct, fuse_iomap_ioend_out)
+
+static inline int bpf_to_errno(enum fuse_iomap_bpf_ret ret)
+{
+ switch (ret) {
+ case FIB_HANDLED:
+ return 0;
+ case FIB_FALLBACK:
+ default:
+ return -ENOSYS;
+ }
+}
+
+/* Try to call the bpf version of ->iomap_begin */
+int fuse_iomap_begin_bpf(struct inode *inode,
+ const struct fuse_iomap_begin_in *inarg,
+ struct fuse_iomap_begin_out *outarg)
+{
+ struct fuse_inode *fi = get_fuse_inode(inode);
+ CLASS(iomap_bpf_ops, bpf_ops)(inode);
+ enum fuse_iomap_bpf_ret ret;
+
+ if (!bpf_ops || !bpf_ops->iomap_begin)
+ return -ENOSYS;
+
+ ret = bpf_ops->iomap_begin(fi, inarg->pos, inarg->count,
+ inarg->opflags, outarg);
+ return bpf_to_errno(ret);
+}
+
+/* Try to call the bpf version of ->iomap_end */
+int fuse_iomap_end_bpf(struct inode *inode,
+ const struct fuse_iomap_end_in *inarg)
+{
+ struct fuse_inode *fi = get_fuse_inode(inode);
+ CLASS(iomap_bpf_ops, bpf_ops)(inode);
+ enum fuse_iomap_bpf_ret ret;
+
+ if (!bpf_ops || !bpf_ops->iomap_end)
+ return -ENOSYS;
+
+ ret = bpf_ops->iomap_end(fi, inarg->pos, inarg->count,
+ inarg->written, inarg->opflags);
+ return bpf_to_errno(ret);
+}
+
+/* Try to call the bpf version of ->iomap_ioend */
+int fuse_iomap_ioend_bpf(struct inode *inode,
+ const struct fuse_iomap_ioend_in *inarg,
+ struct fuse_iomap_ioend_out *outarg)
+{
+ struct fuse_inode *fi = get_fuse_inode(inode);
+ CLASS(iomap_bpf_ops, bpf_ops)(inode);
+ enum fuse_iomap_bpf_ret ret;
+
+ if (!bpf_ops || !bpf_ops->iomap_ioend)
+ return -ENOSYS;
+
+ ret = bpf_ops->iomap_ioend(fi, inarg->pos, inarg->written,
+ inarg->flags, inarg->error, inarg->dev,
+ inarg->new_addr, outarg);
+ return bpf_to_errno(ret);
+}
diff --git a/fs/fuse/inode.c b/fs/fuse/inode.c
index 0f2b12aa1ac4bb..1ab9c0dc3fc964 100644
--- a/fs/fuse/inode.c
+++ b/fs/fuse/inode.c
@@ -10,6 +10,7 @@
#include "fuse_dev_i.h"
#include "dev_uring_i.h"
#include "fuse_iomap.h"
+#include "fuse_iomap_bpf.h"
#include <linux/dax.h>
#include <linux/pagemap.h>
@@ -1718,6 +1719,8 @@ EXPORT_SYMBOL_GPL(fuse_send_init);
void fuse_free_conn(struct fuse_conn *fc)
{
WARN_ON(!list_empty(&fc->devices));
+
+ fuse_iomap_unmount_bpf(fc);
kfree(fc);
}
EXPORT_SYMBOL_GPL(fuse_free_conn);
@@ -2373,6 +2376,10 @@ static int __init fuse_fs_init(void)
if (!fuse_inode_cachep)
goto out;
+ err = fuse_iomap_init_bpf();
+ if (err)
+ goto out2;
+
err = register_fuseblk();
if (err)
goto out2;
next prev parent reply other threads:[~2026-02-23 23:24 UTC|newest]
Thread overview: 231+ messages / expand[flat|nested] mbox.gz Atom feed top
2026-02-23 22:46 [PATCHBLIZZARD v7] fuse/libfuse/e2fsprogs: containerize ext4 for safer operation Darrick J. Wong
2026-02-23 23:00 ` [PATCHSET v7 1/9] fuse: general bug fixes Darrick J. Wong
2026-02-23 23:06 ` [PATCH 1/5] fuse: flush pending FUSE_RELEASE requests before sending FUSE_DESTROY Darrick J. Wong
2026-02-24 19:33 ` Joanne Koong
2026-02-24 19:57 ` Darrick J. Wong
2026-02-24 20:03 ` Joanne Koong
2026-02-23 23:06 ` [PATCH 2/5] fuse: quiet down complaints in fuse_conn_limit_write Darrick J. Wong
2026-02-24 8:36 ` Horst Birthelmer
2026-02-24 19:17 ` Darrick J. Wong
2026-02-24 20:09 ` Joanne Koong
2026-02-27 16:05 ` Miklos Szeredi
2026-02-23 23:07 ` [PATCH 3/5] fuse: implement file attributes mask for statx Darrick J. Wong
2026-03-25 18:35 ` Joanne Koong
2026-03-25 22:12 ` Darrick J. Wong
2026-02-23 23:07 ` [PATCH 4/5] fuse: update file mode when updating acls Darrick J. Wong
2026-03-25 19:39 ` Joanne Koong
2026-03-25 22:23 ` Darrick J. Wong
2026-02-23 23:07 ` [PATCH 5/5] fuse: propagate default and file acls on creation Darrick J. Wong
2026-02-23 23:00 ` [PATCHSET v7 2/9] iomap: cleanups ahead of adding fuse support Darrick J. Wong
2026-02-23 23:07 ` [PATCH 1/2] iomap: allow directio callers to supply _COMP_WORK Darrick J. Wong
2026-02-24 14:00 ` Christoph Hellwig
2026-02-24 19:17 ` Darrick J. Wong
2026-02-23 23:08 ` [PATCH 2/2] iomap: allow NULL swap info bdev when activating swapfile Darrick J. Wong
2026-02-24 14:01 ` Christoph Hellwig
2026-02-24 19:26 ` Darrick J. Wong
2026-02-25 14:16 ` Christoph Hellwig
2026-02-25 17:03 ` Darrick J. Wong
2026-02-25 17:49 ` Christoph Hellwig
2026-02-23 23:01 ` [PATCHSET v7 3/9] fuse: cleanups ahead of adding fuse support Darrick J. Wong
2026-02-23 23:08 ` [PATCH 1/2] fuse: move the passthrough-specific code back to passthrough.c Darrick J. Wong
2026-02-23 23:08 ` [PATCH 2/2] fuse_trace: " Darrick J. Wong
2026-02-23 23:01 ` [PATCHSET v7 4/9] fuse: allow servers to use iomap for better file IO performance Darrick J. Wong
2026-02-23 23:08 ` [PATCH 01/33] fuse: implement the basic iomap mechanisms Darrick J. Wong
2026-02-23 23:09 ` [PATCH 02/33] fuse_trace: " Darrick J. Wong
2026-02-23 23:09 ` [PATCH 03/33] fuse: make debugging configurable at runtime Darrick J. Wong
2026-02-23 23:09 ` [PATCH 04/33] fuse: adapt FUSE_DEV_IOC_BACKING_{OPEN,CLOSE} to add new iomap devices Darrick J. Wong
2026-02-23 23:09 ` [PATCH 05/33] fuse_trace: " Darrick J. Wong
2026-02-23 23:10 ` [PATCH 06/33] fuse: enable SYNCFS and ensure we flush everything before sending DESTROY Darrick J. Wong
2026-02-23 23:10 ` [PATCH 07/33] fuse: clean up per-file type inode initialization Darrick J. Wong
2026-02-23 23:10 ` [PATCH 08/33] fuse: create a per-inode flag for setting exclusive mode Darrick J. Wong
2026-02-23 23:11 ` [PATCH 09/33] fuse: create a per-inode flag for toggling iomap Darrick J. Wong
2026-02-23 23:11 ` [PATCH 10/33] fuse_trace: " Darrick J. Wong
2026-02-23 23:11 ` [PATCH 11/33] fuse: isolate the other regular file IO paths from iomap Darrick J. Wong
2026-02-23 23:11 ` [PATCH 12/33] fuse: implement basic iomap reporting such as FIEMAP and SEEK_{DATA,HOLE} Darrick J. Wong
2026-02-23 23:12 ` [PATCH 13/33] fuse_trace: " Darrick J. Wong
2026-02-23 23:12 ` [PATCH 14/33] fuse: implement direct IO with iomap Darrick J. Wong
2026-02-23 23:12 ` [PATCH 15/33] fuse_trace: " Darrick J. Wong
2026-02-23 23:12 ` [PATCH 16/33] fuse: implement buffered " Darrick J. Wong
2026-02-27 18:04 ` Darrick J. Wong
2026-02-23 23:13 ` [PATCH 17/33] fuse_trace: " Darrick J. Wong
2026-02-23 23:13 ` [PATCH 18/33] fuse: use an unrestricted backing device with iomap pagecache io Darrick J. Wong
2026-02-23 23:13 ` [PATCH 19/33] fuse: implement large folios for iomap pagecache files Darrick J. Wong
2026-02-23 23:13 ` [PATCH 20/33] fuse: advertise support for iomap Darrick J. Wong
2026-02-23 23:14 ` [PATCH 21/33] fuse: query filesystem geometry when using iomap Darrick J. Wong
2026-02-23 23:14 ` [PATCH 22/33] fuse_trace: " Darrick J. Wong
2026-02-23 23:14 ` [PATCH 23/33] fuse: implement fadvise for iomap files Darrick J. Wong
2026-02-23 23:14 ` [PATCH 24/33] fuse: invalidate ranges of block devices being used for iomap Darrick J. Wong
2026-02-23 23:15 ` [PATCH 25/33] fuse_trace: " Darrick J. Wong
2026-02-23 23:15 ` [PATCH 26/33] fuse: implement inline data file IO via iomap Darrick J. Wong
2026-02-27 18:02 ` Darrick J. Wong
2026-02-23 23:15 ` [PATCH 27/33] fuse_trace: " Darrick J. Wong
2026-02-23 23:15 ` [PATCH 28/33] fuse: allow more statx fields Darrick J. Wong
2026-02-23 23:16 ` [PATCH 29/33] fuse: support atomic writes with iomap Darrick J. Wong
2026-02-24 12:58 ` Pankaj Raghav (Samsung)
2026-02-24 19:30 ` Darrick J. Wong
2026-02-24 21:18 ` Pankaj Raghav (Samsung)
2026-02-23 23:16 ` [PATCH 30/33] fuse_trace: " Darrick J. Wong
2026-02-23 23:16 ` [PATCH 31/33] fuse: disable direct fs reclaim for any fuse server that uses iomap Darrick J. Wong
2026-02-23 23:17 ` [PATCH 32/33] fuse: enable swapfile activation on iomap Darrick J. Wong
2026-02-23 23:17 ` [PATCH 33/33] fuse: implement freeze and shutdowns for iomap filesystems Darrick J. Wong
2026-02-23 23:01 ` [PATCHSET v7 5/9] fuse: allow servers to specify root node id Darrick J. Wong
2026-02-23 23:17 ` [PATCH 1/3] fuse: make the root nodeid dynamic Darrick J. Wong
2026-02-23 23:17 ` [PATCH 2/3] fuse_trace: " Darrick J. Wong
2026-02-23 23:18 ` [PATCH 3/3] fuse: allow setting of root nodeid Darrick J. Wong
2026-02-23 23:01 ` [PATCHSET v7 6/9] fuse: handle timestamps and ACLs correctly when iomap is enabled Darrick J. Wong
2026-02-23 23:18 ` [PATCH 1/9] fuse: enable caching of timestamps Darrick J. Wong
2026-02-23 23:18 ` [PATCH 2/9] fuse: force a ctime update after a fileattr_set call when in iomap mode Darrick J. Wong
2026-02-23 23:18 ` [PATCH 3/9] fuse: allow local filesystems to set some VFS iflags Darrick J. Wong
2026-02-23 23:19 ` [PATCH 4/9] fuse_trace: " Darrick J. Wong
2026-02-23 23:19 ` [PATCH 5/9] fuse: cache atime when in iomap mode Darrick J. Wong
2026-02-23 23:19 ` [PATCH 6/9] fuse: let the kernel handle KILL_SUID/KILL_SGID for iomap filesystems Darrick J. Wong
2026-02-23 23:19 ` [PATCH 7/9] fuse_trace: " Darrick J. Wong
2026-02-23 23:20 ` [PATCH 8/9] fuse: update ctime when updating acls on an iomap inode Darrick J. Wong
2026-02-23 23:20 ` [PATCH 9/9] fuse: always cache ACLs when using iomap Darrick J. Wong
2026-02-23 23:02 ` [PATCHSET v7 7/9] fuse: cache iomap mappings for even better file IO performance Darrick J. Wong
2026-02-23 23:20 ` [PATCH 01/12] fuse: cache iomaps Darrick J. Wong
2026-02-27 18:07 ` Darrick J. Wong
2026-02-23 23:20 ` [PATCH 02/12] fuse_trace: " Darrick J. Wong
2026-02-23 23:21 ` [PATCH 03/12] fuse: use the iomap cache for iomap_begin Darrick J. Wong
2026-02-23 23:21 ` [PATCH 04/12] fuse_trace: " Darrick J. Wong
2026-02-23 23:21 ` [PATCH 05/12] fuse: invalidate iomap cache after file updates Darrick J. Wong
2026-02-23 23:21 ` [PATCH 06/12] fuse_trace: " Darrick J. Wong
2026-02-23 23:22 ` [PATCH 07/12] fuse: enable iomap cache management Darrick J. Wong
2026-02-23 23:22 ` [PATCH 08/12] fuse_trace: " Darrick J. Wong
2026-02-23 23:22 ` [PATCH 09/12] fuse: overlay iomap inode info in struct fuse_inode Darrick J. Wong
2026-02-23 23:23 ` [PATCH 10/12] fuse: constrain iomap mapping cache size Darrick J. Wong
2026-02-23 23:23 ` [PATCH 11/12] fuse_trace: " Darrick J. Wong
2026-02-23 23:23 ` [PATCH 12/12] fuse: enable iomap Darrick J. Wong
2026-02-23 23:02 ` [PATCHSET v7 8/9] fuse: run fuse servers as a contained service Darrick J. Wong
2026-02-23 23:23 ` [PATCH 1/2] fuse: allow privileged mount helpers to pre-approve iomap usage Darrick J. Wong
2026-02-23 23:24 ` [PATCH 2/2] fuse: set iomap backing device block size Darrick J. Wong
2026-02-23 23:02 ` [PATCHSET RFC 9/9] fuse: allow fuse servers to upload iomap BPF programs Darrick J. Wong
2026-02-23 23:24 ` Darrick J. Wong [this message]
2026-02-23 23:24 ` [PATCH 2/5] fuse_trace: enable fuse servers to upload BPF programs to handle iomap requests Darrick J. Wong
2026-02-23 23:24 ` [PATCH 3/5] fuse: prevent iomap bpf programs from writing to most of the system Darrick J. Wong
2026-02-23 23:25 ` [PATCH 4/5] fuse: add kfuncs for iomap bpf programs to manage the cache Darrick J. Wong
2026-02-23 23:25 ` [PATCH 5/5] fuse: make fuse_inode opaque to iomap bpf programs Darrick J. Wong
2026-02-23 23:02 ` [PATCHSET v7 1/6] libfuse: allow servers to use iomap for better file IO performance Darrick J. Wong
2026-02-23 23:25 ` [PATCH 01/25] libfuse: bump kernel and library ABI versions Darrick J. Wong
2026-02-23 23:25 ` [PATCH 02/25] libfuse: wait in do_destroy until all open files are closed Darrick J. Wong
2026-02-23 23:26 ` [PATCH 03/25] libfuse: add kernel gates for FUSE_IOMAP Darrick J. Wong
2026-02-23 23:26 ` [PATCH 04/25] libfuse: add fuse commands for iomap_begin and end Darrick J. Wong
2026-02-23 23:26 ` [PATCH 05/25] libfuse: add upper level iomap commands Darrick J. Wong
2026-02-23 23:26 ` [PATCH 06/25] libfuse: add a lowlevel notification to add a new device to iomap Darrick J. Wong
2026-02-23 23:27 ` [PATCH 07/25] libfuse: add upper-level iomap add device function Darrick J. Wong
2026-02-23 23:27 ` [PATCH 08/25] libfuse: add iomap ioend low level handler Darrick J. Wong
2026-02-23 23:27 ` [PATCH 09/25] libfuse: add upper level iomap ioend commands Darrick J. Wong
2026-02-23 23:27 ` [PATCH 10/25] libfuse: add a reply function to send FUSE_ATTR_* to the kernel Darrick J. Wong
2026-02-23 23:28 ` [PATCH 11/25] libfuse: connect high level fuse library to fuse_reply_attr_iflags Darrick J. Wong
2026-02-23 23:28 ` [PATCH 12/25] libfuse: support enabling exclusive mode for files Darrick J. Wong
2026-02-23 23:28 ` [PATCH 13/25] libfuse: support direct I/O through iomap Darrick J. Wong
2026-02-23 23:29 ` [PATCH 14/25] libfuse: don't allow hardlinking of iomap files in the upper level fuse library Darrick J. Wong
2026-02-23 23:29 ` [PATCH 15/25] libfuse: allow discovery of the kernel's iomap capabilities Darrick J. Wong
2026-02-23 23:29 ` [PATCH 16/25] libfuse: add lower level iomap_config implementation Darrick J. Wong
2026-02-23 23:29 ` [PATCH 17/25] libfuse: add upper " Darrick J. Wong
2026-02-23 23:30 ` [PATCH 18/25] libfuse: add low level code to invalidate iomap block device ranges Darrick J. Wong
2026-02-23 23:30 ` [PATCH 19/25] libfuse: add upper-level API to invalidate parts of an iomap block device Darrick J. Wong
2026-02-23 23:30 ` [PATCH 20/25] libfuse: add atomic write support Darrick J. Wong
2026-02-23 23:30 ` [PATCH 21/25] libfuse: allow disabling of fs memory reclaim and write throttling Darrick J. Wong
2026-02-23 23:31 ` [PATCH 22/25] libfuse: create a helper to transform an open regular file into an open loopdev Darrick J. Wong
2026-02-23 23:31 ` [PATCH 23/25] libfuse: add swapfile support for iomap files Darrick J. Wong
2026-02-23 23:31 ` [PATCH 24/25] libfuse: add lower-level filesystem freeze, thaw, and shutdown requests Darrick J. Wong
2026-02-23 23:31 ` [PATCH 25/25] libfuse: add upper-level filesystem freeze, thaw, and shutdown events Darrick J. Wong
2026-02-23 23:03 ` [PATCHSET v7 2/6] libfuse: allow servers to specify root node id Darrick J. Wong
2026-02-23 23:32 ` [PATCH 1/1] libfuse: allow root_nodeid mount option Darrick J. Wong
2026-02-23 23:03 ` [PATCHSET v7 3/6] libfuse: implement syncfs Darrick J. Wong
2026-02-23 23:32 ` [PATCH 1/2] libfuse: add strictatime/lazytime mount options Darrick J. Wong
2026-02-23 23:32 ` [PATCH 2/2] libfuse: set sync, immutable, and append when loading files Darrick J. Wong
2026-02-23 23:03 ` [PATCHSET v7 4/6] libfuse: cache iomap mappings for even better file IO performance Darrick J. Wong
2026-02-23 23:32 ` [PATCH 1/5] libfuse: enable iomap cache management for lowlevel fuse Darrick J. Wong
2026-02-23 23:33 ` [PATCH 2/5] libfuse: add upper-level iomap cache management Darrick J. Wong
2026-02-23 23:33 ` [PATCH 3/5] libfuse: allow constraining of iomap mapping cache size Darrick J. Wong
2026-02-23 23:33 ` [PATCH 4/5] libfuse: add upper-level iomap mapping cache constraint code Darrick J. Wong
2026-02-23 23:33 ` [PATCH 5/5] libfuse: enable iomap Darrick J. Wong
2026-02-23 23:03 ` [PATCHSET v7 5/6] libfuse: run fuse servers as a contained service Darrick J. Wong
2026-02-23 23:34 ` [PATCH 1/5] libfuse: add systemd/inetd socket service mounting helper Darrick J. Wong
2026-02-23 23:34 ` [PATCH 2/5] libfuse: integrate fuse services into mount.fuse3 Darrick J. Wong
2026-02-23 23:34 ` [PATCH 3/5] libfuse: delegate iomap privilege from mount.service to fuse services Darrick J. Wong
2026-02-23 23:34 ` [PATCH 4/5] libfuse: enable setting iomap block device block size Darrick J. Wong
2026-02-23 23:35 ` [PATCH 5/5] fuservicemount: create loop devices for regular files Darrick J. Wong
2026-02-23 23:04 ` [PATCHSET RFC 6/6] fuse: allow fuse servers to upload iomap BPF programs Darrick J. Wong
2026-02-23 23:35 ` [PATCH 1/3] libfuse: allow fuse servers to upload bpf code for iomap functions Darrick J. Wong
2026-02-23 23:35 ` [PATCH 2/3] libfuse: add kfuncs for iomap bpf programs to manage the cache Darrick J. Wong
2026-02-23 23:36 ` [PATCH 3/3] libfuse: make fuse_inode opaque to iomap bpf programs Darrick J. Wong
2026-02-23 23:04 ` [PATCHSET v7 1/8] fuse2fs: use fuse iomap data paths for better file I/O performance Darrick J. Wong
2026-02-23 23:36 ` [PATCH 01/19] fuse2fs: implement bare minimum iomap for file mapping reporting Darrick J. Wong
2026-02-23 23:36 ` [PATCH 02/19] fuse2fs: add iomap= mount option Darrick J. Wong
2026-02-23 23:36 ` [PATCH 03/19] fuse2fs: implement iomap configuration Darrick J. Wong
2026-02-23 23:37 ` [PATCH 04/19] fuse2fs: register block devices for use with iomap Darrick J. Wong
2026-02-23 23:37 ` [PATCH 05/19] fuse2fs: implement directio file reads Darrick J. Wong
2026-02-23 23:37 ` [PATCH 06/19] fuse2fs: add extent dump function for debugging Darrick J. Wong
2026-02-23 23:37 ` [PATCH 07/19] fuse2fs: implement direct write support Darrick J. Wong
2026-02-23 23:38 ` [PATCH 08/19] fuse2fs: turn on iomap for pagecache IO Darrick J. Wong
2026-02-23 23:38 ` [PATCH 09/19] fuse2fs: don't zero bytes in punch hole Darrick J. Wong
2026-02-23 23:38 ` [PATCH 10/19] fuse2fs: don't do file data block IO when iomap is enabled Darrick J. Wong
2026-02-23 23:38 ` [PATCH 11/19] fuse2fs: try to create loop device when ext4 device is a regular file Darrick J. Wong
2026-02-23 23:39 ` [PATCH 12/19] fuse2fs: enable file IO to inline data files Darrick J. Wong
2026-02-23 23:39 ` [PATCH 13/19] fuse2fs: set iomap-related inode flags Darrick J. Wong
2026-02-23 23:39 ` [PATCH 14/19] fuse2fs: configure block device block size Darrick J. Wong
2026-02-23 23:39 ` [PATCH 15/19] fuse4fs: separate invalidation Darrick J. Wong
2026-02-23 23:40 ` [PATCH 16/19] fuse2fs: implement statx Darrick J. Wong
2026-02-23 23:40 ` [PATCH 17/19] fuse2fs: enable atomic writes Darrick J. Wong
2026-02-23 23:40 ` [PATCH 18/19] fuse4fs: disable fs reclaim and write throttling Darrick J. Wong
2026-02-23 23:41 ` [PATCH 19/19] fuse2fs: implement freeze and shutdown requests Darrick J. Wong
2026-02-23 23:04 ` [PATCHSET v7 2/8] fuse4fs: specify the root node id Darrick J. Wong
2026-02-23 23:41 ` [PATCH 1/1] fuse4fs: don't use inode number translation when possible Darrick J. Wong
2026-02-23 23:05 ` [PATCHSET v7 3/8] fuse2fs: handle timestamps and ACLs correctly when iomap is enabled Darrick J. Wong
2026-02-23 23:41 ` [PATCH 01/10] fuse2fs: add strictatime/lazytime mount options Darrick J. Wong
2026-02-23 23:41 ` [PATCH 02/10] fuse2fs: skip permission checking on utimens when iomap is enabled Darrick J. Wong
2026-02-23 23:42 ` [PATCH 03/10] fuse2fs: let the kernel tell us about acl/mode updates Darrick J. Wong
2026-02-23 23:42 ` [PATCH 04/10] fuse2fs: better debugging for file mode updates Darrick J. Wong
2026-02-23 23:42 ` [PATCH 05/10] fuse2fs: debug timestamp updates Darrick J. Wong
2026-02-23 23:42 ` [PATCH 06/10] fuse2fs: use coarse timestamps for iomap mode Darrick J. Wong
2026-02-23 23:43 ` [PATCH 07/10] fuse2fs: add tracing for retrieving timestamps Darrick J. Wong
2026-02-23 23:43 ` [PATCH 08/10] fuse2fs: enable syncfs Darrick J. Wong
2026-02-23 23:43 ` [PATCH 09/10] fuse2fs: set sync, immutable, and append at file load time Darrick J. Wong
2026-02-23 23:43 ` [PATCH 10/10] fuse4fs: increase attribute timeout in iomap mode Darrick J. Wong
2026-02-23 23:05 ` [PATCHSET v7 4/8] fuse2fs: cache iomap mappings for even better file IO performance Darrick J. Wong
2026-02-23 23:44 ` [PATCH 1/3] fuse2fs: enable caching of iomaps Darrick J. Wong
2026-02-23 23:44 ` [PATCH 2/3] fuse2fs: constrain iomap mapping cache size Darrick J. Wong
2026-02-23 23:44 ` [PATCH 3/3] fuse2fs: enable iomap Darrick J. Wong
2026-02-23 23:05 ` [PATCHSET v7 5/8] fuse2fs: improve block and inode caching Darrick J. Wong
2026-02-23 23:44 ` [PATCH 1/6] libsupport: add caching IO manager Darrick J. Wong
2026-02-23 23:45 ` [PATCH 2/6] iocache: add the actual buffer cache Darrick J. Wong
2026-02-23 23:45 ` [PATCH 3/6] iocache: bump buffer mru priority every 50 accesses Darrick J. Wong
2026-02-23 23:45 ` [PATCH 4/6] fuse2fs: enable caching IO manager Darrick J. Wong
2026-02-23 23:45 ` [PATCH 5/6] fuse2fs: increase inode cache size Darrick J. Wong
2026-02-23 23:46 ` [PATCH 6/6] libext2fs: improve caching for inodes Darrick J. Wong
2026-02-23 23:05 ` [PATCHSET v7 6/8] fuse4fs: run servers as a contained service Darrick J. Wong
2026-02-23 23:46 ` [PATCH 1/8] libext2fs: fix MMP code to work with unixfd IO manager Darrick J. Wong
2026-02-23 23:46 ` [PATCH 2/8] fuse4fs: enable safe service mode Darrick J. Wong
2026-02-23 23:47 ` [PATCH 3/8] fuse4fs: set proc title when in fuse " Darrick J. Wong
2026-02-23 23:47 ` [PATCH 4/8] fuse4fs: upsert first file mapping to kernel on open Darrick J. Wong
2026-02-23 23:47 ` [PATCH 5/8] fuse4fs: set iomap backing device blocksize Darrick J. Wong
2026-02-23 23:47 ` [PATCH 6/8] fuse4fs: ask for loop devices when opening via fuservicemount Darrick J. Wong
2026-02-23 23:48 ` [PATCH 7/8] fuse4fs: make MMP work correctly in safe service mode Darrick J. Wong
2026-02-23 23:48 ` [PATCH 8/8] debian: update packaging for fuse4fs service Darrick J. Wong
2026-02-23 23:06 ` [PATCHSET v7 7/8] fuse4fs: reclaim buffer cache under memory pressure Darrick J. Wong
2026-02-23 23:48 ` [PATCH 1/4] libsupport: add pressure stall monitor Darrick J. Wong
2026-02-23 23:48 ` [PATCH 2/4] fuse2fs: only reclaim buffer cache when there is memory pressure Darrick J. Wong
2026-02-23 23:49 ` [PATCH 3/4] fuse4fs: enable memory pressure monitoring with service containers Darrick J. Wong
2026-02-23 23:49 ` [PATCH 4/4] fuse2fs: flush dirty metadata periodically Darrick J. Wong
2026-02-23 23:06 ` [PATCHSET RFC 8/8] fuse: allow fuse servers to upload iomap BPF programs Darrick J. Wong
2026-02-23 23:49 ` [PATCH 1/3] fuse4fs: add dynamic iomap bpf prototype which will break FIEMAP Darrick J. Wong
2026-02-23 23:49 ` [PATCH 2/3] fuse4fs: wire up caching examples to fuse iomap bpf program Darrick J. Wong
2026-02-23 23:50 ` [PATCH 3/3] fuse4fs: adjust test bpf program to deal with opaque inodes Darrick J. Wong
2026-03-16 17:56 ` [PATCHBLIZZARD v7] fuse/libfuse/e2fsprogs: containerize ext4 for safer operation Joanne Koong
2026-03-16 18:04 ` Darrick J. Wong
2026-03-16 23:08 ` Joanne Koong
2026-03-16 23:41 ` Darrick J. Wong
2026-03-17 0:20 ` Demi Marie Obenour
2026-03-17 13:59 ` Theodore Tso
2026-03-17 14:05 ` Demi Marie Obenour
2026-03-17 15:20 ` Theodore Tso
2026-03-18 21:31 ` Darrick J. Wong
2026-03-19 7:28 ` Demi Marie Obenour
2026-03-19 16:08 ` Darrick J. Wong
2026-03-20 17:04 ` Joanne Koong
2026-03-20 20:31 ` Darrick J. Wong
2026-03-17 0:10 ` Demi Marie Obenour
2026-04-29 14:11 ` [PATCHBLIZZARD v8] fuse/libfuse/e2fsprogs: faster file IO for containerized ext4 servers Darrick J. Wong
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=177188736816.3938194.8820121397606069778.stgit@frogsfrogsfrogs \
--to=djwong@kernel.org \
--cc=bernd@bsbernd.com \
--cc=bpf@vger.kernel.org \
--cc=joannelkoong@gmail.com \
--cc=john@groves.net \
--cc=linux-ext4@vger.kernel.org \
--cc=linux-fsdevel@vger.kernel.org \
--cc=miklos@szeredi.hu \
--cc=neal@gompa.dev \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox