提交 c25d2467 编写于 作者: J Josef Bacik 提交者: Al Viro

XFS: handle hole punching via fallocate properly

This patch simply allows XFS to handle the hole punching flag in fallocate
properly.  I've tested this with a little program that does a bunch of random
hole punching with FL_KEEP_SIZE and without it to make sure it does the right
thing.  Thanks,
Signed-off-by: NJosef Bacik <josef@redhat.com>
Signed-off-by: NAl Viro <viro@zeniv.linux.org.uk>
上级 79124f18
...@@ -516,6 +516,7 @@ xfs_vn_fallocate( ...@@ -516,6 +516,7 @@ xfs_vn_fallocate(
loff_t new_size = 0; loff_t new_size = 0;
xfs_flock64_t bf; xfs_flock64_t bf;
xfs_inode_t *ip = XFS_I(inode); xfs_inode_t *ip = XFS_I(inode);
int cmd = XFS_IOC_RESVSP;
/* preallocation on directories not yet supported */ /* preallocation on directories not yet supported */
error = -ENODEV; error = -ENODEV;
...@@ -528,6 +529,9 @@ xfs_vn_fallocate( ...@@ -528,6 +529,9 @@ xfs_vn_fallocate(
xfs_ilock(ip, XFS_IOLOCK_EXCL); xfs_ilock(ip, XFS_IOLOCK_EXCL);
if (mode & FALLOC_FL_PUNCH_HOLE)
cmd = XFS_IOC_UNRESVSP;
/* check the new inode size is valid before allocating */ /* check the new inode size is valid before allocating */
if (!(mode & FALLOC_FL_KEEP_SIZE) && if (!(mode & FALLOC_FL_KEEP_SIZE) &&
offset + len > i_size_read(inode)) { offset + len > i_size_read(inode)) {
...@@ -537,8 +541,7 @@ xfs_vn_fallocate( ...@@ -537,8 +541,7 @@ xfs_vn_fallocate(
goto out_unlock; goto out_unlock;
} }
error = -xfs_change_file_space(ip, XFS_IOC_RESVSP, &bf, error = -xfs_change_file_space(ip, cmd, &bf, 0, XFS_ATTR_NOLOCK);
0, XFS_ATTR_NOLOCK);
if (error) if (error)
goto out_unlock; goto out_unlock;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册