aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--fs/fuse/file.c7
1 files changed, 3 insertions, 4 deletions
diff --git a/fs/fuse/file.c b/fs/fuse/file.c
index 2ca86141d13a..18aafa6c9af4 100644
--- a/fs/fuse/file.c
+++ b/fs/fuse/file.c
@@ -272,7 +272,6 @@ static int fuse_readpage(struct file *file, struct page *page)
272{ 272{
273 struct inode *inode = page->mapping->host; 273 struct inode *inode = page->mapping->host;
274 struct fuse_conn *fc = get_fuse_conn(inode); 274 struct fuse_conn *fc = get_fuse_conn(inode);
275 loff_t pos = (loff_t) page->index << PAGE_CACHE_SHIFT;
276 struct fuse_req *req = fuse_get_request(fc); 275 struct fuse_req *req = fuse_get_request(fc);
277 int err = -EINTR; 276 int err = -EINTR;
278 if (!req) 277 if (!req)
@@ -281,7 +280,7 @@ static int fuse_readpage(struct file *file, struct page *page)
281 req->out.page_zeroing = 1; 280 req->out.page_zeroing = 1;
282 req->num_pages = 1; 281 req->num_pages = 1;
283 req->pages[0] = page; 282 req->pages[0] = page;
284 fuse_send_read(req, file, inode, pos, PAGE_CACHE_SIZE); 283 fuse_send_read(req, file, inode, page_offset(page), PAGE_CACHE_SIZE);
285 err = req->out.h.error; 284 err = req->out.h.error;
286 fuse_put_request(fc, req); 285 fuse_put_request(fc, req);
287 if (!err) 286 if (!err)
@@ -295,7 +294,7 @@ static int fuse_readpage(struct file *file, struct page *page)
295static int fuse_send_readpages(struct fuse_req *req, struct file *file, 294static int fuse_send_readpages(struct fuse_req *req, struct file *file,
296 struct inode *inode) 295 struct inode *inode)
297{ 296{
298 loff_t pos = (loff_t) req->pages[0]->index << PAGE_CACHE_SHIFT; 297 loff_t pos = page_offset(req->pages[0]);
299 size_t count = req->num_pages << PAGE_CACHE_SHIFT; 298 size_t count = req->num_pages << PAGE_CACHE_SHIFT;
300 unsigned i; 299 unsigned i;
301 req->out.page_zeroing = 1; 300 req->out.page_zeroing = 1;
@@ -402,7 +401,7 @@ static int fuse_commit_write(struct file *file, struct page *page,
402 unsigned count = to - offset; 401 unsigned count = to - offset;
403 struct inode *inode = page->mapping->host; 402 struct inode *inode = page->mapping->host;
404 struct fuse_conn *fc = get_fuse_conn(inode); 403 struct fuse_conn *fc = get_fuse_conn(inode);
405 loff_t pos = ((loff_t) page->index << PAGE_CACHE_SHIFT) + offset; 404 loff_t pos = page_offset(page) + offset;
406 struct fuse_req *req = fuse_get_request(fc); 405 struct fuse_req *req = fuse_get_request(fc);
407 if (!req) 406 if (!req)
408 return -EINTR; 407 return -EINTR;