xfs: map unwritten blocks in XFS_IOC_{ALLOC,FREE}SP just like fallocate
authorDarrick J. Wong <djwong@kernel.org>
Wed, 22 Dec 2021 22:19:18 +0000 (14:19 -0800)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Tue, 11 Jan 2022 12:57:36 +0000 (13:57 +0100)
commit 983d8e60f50806f90534cc5373d0ce867e5aaf79 upstream.

The old ALLOCSP/FREESP ioctls in XFS can be used to preallocate space at
the end of files, just like fallocate and RESVSP.  Make the behavior
consistent with the other ioctls.

Reported-by: Kirill Tkhai <ktkhai@virtuozzo.com>
Signed-off-by: Darrick J. Wong <djwong@kernel.org>
Signed-off-by: Darrick J. Wong <darrick.wong@oracle.com>
Reviewed-by: Dave Chinner <dchinner@redhat.com>
Reviewed-by: Eric Sandeen <sandeen@redhat.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
fs/xfs/xfs_ioctl.c

index 79a9a0def7dbdaa2dccc8058600fc96461ff5dc4..5b2b223f928580e2cff5174d26d96d413b685692 100644 (file)
@@ -715,7 +715,8 @@ xfs_ioc_space(
                flags |= XFS_PREALLOC_CLEAR;
                if (bf->l_start > XFS_ISIZE(ip)) {
                        error = xfs_alloc_file_space(ip, XFS_ISIZE(ip),
-                                       bf->l_start - XFS_ISIZE(ip), 0);
+                                       bf->l_start - XFS_ISIZE(ip),
+                                       XFS_BMAPI_PREALLOC);
                        if (error)
                                goto out_unlock;
                }