Re: [RFC PATCH 0/4] xfs: add handle for reflink in dax

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 





On 4/17/19 9:34 AM, Darrick J. Wong wrote:
On Wed, Apr 18, 2019 at 09:27:11AM +0800, Shiyang Ruan wrote:
In XFS (under fsdax mode), reflink did not work correctly because xfs
iomap operators did not handle the inode with both reflink and dax flag.

This patchset aims to take care of this issue to make COW operation work
correctly in XFS.

XFS uses iomap to do read/write/mmap operations:
   vfs interface       xfs:
     iomap_bengin();     --> xfs_iomap_begin();
     actor();            --> dax_iomap_actor() / mmap actor function
     iomap_end();        --> xfs_iomap_end();

In xfs_iomap_begin(), COW operation is detected but not told to actor
function.  To resolve this, a new field 'src_addr' is added into
'struct iomap' to pass this COW info.  It means the start address of
source blocks in a COW operation, for actor functions to copy data
before writing.

In actor functions, the value of iomap->src_addr determines if it is a
COW operation.  If it is, copy data from source blocks to destination
blocks first, and then write user data.

After the COW operation, it is supposed to update the metadata of the
inode.  Added in xfs_iomap_end().

How do the fs/iomap.c changes in your series compare with Goldwyn's
"btrfs dax support" series that he put out today?
Sorry, I think I missed his series.  Will check it right now.

Also, there are a few things missing:

1. A DAX-compatible file contents comparison function for the dedupe
ioctl.

2. Checks that we aren't trying to reflink or dedupe between S_DAX and
!S_DAX files.

3. Do we need to make changes to the hairy
xfs_iolock_two_inodes_and_break_layout function to handle DAX?  Seeing
as it doesn't call xfs_break_dax_layouts...
Thanks for your comments. I did not think carefully about 'dedupe'. Will take this into consideration.

--
Thanks,
Shiyang Ruan.

--D



Shiyang Ruan (4):
   fs/iomap: Introduce src_addr for COW in fsdax mode.
   fs/xfs: iomap: add handle for reflink in fsdax mode
   fs/dax: copy source blocks before writing when COW
   fs/xfs: iomap: update the extent list after a COW

  fs/dax.c              | 70 +++++++++++++++++++++++++++++++++++++++++++
  fs/xfs/xfs_iomap.c    | 23 +++++++++++---
  include/linux/iomap.h |  4 +++
  3 files changed, 93 insertions(+), 4 deletions(-)

--
2.17.0










[Index of Archives]     [XFS Filesystem Development (older mail)]     [Linux Filesystem Development]     [Linux Audio Users]     [Yosemite Trails]     [Linux Kernel]     [Linux RAID]     [Linux SCSI]


  Powered by Linux