netfs: Implement unbuffered/DIO write support
Implement support for unbuffered writes and direct I/O writes. If the write is misaligned with respect to the fscrypt block size, then RMW cycles are performed if necessary. DIO writes are a special case of unbuffered writes with extra restriction imposed, such as block size alignment requirements. Also provide a field that can tell the code to add some extra space onto the bounce buffer for use by the filesystem in the case of a content-encrypted file. Signed-off-by: David Howells <dhowells@redhat.com> Reviewed-by: Jeff Layton <jlayton@kernel.org> cc: linux-cachefs@redhat.com cc: linux-fsdevel@vger.kernel.org cc: linux-mm@kvack.org
This commit is contained in:
@@ -20,8 +20,10 @@ struct netfs_io_request *netfs_alloc_request(struct address_space *mapping,
|
||||
struct inode *inode = file ? file_inode(file) : mapping->host;
|
||||
struct netfs_inode *ctx = netfs_inode(inode);
|
||||
struct netfs_io_request *rreq;
|
||||
bool is_dio = (origin == NETFS_DIO_READ);
|
||||
bool cached = is_dio && netfs_is_cache_enabled(ctx);
|
||||
bool is_unbuffered = (origin == NETFS_UNBUFFERED_WRITE ||
|
||||
origin == NETFS_DIO_READ ||
|
||||
origin == NETFS_DIO_WRITE);
|
||||
bool cached = !is_unbuffered && netfs_is_cache_enabled(ctx);
|
||||
int ret;
|
||||
|
||||
rreq = kzalloc(ctx->ops->io_request_size ?: sizeof(struct netfs_io_request),
|
||||
|
||||
Reference in New Issue
Block a user