diff options
author | Darrick J. Wong | 2020-10-01 10:56:07 -0700 |
---|---|---|
committer | Darrick J. Wong | 2020-10-07 08:40:29 -0700 |
commit | 8ffa90e1145c70c7ac47f14b59583b2296d89e72 (patch) | |
tree | 6c08e7444539ba7b0f809c86332805accda947c1 /fs/xfs/Kconfig | |
parent | acd1ac3aa22fd58803a12d26b1ab7f70232f8d8d (diff) |
xfs: fix deadlock and streamline xfs_getfsmap performance
Refactor xfs_getfsmap to improve its performance: instead of indirectly
calling a function that copies one record to userspace at a time, create
a shadow buffer in the kernel and copy the whole array once at the end.
On the author's computer, this reduces the runtime on his /home by ~20%.
This also eliminates a deadlock when running GETFSMAP against the
realtime device. The current code locks the rtbitmap to create
fsmappings and copies them into userspace, having not released the
rtbitmap lock. If the userspace buffer is an mmap of a sparse file that
itself resides on the realtime device, the write page fault will recurse
into the fs for allocation, which will deadlock on the rtbitmap lock.
Fixes: 4c934c7dd60c ("xfs: report realtime space information via the rtbitmap")
Signed-off-by: Darrick J. Wong <darrick.wong@oracle.com>
Reviewed-by: Christoph Hellwig <hch@lst.de>
Reviewed-by: Chandan Babu R <chandanrlinux@gmail.com>
Diffstat (limited to 'fs/xfs/Kconfig')
0 files changed, 0 insertions, 0 deletions