mirror of
https://git.proxmox.com/git/mirror_zfs.git
synced 2025-01-22 07:56:36 +03:00
91d5ac85c0
In Linux 5.12, the filesystem API was modified to support ipmapped
mounts by adding a "struct user_namespace *" parameter to a number
functions and VFS handlers. This change adds the needed autoconf
macros to detect the new interfaces and updates the code appropriately.
This change does not add support for idmapped mounts, instead it
preserves the existing behavior by passing the initial user namespace
where needed. A subsequent commit will be required to add support
for idmapped mounted.
Reviewed-by: Tony Hutter <hutter2@llnl.gov>
Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov>
Co-authored-by: Brian Behlendorf <behlendorf1@llnl.gov>
Signed-off-by: Coleman Kane <ckane@colemankane.org>
Closes #11712
(cherry picked from commit e2a8296131
)
Signed-off-by: Jonathon Fernyhough <jonathon@m2x.dev>
93 lines
2.2 KiB
Plaintext
93 lines
2.2 KiB
Plaintext
AC_DEFUN([ZFS_AC_KERNEL_SRC_INODE_GETATTR], [
|
|
dnl #
|
|
dnl # Linux 5.12 API
|
|
dnl # The getattr I/O operations handler type was extended to require
|
|
dnl # a struct user_namespace* as its first arg, to support idmapped
|
|
dnl # mounts.
|
|
dnl #
|
|
ZFS_LINUX_TEST_SRC([inode_operations_getattr_userns], [
|
|
#include <linux/fs.h>
|
|
|
|
int test_getattr(
|
|
struct user_namespace *userns,
|
|
const struct path *p, struct kstat *k,
|
|
u32 request_mask, unsigned int query_flags)
|
|
{ return 0; }
|
|
|
|
static const struct inode_operations
|
|
iops __attribute__ ((unused)) = {
|
|
.getattr = test_getattr,
|
|
};
|
|
],[])
|
|
|
|
dnl #
|
|
dnl # Linux 4.11 API
|
|
dnl # See torvalds/linux@a528d35
|
|
dnl #
|
|
ZFS_LINUX_TEST_SRC([inode_operations_getattr_path], [
|
|
#include <linux/fs.h>
|
|
|
|
int test_getattr(
|
|
const struct path *p, struct kstat *k,
|
|
u32 request_mask, unsigned int query_flags)
|
|
{ return 0; }
|
|
|
|
static const struct inode_operations
|
|
iops __attribute__ ((unused)) = {
|
|
.getattr = test_getattr,
|
|
};
|
|
],[])
|
|
|
|
ZFS_LINUX_TEST_SRC([inode_operations_getattr_vfsmount], [
|
|
#include <linux/fs.h>
|
|
|
|
int test_getattr(
|
|
struct vfsmount *mnt, struct dentry *d,
|
|
struct kstat *k)
|
|
{ return 0; }
|
|
|
|
static const struct inode_operations
|
|
iops __attribute__ ((unused)) = {
|
|
.getattr = test_getattr,
|
|
};
|
|
],[])
|
|
])
|
|
|
|
AC_DEFUN([ZFS_AC_KERNEL_INODE_GETATTR], [
|
|
dnl #
|
|
dnl # Kernel 5.12 test
|
|
dnl #
|
|
AC_MSG_CHECKING([whether iops->getattr() takes user_namespace])
|
|
ZFS_LINUX_TEST_RESULT([inode_operations_getattr_userns], [
|
|
AC_MSG_RESULT(yes)
|
|
AC_DEFINE(HAVE_USERNS_IOPS_GETATTR, 1,
|
|
[iops->getattr() takes struct user_namespace*])
|
|
],[
|
|
AC_MSG_RESULT(no)
|
|
|
|
dnl #
|
|
dnl # Kernel 4.11 test
|
|
dnl #
|
|
AC_MSG_CHECKING([whether iops->getattr() takes a path])
|
|
ZFS_LINUX_TEST_RESULT([inode_operations_getattr_path], [
|
|
AC_MSG_RESULT(yes)
|
|
AC_DEFINE(HAVE_PATH_IOPS_GETATTR, 1,
|
|
[iops->getattr() takes a path])
|
|
],[
|
|
AC_MSG_RESULT(no)
|
|
|
|
dnl #
|
|
dnl # Kernel < 4.11 test
|
|
dnl #
|
|
AC_MSG_CHECKING([whether iops->getattr() takes a vfsmount])
|
|
ZFS_LINUX_TEST_RESULT([inode_operations_getattr_vfsmount], [
|
|
AC_MSG_RESULT(yes)
|
|
AC_DEFINE(HAVE_VFSMOUNT_IOPS_GETATTR, 1,
|
|
[iops->getattr() takes a vfsmount])
|
|
],[
|
|
AC_MSG_RESULT(no)
|
|
])
|
|
])
|
|
])
|
|
])
|