fix gfs2_stuffed_write_end() on short copies
authorAl Viro <viro@zeniv.linux.org.uk>
Tue, 6 Sep 2016 02:06:35 +0000 (22:06 -0400)
committerAl Viro <viro@zeniv.linux.org.uk>
Sat, 10 Dec 2016 19:25:18 +0000 (14:25 -0500)
commit43388b21e72d36204822bcc3119e42abe6ebceef
treeaa7571d5dac86ec5826a88eb5fc2cf099a8236fc
parentb9de313cf05fe08fa59efaf19756ec5283af672a
fix gfs2_stuffed_write_end() on short copies

a) the page is uptodate - ->write_begin() would either fail (in which
case we don't reach ->write_end()), or unstuff the inode, or find the
page already uptodate, or do a successful call of stuffed_readpage(),
which would've made it uptodate

b) zeroing the tail in pagecache is wrong.  kill -9 at the right time
while writing unmodified file contents to the same file should _not_
leave us in a situation when read() from the file will be reporting
it full of zeroes.  Especially since that effect will be transient -
at some later point the page will be evicted and then we'll be back
to the real file contents.

Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
fs/gfs2/aops.c