mirror of
https://git.proxmox.com/git/mirror_zfs.git
synced 2026-05-22 02:27:36 +03:00
zfs_file: rename zfs_file_fallocate to zfs_file_deallocate
We only use it on a specific way: to punch a hole in (make sparse) a region of a file, in order to implement TRIM-like behaviour. So, call the op "deallocate", and move the Linux-style mode flags down into the Linux implementation, since they're an implementation detail. FreeBSD gets a no-op stub (for the moment). Sponsored-by: https://despairlabs.com/sponsor/ Reviewed by: Brian Behlendorf <behlendorf1@llnl.gov> Reviewed-by: Alexander Motin <mav@FreeBSD.org> Reviewed-by: Tino Reichardt <milky-zfs@mcmilk.de> Signed-off-by: Rob Norris <robn@despairlabs.com> Closes #16496
This commit is contained in:
committed by
Brian Behlendorf
parent
7cdfda3934
commit
fa330646b9
+13
-11
@@ -1367,24 +1367,26 @@ zfs_file_fsync(zfs_file_t *fp, int flags)
|
||||
}
|
||||
|
||||
/*
|
||||
* fallocate - allocate or free space on disk
|
||||
* deallocate - zero and/or deallocate file storage
|
||||
*
|
||||
* fp - file pointer
|
||||
* mode (non-standard options for hole punching etc)
|
||||
* offset - offset to start allocating or freeing from
|
||||
* len - length to free / allocate
|
||||
*
|
||||
* OPTIONAL
|
||||
* offset - offset to start zeroing or deallocating
|
||||
* len - length to zero or deallocate
|
||||
*/
|
||||
int
|
||||
zfs_file_fallocate(zfs_file_t *fp, int mode, loff_t offset, loff_t len)
|
||||
zfs_file_deallocate(zfs_file_t *fp, loff_t offset, loff_t len)
|
||||
{
|
||||
#ifdef __linux__
|
||||
return (fallocate(fp->f_fd, mode, offset, len));
|
||||
int rc;
|
||||
#if defined(__linux__)
|
||||
rc = fallocate(fp->f_fd,
|
||||
FALLOC_FL_PUNCH_HOLE | FALLOC_FL_KEEP_SIZE, offset, len);
|
||||
#else
|
||||
(void) fp, (void) mode, (void) offset, (void) len;
|
||||
return (EOPNOTSUPP);
|
||||
(void) fp, (void) offset, (void) len;
|
||||
rc = EOPNOTSUPP;
|
||||
#endif
|
||||
if (rc)
|
||||
return (SET_ERROR(rc));
|
||||
return (0);
|
||||
}
|
||||
|
||||
/*
|
||||
|
||||
Reference in New Issue
Block a user