summaryrefslogtreecommitdiffstats
path: root/fs/xfs/xfs_pnfs.c
diff options
context:
space:
mode:
authorDarrick J. Wong <darrick.wong@oracle.com>2019-08-15 02:38:09 +0200
committerDarrick J. Wong <darrick.wong@oracle.com>2019-08-19 03:53:25 +0200
commit5d888b481e6abc726b36c86f0bf13af1583bb336 (patch)
tree902c57ac0fe14c9693ab36bd943de335eb23fc6d /fs/xfs/xfs_pnfs.c
parentvfs: fix page locking deadlocks when deduping files (diff)
downloadlinux-5d888b481e6abc726b36c86f0bf13af1583bb336.tar.xz
linux-5d888b481e6abc726b36c86f0bf13af1583bb336.zip
xfs: fix reflink source file racing with directio writes
While trawling through the dedupe file comparison code trying to fix page deadlocking problems, Dave Chinner noticed that the reflink code only takes shared IOLOCK/MMAPLOCKs on the source file. Because page_mkwrite and directio writes do not take the EXCL versions of those locks, this means that reflink can race with writer processes. For pure remapping this can lead to undefined behavior and file corruption; for dedupe this means that we cannot be sure that the contents are identical when we decide to go ahead with the remapping. Signed-off-by: Darrick J. Wong <darrick.wong@oracle.com> Reviewed-by: Christoph Hellwig <hch@lst.de>
Diffstat (limited to 'fs/xfs/xfs_pnfs.c')
0 files changed, 0 insertions, 0 deletions