+15
−0
Loading
LOCALIO is an NFS loopback mount optimization that avoids using the network for READ, WRITE and COMMIT if the NFS client and server are determined to be on the same system. But because LOCALIO is still fundamentally "just NFS loopback mount" it is susceptible to recursion deadlock via direct reclaim, e.g.: NFS LOCALIO down to XFS and then back into NFS via nfs_writepages. Fix LOCALIO's potential for direct reclaim deadlock by ensuring that all its page cache allocations are done from GFP_NOFS context. Thanks to Ben Coddington for pointing out commit ad22c7a0 ("xfs: prevent stack overflows from page cache allocation"). Reported-by:John Cagle <john.cagle@hammerspace.com> Tested-by:
Allen Lu <allen.lu@hammerspace.com> Suggested-by:
Benjamin Coddington <bcodding@hammerspace.com> Fixes: 70ba381e ("nfs: add LOCALIO support") Signed-off-by:
Mike Snitzer <snitzer@hammerspace.com> Signed-off-by:
Anna Schumaker <anna.schumaker@oracle.com>