]> git.baikalelectronics.ru Git - kernel.git/commitdiff
afs: Fix afs_write_end() when called with copied == 0 [ver #3]
authorDavid Howells <dhowells@redhat.com>
Sat, 14 Nov 2020 17:27:57 +0000 (17:27 +0000)
committerLinus Torvalds <torvalds@linux-foundation.org>
Sat, 14 Nov 2020 19:51:18 +0000 (11:51 -0800)
When afs_write_end() is called with copied == 0, it tries to set the
dirty region, but there's no way to actually encode a 0-length region in
the encoding in page->private.

"0,0", for example, indicates a 1-byte region at offset 0.  The maths
miscalculates this and sets it incorrectly.

Fix it to just do nothing but unlock and put the page in this case.  We
don't actually need to mark the page dirty as nothing presumably
changed.

Fixes: ecc194266698 ("afs: Alter dirty range encoding in page->private")
Signed-off-by: David Howells <dhowells@redhat.com>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
fs/afs/write.c

index 50371207f3273e9c6c1862b3792aad001aa4c2f5..c9195fc67fd8fc41dbe5614b04e3cd9a5f0e42dd 100644 (file)
@@ -169,11 +169,14 @@ int afs_write_end(struct file *file, struct address_space *mapping,
        unsigned int f, from = pos & (PAGE_SIZE - 1);
        unsigned int t, to = from + copied;
        loff_t i_size, maybe_i_size;
-       int ret;
+       int ret = 0;
 
        _enter("{%llx:%llu},{%lx}",
               vnode->fid.vid, vnode->fid.vnode, page->index);
 
+       if (copied == 0)
+               goto out;
+
        maybe_i_size = pos + copied;
 
        i_size = i_size_read(&vnode->vfs_inode);