xfs: switch to NOFS allocation under i_lock in xfs_readlink_bmap
xfs_readlink_bmap is called with i_lock held, but i_lock is taken in reclaim context so all allocations under it must avoid recursions into the filesystem. Reported by the new reclaim context tracing in lockdep. Signed-off-by: Christoph Hellwig <hch@lst.de> Reviewed-by: Felix Blyakher <felixb@sgi.com> Signed-off-by: Felix Blyakher <felixb@sgi.com>
This commit is contained in:
committed by
Felix Blyakher
parent
10746e47e7
commit
7b02ecb303
@@ -538,7 +538,9 @@ xfs_readlink_bmap(
|
|||||||
d = XFS_FSB_TO_DADDR(mp, mval[n].br_startblock);
|
d = XFS_FSB_TO_DADDR(mp, mval[n].br_startblock);
|
||||||
byte_cnt = XFS_FSB_TO_B(mp, mval[n].br_blockcount);
|
byte_cnt = XFS_FSB_TO_B(mp, mval[n].br_blockcount);
|
||||||
|
|
||||||
bp = xfs_buf_read(mp->m_ddev_targp, d, BTOBB(byte_cnt), 0);
|
bp = xfs_buf_read_flags(mp->m_ddev_targp, d, BTOBB(byte_cnt),
|
||||||
|
XBF_LOCK | XBF_MAPPED |
|
||||||
|
XBF_DONT_BLOCK);
|
||||||
error = XFS_BUF_GETERROR(bp);
|
error = XFS_BUF_GETERROR(bp);
|
||||||
if (error) {
|
if (error) {
|
||||||
xfs_ioerror_alert("xfs_readlink",
|
xfs_ioerror_alert("xfs_readlink",
|
||||||
|
Reference in New Issue
Block a user