]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
xfs: add missing error check in xfs_prepare_shift()
authorBrian Foster <bfoster@redhat.com>
Fri, 26 Apr 2019 14:30:24 +0000 (07:30 -0700)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Fri, 13 Dec 2019 07:52:57 +0000 (08:52 +0100)
commit 1749d1ea89bdf3181328b7d846e609d5a0e53e50 upstream.

xfs_prepare_shift() fails to check the error return from
xfs_flush_unmap_range(). If the latter fails, that could lead to an
insert/collapse range operation over a delalloc range, which is not
supported.

Add an error check and return appropriately. This is reproduced
rarely by generic/475.

Fixes: 7f9f71be84bc ("xfs: extent shifting doesn't fully invalidate page cache")
Signed-off-by: Brian Foster <bfoster@redhat.com>
Reviewed-by: Darrick J. Wong <darrick.wong@oracle.com>
Signed-off-by: Darrick J. Wong <darrick.wong@oracle.com>
Reviewed-by: Allison Collins <allison.henderson@oracle.com>
Reviewed-by: Dave Chinner <dchinner@redhat.com>
Cc: Nobuhiro Iwamatsu <nobuhiro1.iwamatsu@toshiba.co.jp>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
fs/xfs/xfs_bmap_util.c

index c045723678be9fc2e57a95013d3bb44e2267ded2..e638740f16813ba069971755ab97f96849bb8db0 100644 (file)
@@ -1245,6 +1245,8 @@ xfs_prepare_shift(
         * about to shift down every extent from offset to EOF.
         */
        error = xfs_flush_unmap_range(ip, offset, XFS_ISIZE(ip));
+       if (error)
+               return error;
 
        /*
         * Clean out anything hanging around in the cow fork now that