Commit 2a0b4f64 authored by David Howells's avatar David Howells

afs: Don't invoke the server to read data beyond EOF

When writing a new page, clear space in the page rather than attempting to
load it from the server if the space is beyond the EOF.
Signed-off-by: default avatarDavid Howells <dhowells@redhat.com>
parent f51375cd
...@@ -33,10 +33,21 @@ static int afs_fill_page(struct afs_vnode *vnode, struct key *key, ...@@ -33,10 +33,21 @@ static int afs_fill_page(struct afs_vnode *vnode, struct key *key,
loff_t pos, unsigned int len, struct page *page) loff_t pos, unsigned int len, struct page *page)
{ {
struct afs_read *req; struct afs_read *req;
size_t p;
void *data;
int ret; int ret;
_enter(",,%llu", (unsigned long long)pos); _enter(",,%llu", (unsigned long long)pos);
if (pos >= vnode->vfs_inode.i_size) {
p = pos & ~PAGE_MASK;
ASSERTCMP(p + len, <=, PAGE_SIZE);
data = kmap(page);
memset(data + p, 0, len);
kunmap(page);
return 0;
}
req = kzalloc(sizeof(struct afs_read) + sizeof(struct page *), req = kzalloc(sizeof(struct afs_read) + sizeof(struct page *),
GFP_KERNEL); GFP_KERNEL);
if (!req) if (!req)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment