diff options
author | Darrick J. Wong <darrick.wong@oracle.com> | 2017-01-09 10:38:54 -0500 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@linuxfoundation.org> | 2017-01-12 05:39:43 -0500 |
commit | cd4bf1d416ef199223fa41eb8225f2a137c0be99 (patch) | |
tree | e24c615465a29f532cac0a5e574923245f16c4c4 /fs | |
parent | b88398de18331ed448739866bf9fe3743e7c1bbf (diff) |
xfs: don't crash if reading a directory results in an unexpected hole
commit 96a3aefb8ffde23180130460b0b2407b328eb727 upstream.
In xfs_dir3_data_read, we can encounter the situation where err == 0 and
*bpp == NULL if the given bno offset happens to be a hole; this leads to
a crash if we try to set the buffer type after the _da_read_buf call.
Holes can happen due to corrupt or malicious entries in the bmbt data,
so be a little more careful when we're handling buffers.
Signed-off-by: Darrick J. Wong <darrick.wong@oracle.com>
Reviewed-by: Dave Chinner <dchinner@redhat.com>
Signed-off-by: Dave Chinner <david@fromorbit.com>
Cc: Christoph Hellwig <hch@lst.de>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'fs')
-rw-r--r-- | fs/xfs/libxfs/xfs_dir2_data.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/fs/xfs/libxfs/xfs_dir2_data.c b/fs/xfs/libxfs/xfs_dir2_data.c index 725fc7841fde..e526f5a5f0be 100644 --- a/fs/xfs/libxfs/xfs_dir2_data.c +++ b/fs/xfs/libxfs/xfs_dir2_data.c | |||
@@ -329,7 +329,7 @@ xfs_dir3_data_read( | |||
329 | 329 | ||
330 | err = xfs_da_read_buf(tp, dp, bno, mapped_bno, bpp, | 330 | err = xfs_da_read_buf(tp, dp, bno, mapped_bno, bpp, |
331 | XFS_DATA_FORK, &xfs_dir3_data_buf_ops); | 331 | XFS_DATA_FORK, &xfs_dir3_data_buf_ops); |
332 | if (!err && tp) | 332 | if (!err && tp && *bpp) |
333 | xfs_trans_buf_set_type(tp, *bpp, XFS_BLFT_DIR_DATA_BUF); | 333 | xfs_trans_buf_set_type(tp, *bpp, XFS_BLFT_DIR_DATA_BUF); |
334 | return err; | 334 | return err; |
335 | } | 335 | } |