xfs
[Top] [All Lists]

[PATCH v2 3/5] xfs: call dax_get_unmapped_area() for DAX pmd mappings

To: akpm@xxxxxxxxxxxxxxxxxxxx, dan.j.williams@xxxxxxxxx
Subject: [PATCH v2 3/5] xfs: call dax_get_unmapped_area() for DAX pmd mappings
From: Toshi Kani <toshi.kani@xxxxxxx>
Date: Tue, 12 Apr 2016 14:39:30 -0600
Cc: linux-nvdimm@xxxxxxxxxxxx, linux-fsdevel@xxxxxxxxxxxxxxx, linux-kernel@xxxxxxxxxxxxxxx, Toshi Kani <toshi.kani@xxxxxxx>, Dave Chinner <david@xxxxxxxxxxxxx>, Matthew Wilcox <willy@xxxxxxxxxxxxxxx>, Ross Zwisler <ross.zwisler@xxxxxxxxxxxxxxx>, <xfs@xxxxxxxxxxx>
Delivered-to: xfs@xxxxxxxxxxx
In-reply-to: <1460493572-31667-1-git-send-email-toshi.kani@xxxxxxx>
References: <1460493572-31667-1-git-send-email-toshi.kani@xxxxxxx>
To support DAX pmd mappings with unmodified applications,
filesystems need to align an mmap address by the pmd size.

Call dax_get_unmapped_area() from f_op->get_unmapped_area.

Note, there is no change in behavior for a non-DAX file.

Signed-off-by: Toshi Kani <toshi.kani@xxxxxxx>
Cc: Dave Chinner <david@xxxxxxxxxxxxx>
Cc: Dan Williams <dan.j.williams@xxxxxxxxx>
Cc: Matthew Wilcox <willy@xxxxxxxxxxxxxxx>
Cc: Ross Zwisler <ross.zwisler@xxxxxxxxxxxxxxx>
Cc: <xfs@xxxxxxxxxxx>
---
 fs/xfs/xfs_file.c |    3 +++
 1 file changed, 3 insertions(+)

diff --git a/fs/xfs/xfs_file.c b/fs/xfs/xfs_file.c
index 569938a..51c554b 100644
--- a/fs/xfs/xfs_file.c
+++ b/fs/xfs/xfs_file.c
@@ -1708,6 +1708,9 @@ const struct file_operations xfs_file_operations = {
        .open           = xfs_file_open,
        .release        = xfs_file_release,
        .fsync          = xfs_file_fsync,
+#ifdef CONFIG_FS_DAX
+       .get_unmapped_area = dax_get_unmapped_area,
+#endif
        .fallocate      = xfs_file_fallocate,
 };
 

<Prev in Thread] Current Thread [Next in Thread>
  • [PATCH v2 3/5] xfs: call dax_get_unmapped_area() for DAX pmd mappings, Toshi Kani <=