From: Al Viro Date: Tue, 6 Sep 2016 02:20:03 +0000 (-0400) Subject: fix ceph_write_end() X-Git-Tag: v4.10-rc1~57^2~2^2~4 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=b9de313cf05fe08fa59efaf19756ec5283af672a;p=platform%2Fkernel%2Flinux-exynos.git fix ceph_write_end() don't zero on short copies; if the page was uptodate it's just plain wrong, and if it wasn't we'll be better off just returning 0 and buggering off. Signed-off-by: Al Viro --- diff --git a/fs/ceph/addr.c b/fs/ceph/addr.c index ef3ebd7..834be09 100644 --- a/fs/ceph/addr.c +++ b/fs/ceph/addr.c @@ -1276,25 +1276,27 @@ static int ceph_write_end(struct file *file, struct address_space *mapping, struct page *page, void *fsdata) { struct inode *inode = file_inode(file); - unsigned from = pos & (PAGE_SIZE - 1); int check_cap = 0; dout("write_end file %p inode %p page %p %d~%d (%d)\n", file, inode, page, (int)pos, (int)copied, (int)len); /* zero the stale part of the page if we did a short copy */ - if (copied < len) - zero_user_segment(page, from+copied, len); + if (!PageUptodate(page)) { + if (copied < len) { + copied = 0; + goto out; + } + SetPageUptodate(page); + } /* did file size increase? */ if (pos+copied > i_size_read(inode)) check_cap = ceph_inode_set_size(inode, pos+copied); - if (!PageUptodate(page)) - SetPageUptodate(page); - set_page_dirty(page); +out: unlock_page(page); put_page(page);