Hi, Some workloads benefit from NFSD avoiding the page cache, particularly those with a working set that is significantly larger than available system memory. This patchset introduces _optional_ support to configure the use of O_DIRECT or DONTCACHE for NFSD's READ and WRITE support. The NFSD default to use page cache is left unchanged. This code has proven to work well during my testing. Any suggestions for further refinement are welcome. Thanks, Mike Changes since v8: - Remove a few WARN_ON_ONCE from the misaligned DIO READ and WRITE paths - pr_warn_ratelimited if EINVAL on misaligned READ and WRITE paths - handle DIO WRITE -ENOTBLK return by falling back to using buffered IO. - fix misaligned DIO READ to not use a start_extra_page - use /end/ of rq_pages for front_pad page - fix checkpatch warning about 'unsigned' in nfsd_iov_iter_aligned_bvec - fix NFSD debugfs interfaces to no longer use UNSPECIFIED state, explicitly default to NFSD_IO_BUFFERED - add Documentation/filesystems/nfs/nfsd-io-modes.rst Mike Snitzer (9): NFSD: filecache: add STATX_DIOALIGN and STATX_DIO_READ_ALIGN support NFSD: pass nfsd_file to nfsd_iter_read() NFSD: add io_cache_read controls to debugfs interface NFSD: add io_cache_write controls to debugfs interface NFSD: issue READs using O_DIRECT even if IO is misaligned NFSD: issue WRITEs using O_DIRECT even if IO is misaligned NFSD: add nfsd_analyze_read_dio and nfsd_analyze_write_dio trace events NFSD: add Documentation/filesystems/nfs/nfsd-io-modes.rst NFSD: use /end/ of rq_pages for misaligned DIO READ's start_extra page .../filesystems/nfs/nfsd-io-modes.rst | 144 ++++++ fs/nfsd/debugfs.c | 98 +++++ fs/nfsd/filecache.c | 32 ++ fs/nfsd/filecache.h | 4 + fs/nfsd/nfs4xdr.c | 8 +- fs/nfsd/nfsd.h | 10 + fs/nfsd/nfsfh.c | 4 + fs/nfsd/trace.h | 61 +++ fs/nfsd/vfs.c | 409 +++++++++++++++++- fs/nfsd/vfs.h | 2 +- include/linux/sunrpc/svc.h | 5 +- 11 files changed, 759 insertions(+), 18 deletions(-) create mode 100644 Documentation/filesystems/nfs/nfsd-io-modes.rst -- 2.44.0