Enable parallel direct writes on the same file.
authorDharmendra singh <dsingh@ddn.com>
Fri, 8 Apr 2022 10:18:27 +0000 (10:18 +0000)
committerNikolaus Rath <Nikolaus@rath.org>
Fri, 3 Mar 2023 12:41:49 +0000 (12:41 +0000)
commita5eb7f2a0117ab43119ef5724cf5f4f2f181804a
tree778bba47c24bc4f95b0353910d7af48b5c09722d
parent4f8aae77e6d5f27ce22a3b62f9d69f36f5a5774c
Enable parallel direct writes on the same file.

Right now fuse kernel serializes direct writes on the
same file. This serialization is good for such FUSE
implementations which rely on the inode lock to
avoid any data inconsistency issues but it hurts badly
such FUSE implementations which have their own mechanism
of dealing with cache/data integrity and can handle
parallel direct writes on the same file.

This patch allows parallel direct writes on the same file to be
enabled with the help of a flag FOPEN_PARALLEL_DIRECT_WRITES.
FUSE implementations which want to use this feature can
set this flag during fuse init. Default behaviour remains
same i.e no parallel direct writes on the same file.

Corresponding fuse kernel patch(Merged).
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git/commit/?h=v6.2&id=153524053bbb0d27bb2e0be36d1b46862e9ce74c
include/fuse.h
include/fuse_common.h
include/fuse_kernel.h
lib/fuse.c
lib/fuse_lowlevel.c