aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMiklos Szeredi <mszeredi@redhat.com>2018-03-20 12:11:45 -0400
committerMiklos Szeredi <mszeredi@redhat.com>2018-03-20 12:11:45 -0400
commit5ba24197b94d4070d8c2a17fa4944a55cc39ef03 (patch)
treea7caddbfaf56813c2495ed2dce2e9139a1192c9f
parentbf5c1898bf9e6d5ce9840743e8eccc74c14d16a4 (diff)
fuse: add writeback documentation
Document various modes of I/O supported by the fuse kernel module. Signed-off-by: Miklos Szeredi <mszeredi@redhat.com>
-rw-r--r--Documentation/filesystems/fuse-io.txt38
1 files changed, 38 insertions, 0 deletions
diff --git a/Documentation/filesystems/fuse-io.txt b/Documentation/filesystems/fuse-io.txt
new file mode 100644
index 000000000000..07b8f73f100f
--- /dev/null
+++ b/Documentation/filesystems/fuse-io.txt
@@ -0,0 +1,38 @@
1Fuse supports the following I/O modes:
2
3- direct-io
4- cached
5 + write-through
6 + writeback-cache
7
8The direct-io mode can be selected with the FOPEN_DIRECT_IO flag in the
9FUSE_OPEN reply.
10
11In direct-io mode the page cache is completely bypassed for reads and writes.
12No read-ahead takes place. Shared mmap is disabled.
13
14In cached mode reads may be satisfied from the page cache, and data may be
15read-ahead by the kernel to fill the cache. The cache is always kept consistent
16after any writes to the file. All mmap modes are supported.
17
18The cached mode has two sub modes controlling how writes are handled. The
19write-through mode is the default and is supported on all kernels. The
20writeback-cache mode may be selected by the FUSE_WRITEBACK_CACHE flag in the
21FUSE_INIT reply.
22
23In write-through mode each write is immediately sent to userspace as one or more
24WRITE requests, as well as updating any cached pages (and caching previously
25uncached, but fully written pages). No READ requests are ever sent for writes,
26so when an uncached page is partially written, the page is discarded.
27
28In writeback-cache mode (enabled by the FUSE_WRITEBACK_CACHE flag) writes go to
29the cache only, which means that the write(2) syscall can often complete very
30fast. Dirty pages are written back implicitly (background writeback or page
31reclaim on memory pressure) or explicitly (invoked by close(2), fsync(2) and
32when the last ref to the file is being released on munmap(2)). This mode
33assumes that all changes to the filesystem go through the FUSE kernel module
34(size and atime/ctime/mtime attributes are kept up-to-date by the kernel), so
35it's generally not suitable for network filesystems. If a partial page is
36written, then the page needs to be first read from userspace. This means, that
37even for files opened for O_WRONLY it is possible that READ requests will be
38generated by the kernel.