Commit 64485437 authored by Dave Chinner's avatar Dave Chinner Committed by Dave Chinner

xfs: XFS_DIFLAG2_DAX limited by PAGE_SIZE

If the block size of a filesystem is not at least PAGE_SIZEd, then
at this point in time DAX cannot be used due to the fact we can't
guarantee extents are page sized or aligned without further work.
Hence disallow setting the DAX flag on an inode if the block size is
too small. Also, be defensive and check the block size when reading
an inode in off disk.

In future, we want to allow DAX to work on any filesystem, so this
is temporary while we sort of the correct conbination of extent size
hints and allocation alignment configurations needed to guarantee
page sized and aligned extent allocation for DAX enabled files.
Signed-off-by: default avatarDave Chinner <dchinner@redhat.com>
Reviewed-by: default avatarBrian Foster <bfoster@redhat.com>
Tested-by: default avatarRoss Zwisler <ross.zwisler@linux.intel.com>
Signed-off-by: default avatarDave Chinner <david@fromorbit.com>
parent 3a6a854a
...@@ -1080,11 +1080,15 @@ xfs_ioctl_setattr_dax_invalidate( ...@@ -1080,11 +1080,15 @@ xfs_ioctl_setattr_dax_invalidate(
/* /*
* It is only valid to set the DAX flag on regular files and * It is only valid to set the DAX flag on regular files and
* directories. On directories it serves as an inherit hint. * directories on filesystems where the block size is equal to the page
* size. On directories it serves as an inherit hint.
*/ */
if ((fa->fsx_xflags & FS_XFLAG_DAX) && if (fa->fsx_xflags & FS_XFLAG_DAX) {
!(S_ISREG(inode->i_mode) || S_ISDIR(inode->i_mode))) if (!(S_ISREG(inode->i_mode) || S_ISDIR(inode->i_mode)))
return -EINVAL; return -EINVAL;
if (ip->i_mount->m_sb.sb_blocksize != PAGE_SIZE)
return -EINVAL;
}
/* If the DAX state is not changing, we have nothing to do here. */ /* If the DAX state is not changing, we have nothing to do here. */
if ((fa->fsx_xflags & FS_XFLAG_DAX) && IS_DAX(inode)) if ((fa->fsx_xflags & FS_XFLAG_DAX) && IS_DAX(inode))
......
...@@ -1206,6 +1206,7 @@ xfs_diflags_to_iflags( ...@@ -1206,6 +1206,7 @@ xfs_diflags_to_iflags(
if (flags & XFS_DIFLAG_NOATIME) if (flags & XFS_DIFLAG_NOATIME)
inode->i_flags |= S_NOATIME; inode->i_flags |= S_NOATIME;
if (S_ISREG(inode->i_mode) && if (S_ISREG(inode->i_mode) &&
ip->i_mount->m_sb.sb_blocksize == PAGE_SIZE &&
(ip->i_mount->m_flags & XFS_MOUNT_DAX || (ip->i_mount->m_flags & XFS_MOUNT_DAX ||
ip->i_d.di_flags2 & XFS_DIFLAG2_DAX)) ip->i_d.di_flags2 & XFS_DIFLAG2_DAX))
inode->i_flags |= S_DAX; inode->i_flags |= S_DAX;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment