mirror of
https://git.proxmox.com/git/mirror_zfs.git
synced 2025-10-24 08:55:00 +03:00
config: remove HAVE_VFS_FILE_OPERATIONS_EXTEND
Sponsored-by: https://despairlabs.com/sponsor/ Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov> Reviewed-by: Tony Hutter <hutter2@llnl.gov> Reviewed-by: Tino Reichardt <milky-zfs@mcmilk.de> Signed-off-by: Rob Norris <robn@despairlabs.com> Closes #16479
This commit is contained in:
parent
d29ed3630e
commit
49f449c865
@ -1,50 +0,0 @@
|
|||||||
dnl #
|
|
||||||
dnl # EL7 have backported copy_file_range and clone_file_range and
|
|
||||||
dnl # added them to an "extended" file_operations struct.
|
|
||||||
dnl #
|
|
||||||
dnl # We're testing for both functions in one here, because they will only
|
|
||||||
dnl # ever appear together and we don't want to match a similar method in
|
|
||||||
dnl # some future vendor kernel.
|
|
||||||
dnl #
|
|
||||||
AC_DEFUN([ZFS_AC_KERNEL_SRC_VFS_FILE_OPERATIONS_EXTEND], [
|
|
||||||
ZFS_LINUX_TEST_SRC([vfs_file_operations_extend], [
|
|
||||||
#include <linux/fs.h>
|
|
||||||
|
|
||||||
static ssize_t test_copy_file_range(struct file *src_file,
|
|
||||||
loff_t src_off, struct file *dst_file, loff_t dst_off,
|
|
||||||
size_t len, unsigned int flags) {
|
|
||||||
(void) src_file; (void) src_off;
|
|
||||||
(void) dst_file; (void) dst_off;
|
|
||||||
(void) len; (void) flags;
|
|
||||||
return (0);
|
|
||||||
}
|
|
||||||
|
|
||||||
static int test_clone_file_range(struct file *src_file,
|
|
||||||
loff_t src_off, struct file *dst_file, loff_t dst_off,
|
|
||||||
u64 len) {
|
|
||||||
(void) src_file; (void) src_off;
|
|
||||||
(void) dst_file; (void) dst_off;
|
|
||||||
(void) len;
|
|
||||||
return (0);
|
|
||||||
}
|
|
||||||
|
|
||||||
static const struct file_operations_extend
|
|
||||||
fops __attribute__ ((unused)) = {
|
|
||||||
.kabi_fops = {},
|
|
||||||
.copy_file_range = test_copy_file_range,
|
|
||||||
.clone_file_range = test_clone_file_range,
|
|
||||||
};
|
|
||||||
],[])
|
|
||||||
])
|
|
||||||
AC_DEFUN([ZFS_AC_KERNEL_VFS_FILE_OPERATIONS_EXTEND], [
|
|
||||||
AC_MSG_CHECKING([whether file_operations_extend takes \
|
|
||||||
.copy_file_range() and .clone_file_range()])
|
|
||||||
ZFS_LINUX_TEST_RESULT([vfs_file_operations_extend], [
|
|
||||||
AC_MSG_RESULT([yes])
|
|
||||||
AC_DEFINE(HAVE_VFS_FILE_OPERATIONS_EXTEND, 1,
|
|
||||||
[file_operations_extend takes .copy_file_range()
|
|
||||||
and .clone_file_range()])
|
|
||||||
],[
|
|
||||||
AC_MSG_RESULT([no])
|
|
||||||
])
|
|
||||||
])
|
|
@ -107,7 +107,6 @@ AC_DEFUN([ZFS_AC_KERNEL_TEST_SRC], [
|
|||||||
ZFS_AC_KERNEL_SRC_VFS_REMAP_FILE_RANGE
|
ZFS_AC_KERNEL_SRC_VFS_REMAP_FILE_RANGE
|
||||||
ZFS_AC_KERNEL_SRC_VFS_CLONE_FILE_RANGE
|
ZFS_AC_KERNEL_SRC_VFS_CLONE_FILE_RANGE
|
||||||
ZFS_AC_KERNEL_SRC_VFS_DEDUPE_FILE_RANGE
|
ZFS_AC_KERNEL_SRC_VFS_DEDUPE_FILE_RANGE
|
||||||
ZFS_AC_KERNEL_SRC_VFS_FILE_OPERATIONS_EXTEND
|
|
||||||
ZFS_AC_KERNEL_SRC_KMAP_ATOMIC_ARGS
|
ZFS_AC_KERNEL_SRC_KMAP_ATOMIC_ARGS
|
||||||
ZFS_AC_KERNEL_SRC_KMAP_LOCAL_PAGE
|
ZFS_AC_KERNEL_SRC_KMAP_LOCAL_PAGE
|
||||||
ZFS_AC_KERNEL_SRC_FOLLOW_DOWN_ONE
|
ZFS_AC_KERNEL_SRC_FOLLOW_DOWN_ONE
|
||||||
@ -243,7 +242,6 @@ AC_DEFUN([ZFS_AC_KERNEL_TEST_RESULT], [
|
|||||||
ZFS_AC_KERNEL_VFS_REMAP_FILE_RANGE
|
ZFS_AC_KERNEL_VFS_REMAP_FILE_RANGE
|
||||||
ZFS_AC_KERNEL_VFS_CLONE_FILE_RANGE
|
ZFS_AC_KERNEL_VFS_CLONE_FILE_RANGE
|
||||||
ZFS_AC_KERNEL_VFS_DEDUPE_FILE_RANGE
|
ZFS_AC_KERNEL_VFS_DEDUPE_FILE_RANGE
|
||||||
ZFS_AC_KERNEL_VFS_FILE_OPERATIONS_EXTEND
|
|
||||||
ZFS_AC_KERNEL_KMAP_ATOMIC_ARGS
|
ZFS_AC_KERNEL_KMAP_ATOMIC_ARGS
|
||||||
ZFS_AC_KERNEL_KMAP_LOCAL_PAGE
|
ZFS_AC_KERNEL_KMAP_LOCAL_PAGE
|
||||||
ZFS_AC_KERNEL_FOLLOW_DOWN_ONE
|
ZFS_AC_KERNEL_FOLLOW_DOWN_ONE
|
||||||
|
@ -52,11 +52,7 @@ extern const struct inode_operations zpl_special_inode_operations;
|
|||||||
|
|
||||||
/* zpl_file.c */
|
/* zpl_file.c */
|
||||||
extern const struct address_space_operations zpl_address_space_operations;
|
extern const struct address_space_operations zpl_address_space_operations;
|
||||||
#ifdef HAVE_VFS_FILE_OPERATIONS_EXTEND
|
|
||||||
extern const struct file_operations_extend zpl_file_operations;
|
|
||||||
#else
|
|
||||||
extern const struct file_operations zpl_file_operations;
|
extern const struct file_operations zpl_file_operations;
|
||||||
#endif
|
|
||||||
extern const struct file_operations zpl_dir_file_operations;
|
extern const struct file_operations zpl_dir_file_operations;
|
||||||
|
|
||||||
/* zpl_super.c */
|
/* zpl_super.c */
|
||||||
|
@ -2020,9 +2020,6 @@ zfs_init(void)
|
|||||||
zfs_znode_init();
|
zfs_znode_init();
|
||||||
dmu_objset_register_type(DMU_OST_ZFS, zpl_get_file_info);
|
dmu_objset_register_type(DMU_OST_ZFS, zpl_get_file_info);
|
||||||
register_filesystem(&zpl_fs_type);
|
register_filesystem(&zpl_fs_type);
|
||||||
#ifdef HAVE_VFS_FILE_OPERATIONS_EXTEND
|
|
||||||
register_fo_extend(&zpl_file_operations);
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
@ -2033,9 +2030,6 @@ zfs_fini(void)
|
|||||||
*/
|
*/
|
||||||
taskq_wait(system_delay_taskq);
|
taskq_wait(system_delay_taskq);
|
||||||
taskq_wait(system_taskq);
|
taskq_wait(system_taskq);
|
||||||
#ifdef HAVE_VFS_FILE_OPERATIONS_EXTEND
|
|
||||||
unregister_fo_extend(&zpl_file_operations);
|
|
||||||
#endif
|
|
||||||
unregister_filesystem(&zpl_fs_type);
|
unregister_filesystem(&zpl_fs_type);
|
||||||
zfs_znode_fini();
|
zfs_znode_fini();
|
||||||
zfsctl_fini();
|
zfsctl_fini();
|
||||||
|
@ -415,11 +415,7 @@ zfs_inode_set_ops(zfsvfs_t *zfsvfs, struct inode *ip)
|
|||||||
switch (ip->i_mode & S_IFMT) {
|
switch (ip->i_mode & S_IFMT) {
|
||||||
case S_IFREG:
|
case S_IFREG:
|
||||||
ip->i_op = &zpl_inode_operations;
|
ip->i_op = &zpl_inode_operations;
|
||||||
#ifdef HAVE_VFS_FILE_OPERATIONS_EXTEND
|
|
||||||
ip->i_fop = &zpl_file_operations.kabi_fops;
|
|
||||||
#else
|
|
||||||
ip->i_fop = &zpl_file_operations;
|
ip->i_fop = &zpl_file_operations;
|
||||||
#endif
|
|
||||||
ip->i_mapping->a_ops = &zpl_address_space_operations;
|
ip->i_mapping->a_ops = &zpl_address_space_operations;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
@ -459,11 +455,7 @@ zfs_inode_set_ops(zfsvfs_t *zfsvfs, struct inode *ip)
|
|||||||
/* Assume the inode is a file and attempt to continue */
|
/* Assume the inode is a file and attempt to continue */
|
||||||
ip->i_mode = S_IFREG | 0644;
|
ip->i_mode = S_IFREG | 0644;
|
||||||
ip->i_op = &zpl_inode_operations;
|
ip->i_op = &zpl_inode_operations;
|
||||||
#ifdef HAVE_VFS_FILE_OPERATIONS_EXTEND
|
|
||||||
ip->i_fop = &zpl_file_operations.kabi_fops;
|
|
||||||
#else
|
|
||||||
ip->i_fop = &zpl_file_operations;
|
ip->i_fop = &zpl_file_operations;
|
||||||
#endif
|
|
||||||
ip->i_mapping->a_ops = &zpl_address_space_operations;
|
ip->i_mapping->a_ops = &zpl_address_space_operations;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -1126,12 +1126,7 @@ const struct address_space_operations zpl_address_space_operations = {
|
|||||||
#endif
|
#endif
|
||||||
};
|
};
|
||||||
|
|
||||||
#ifdef HAVE_VFS_FILE_OPERATIONS_EXTEND
|
|
||||||
const struct file_operations_extend zpl_file_operations = {
|
|
||||||
.kabi_fops = {
|
|
||||||
#else
|
|
||||||
const struct file_operations zpl_file_operations = {
|
const struct file_operations zpl_file_operations = {
|
||||||
#endif
|
|
||||||
.open = zpl_open,
|
.open = zpl_open,
|
||||||
.release = zpl_release,
|
.release = zpl_release,
|
||||||
.llseek = zpl_llseek,
|
.llseek = zpl_llseek,
|
||||||
@ -1170,11 +1165,6 @@ const struct file_operations zpl_file_operations = {
|
|||||||
#ifdef CONFIG_COMPAT
|
#ifdef CONFIG_COMPAT
|
||||||
.compat_ioctl = zpl_compat_ioctl,
|
.compat_ioctl = zpl_compat_ioctl,
|
||||||
#endif
|
#endif
|
||||||
#ifdef HAVE_VFS_FILE_OPERATIONS_EXTEND
|
|
||||||
}, /* kabi_fops */
|
|
||||||
.copy_file_range = zpl_copy_file_range,
|
|
||||||
.clone_file_range = zpl_clone_file_range,
|
|
||||||
#endif
|
|
||||||
};
|
};
|
||||||
|
|
||||||
const struct file_operations zpl_dir_file_operations = {
|
const struct file_operations zpl_dir_file_operations = {
|
||||||
|
@ -83,8 +83,7 @@ zpl_clone_file_range_impl(struct file *src_file, loff_t src_off,
|
|||||||
return ((ssize_t)len_o);
|
return ((ssize_t)len_o);
|
||||||
}
|
}
|
||||||
|
|
||||||
#if defined(HAVE_VFS_COPY_FILE_RANGE) || \
|
#if defined(HAVE_VFS_COPY_FILE_RANGE)
|
||||||
defined(HAVE_VFS_FILE_OPERATIONS_EXTEND)
|
|
||||||
/*
|
/*
|
||||||
* Entry point for copy_file_range(). Copy len bytes from src_off in src_file
|
* Entry point for copy_file_range(). Copy len bytes from src_off in src_file
|
||||||
* to dst_off in dst_file. We are permitted to do this however we like, so we
|
* to dst_off in dst_file. We are permitted to do this however we like, so we
|
||||||
@ -134,7 +133,7 @@ zpl_copy_file_range(struct file *src_file, loff_t src_off,
|
|||||||
|
|
||||||
return (ret);
|
return (ret);
|
||||||
}
|
}
|
||||||
#endif /* HAVE_VFS_COPY_FILE_RANGE || HAVE_VFS_FILE_OPERATIONS_EXTEND */
|
#endif /* HAVE_VFS_COPY_FILE_RANGE */
|
||||||
|
|
||||||
#ifdef HAVE_VFS_REMAP_FILE_RANGE
|
#ifdef HAVE_VFS_REMAP_FILE_RANGE
|
||||||
/*
|
/*
|
||||||
@ -179,8 +178,7 @@ zpl_remap_file_range(struct file *src_file, loff_t src_off,
|
|||||||
}
|
}
|
||||||
#endif /* HAVE_VFS_REMAP_FILE_RANGE */
|
#endif /* HAVE_VFS_REMAP_FILE_RANGE */
|
||||||
|
|
||||||
#if defined(HAVE_VFS_CLONE_FILE_RANGE) || \
|
#if defined(HAVE_VFS_CLONE_FILE_RANGE)
|
||||||
defined(HAVE_VFS_FILE_OPERATIONS_EXTEND)
|
|
||||||
/*
|
/*
|
||||||
* Entry point for FICLONE and FICLONERANGE, before Linux 4.20.
|
* Entry point for FICLONE and FICLONERANGE, before Linux 4.20.
|
||||||
*/
|
*/
|
||||||
@ -201,7 +199,7 @@ zpl_clone_file_range(struct file *src_file, loff_t src_off,
|
|||||||
|
|
||||||
return (ret);
|
return (ret);
|
||||||
}
|
}
|
||||||
#endif /* HAVE_VFS_CLONE_FILE_RANGE || HAVE_VFS_FILE_OPERATIONS_EXTEND */
|
#endif /* HAVE_VFS_CLONE_FILE_RANGE */
|
||||||
|
|
||||||
#ifdef HAVE_VFS_DEDUPE_FILE_RANGE
|
#ifdef HAVE_VFS_DEDUPE_FILE_RANGE
|
||||||
/*
|
/*
|
||||||
|
Loading…
Reference in New Issue
Block a user