gfs2: Make sure not to return short direct writes
authorAndreas Gruenbacher <agruenba@redhat.com>
Thu, 24 Mar 2022 22:13:26 +0000 (23:13 +0100)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Mon, 9 May 2022 07:14:39 +0000 (09:14 +0200)
commitb5afb477d2f8e1fa87af7d37ab22f6c619a20c63
treee9962d670507a75a3f3985946bc9fffc15e086fc
parentfe24959a79c9c036e377adaff44beee81a58d5ff
gfs2: Make sure not to return short direct writes

[ Upstream commit 3bde4c48586074202044456285a97ccdf9048988 ]

When direct writes fail with -ENOTBLK because we're writing into a
hole (gfs2_iomap_begin()) or because of a page invalidation failure
(iomap_dio_rw()), we're falling back to buffered writes.  In that case,
when we lose the inode glock in gfs2_file_buffered_write(), we want to
re-acquire it instead of returning a short write.

Signed-off-by: Andreas Gruenbacher <agruenba@redhat.com>
Signed-off-by: Sasha Levin <sashal@kernel.org>
fs/gfs2/file.c