aboutsummaryrefslogtreecommitdiffstats
path: root/config/kernel-tmpfile.m4
diff options
context:
space:
mode:
Diffstat (limited to 'config/kernel-tmpfile.m4')
-rw-r--r--config/kernel-tmpfile.m428
1 files changed, 24 insertions, 4 deletions
diff --git a/config/kernel-tmpfile.m4 b/config/kernel-tmpfile.m4
index f510bfe6b..45c2e6cee 100644
--- a/config/kernel-tmpfile.m4
+++ b/config/kernel-tmpfile.m4
@@ -3,23 +3,43 @@ dnl # 3.11 API change
dnl # Add support for i_op->tmpfile
dnl #
AC_DEFUN([ZFS_AC_KERNEL_SRC_TMPFILE], [
- ZFS_LINUX_TEST_SRC([inode_operations_tmpfile], [
+ dnl #
+ dnl # 5.11 API change
+ dnl # add support for userns parameter to tmpfile
+ dnl #
+ ZFS_LINUX_TEST_SRC([inode_operations_tmpfile_userns], [
#include <linux/fs.h>
- int tmpfile(struct inode *inode, struct dentry *dentry,
+ int tmpfile(struct user_namespace *userns,
+ struct inode *inode, struct dentry *dentry,
umode_t mode) { return 0; }
static struct inode_operations
iops __attribute__ ((unused)) = {
.tmpfile = tmpfile,
};
],[])
+ ZFS_LINUX_TEST_SRC([inode_operations_tmpfile], [
+ #include <linux/fs.h>
+ int tmpfile(struct inode *inode, struct dentry *dentry,
+ umode_t mode) { return 0; }
+ static struct inode_operations
+ iops __attribute__ ((unused)) = {
+ .tmpfile = tmpfile,
+ };
+ ],[])
])
AC_DEFUN([ZFS_AC_KERNEL_TMPFILE], [
AC_MSG_CHECKING([whether i_op->tmpfile() exists])
- ZFS_LINUX_TEST_RESULT([inode_operations_tmpfile], [
+ ZFS_LINUX_TEST_RESULT([inode_operations_tmpfile_userns], [
AC_MSG_RESULT(yes)
AC_DEFINE(HAVE_TMPFILE, 1, [i_op->tmpfile() exists])
+ AC_DEFINE(HAVE_TMPFILE_USERNS, 1, [i_op->tmpfile() has userns])
],[
- AC_MSG_RESULT(no)
+ ZFS_LINUX_TEST_RESULT([inode_operations_tmpfile], [
+ AC_MSG_RESULT(yes)
+ AC_DEFINE(HAVE_TMPFILE, 1, [i_op->tmpfile() exists])
+ ],[
+ AC_MSG_RESULT(no)
+ ])
])
])