Skip to content

Commit c9c37e2

Browse files
author
Al Viro
committed
fuse: switch to iov_iter_get_pages()
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
1 parent d22a943 commit c9c37e2

File tree

1 file changed

+12
-21
lines changed

1 file changed

+12
-21
lines changed

fs/fuse/file.c

Lines changed: 12 additions & 21 deletions
Original file line numberDiff line numberDiff line change
@@ -1294,7 +1294,7 @@ static int fuse_get_user_pages(struct fuse_req *req, struct iov_iter *ii,
12941294
size_t nbytes = 0; /* # bytes already packed in req */
12951295

12961296
/* Special case for kernel I/O: can copy directly into the buffer */
1297-
if (segment_eq(get_fs(), KERNEL_DS)) {
1297+
if (ii->type & REQ_KERNEL) {
12981298
unsigned long user_addr = fuse_get_user_addr(ii);
12991299
size_t frag_size = fuse_get_frag_size(ii, *nbytesp);
13001300

@@ -1310,35 +1310,26 @@ static int fuse_get_user_pages(struct fuse_req *req, struct iov_iter *ii,
13101310

13111311
while (nbytes < *nbytesp && req->num_pages < req->max_pages) {
13121312
unsigned npages;
1313-
unsigned long user_addr = fuse_get_user_addr(ii);
1314-
unsigned offset = user_addr & ~PAGE_MASK;
1315-
size_t frag_size = fuse_get_frag_size(ii, *nbytesp - nbytes);
1316-
int ret;
1317-
1313+
size_t start, end, frag_size;
13181314
unsigned n = req->max_pages - req->num_pages;
1319-
frag_size = min_t(size_t, frag_size, n << PAGE_SHIFT);
1320-
1321-
npages = (frag_size + offset + PAGE_SIZE - 1) >> PAGE_SHIFT;
1322-
npages = clamp(npages, 1U, n);
1323-
1324-
ret = get_user_pages_fast(user_addr, npages, !write,
1325-
&req->pages[req->num_pages]);
1315+
ssize_t ret = iov_iter_get_pages(ii,
1316+
&req->pages[req->num_pages],
1317+
n * PAGE_SIZE, &start);
13261318
if (ret < 0)
13271319
return ret;
13281320

1329-
npages = ret;
1330-
frag_size = min_t(size_t, frag_size,
1331-
(npages << PAGE_SHIFT) - offset);
1332-
iov_iter_advance(ii, frag_size);
1321+
iov_iter_advance(ii, ret);
1322+
nbytes += ret;
13331323

1334-
req->page_descs[req->num_pages].offset = offset;
1324+
ret += start;
1325+
npages = (ret + PAGE_SIZE - 1) / PAGE_SIZE;
1326+
1327+
req->page_descs[req->num_pages].offset = start;
13351328
fuse_page_descs_length_init(req, req->num_pages, npages);
13361329

13371330
req->num_pages += npages;
13381331
req->page_descs[req->num_pages - 1].length -=
1339-
(npages << PAGE_SHIFT) - offset - frag_size;
1340-
1341-
nbytes += frag_size;
1332+
(PAGE_SIZE - ret) & (PAGE_SIZE - 1);
13421333
}
13431334

13441335
if (write)

0 commit comments

Comments
 (0)