|
@@ -1610,9 +1610,8 @@ xfs_filemap_pmd_fault(
|
|
|
/*
|
|
|
* pfn_mkwrite was originally inteneded to ensure we capture time stamp
|
|
|
* updates on write faults. In reality, it's need to serialise against
|
|
|
- * truncate similar to page_mkwrite. Hence we open-code dax_pfn_mkwrite()
|
|
|
- * here and cycle the XFS_MMAPLOCK_SHARED to ensure we serialise the fault
|
|
|
- * barrier in place.
|
|
|
+ * truncate similar to page_mkwrite. Hence we cycle the XFS_MMAPLOCK_SHARED
|
|
|
+ * to ensure we serialise the fault barrier in place.
|
|
|
*/
|
|
|
static int
|
|
|
xfs_filemap_pfn_mkwrite(
|
|
@@ -1635,6 +1634,8 @@ xfs_filemap_pfn_mkwrite(
|
|
|
size = (i_size_read(inode) + PAGE_SIZE - 1) >> PAGE_SHIFT;
|
|
|
if (vmf->pgoff >= size)
|
|
|
ret = VM_FAULT_SIGBUS;
|
|
|
+ else if (IS_DAX(inode))
|
|
|
+ ret = dax_pfn_mkwrite(vma, vmf);
|
|
|
xfs_iunlock(ip, XFS_MMAPLOCK_SHARED);
|
|
|
sb_end_pagefault(inode->i_sb);
|
|
|
return ret;
|