Skip to content

Commit bfaa33b

Browse files
dhowellsbrauner
authored andcommitted
netfs: Provide an iterator-reset function
Provide a function to reset the iterator on a subrequest. Signed-off-by: David Howells <dhowells@redhat.com> cc: Jeff Layton <jlayton@kernel.org> cc: netfs@lists.linux.dev cc: linux-fsdevel@vger.kernel.org Link: https://lore.kernel.org/r/20240814203850.2240469-17-dhowells@redhat.com/ # v2 Signed-off-by: Christian Brauner <brauner@kernel.org>
1 parent cd0277e commit bfaa33b

File tree

4 files changed

+23
-8
lines changed

4 files changed

+23
-8
lines changed

fs/netfs/internal.h

Lines changed: 1 addition & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -69,6 +69,7 @@ int netfs_buffer_append_folio(struct netfs_io_request *rreq, struct folio *folio
6969
bool needs_put);
7070
struct folio_queue *netfs_delete_buffer_head(struct netfs_io_request *wreq);
7171
void netfs_clear_buffer(struct netfs_io_request *rreq);
72+
void netfs_reset_iter(struct netfs_io_subrequest *subreq);
7273

7374
/*
7475
* objects.c
@@ -161,9 +162,6 @@ struct netfs_io_request *netfs_create_write_req(struct address_space *mapping,
161162
void netfs_reissue_write(struct netfs_io_stream *stream,
162163
struct netfs_io_subrequest *subreq,
163164
struct iov_iter *source);
164-
int netfs_advance_write(struct netfs_io_request *wreq,
165-
struct netfs_io_stream *stream,
166-
loff_t start, size_t len, bool to_eof);
167165
struct netfs_io_request *netfs_begin_writethrough(struct kiocb *iocb, size_t len);
168166
int netfs_advance_writethrough(struct netfs_io_request *wreq, struct writeback_control *wbc,
169167
struct folio *folio, size_t copied, bool to_page_end,

fs/netfs/misc.c

Lines changed: 18 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -84,6 +84,24 @@ void netfs_clear_buffer(struct netfs_io_request *rreq)
8484
}
8585
}
8686

87+
/*
88+
* Reset the subrequest iterator to refer just to the region remaining to be
89+
* read. The iterator may or may not have been advanced by socket ops or
90+
* extraction ops to an extent that may or may not match the amount actually
91+
* read.
92+
*/
93+
void netfs_reset_iter(struct netfs_io_subrequest *subreq)
94+
{
95+
struct iov_iter *io_iter = &subreq->io_iter;
96+
size_t remain = subreq->len - subreq->transferred;
97+
98+
if (io_iter->count > remain)
99+
iov_iter_advance(io_iter, io_iter->count - remain);
100+
else if (io_iter->count < remain)
101+
iov_iter_revert(io_iter, remain - io_iter->count);
102+
iov_iter_truncate(&subreq->io_iter, remain);
103+
}
104+
87105
/**
88106
* netfs_dirty_folio - Mark folio dirty and pin a cache object for writeback
89107
* @mapping: The mapping the folio belongs to.

fs/netfs/write_collect.c

Lines changed: 1 addition & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -226,9 +226,8 @@ static void netfs_retry_write_stream(struct netfs_io_request *wreq,
226226
/* Determine the set of buffers we're going to use. Each
227227
* subreq gets a subset of a single overall contiguous buffer.
228228
*/
229+
netfs_reset_iter(from);
229230
source = from->io_iter;
230-
iov_iter_revert(&source, subreq->len - source.count);
231-
iov_iter_advance(&source, from->transferred);
232231
source.count = len;
233232

234233
/* Work through the sublist. */

fs/netfs/write_issue.c

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -261,9 +261,9 @@ static void netfs_issue_write(struct netfs_io_request *wreq,
261261
* we can avoid overrunning the credits obtained (cifs) and try to parallelise
262262
* content-crypto preparation with network writes.
263263
*/
264-
int netfs_advance_write(struct netfs_io_request *wreq,
265-
struct netfs_io_stream *stream,
266-
loff_t start, size_t len, bool to_eof)
264+
static int netfs_advance_write(struct netfs_io_request *wreq,
265+
struct netfs_io_stream *stream,
266+
loff_t start, size_t len, bool to_eof)
267267
{
268268
struct netfs_io_subrequest *subreq = stream->construct;
269269
size_t part;

0 commit comments

Comments
 (0)