dnl #
dnl # 2.6.39 API change,
dnl # The is_owner_or_cap() macro was renamed to inode_owner_or_capable(),
dnl # This is used for permission checks in the xattr and file attribute call
dnl # paths.
dnl #
dnl # 5.12 API change,
dnl # inode_owner_or_capable() now takes struct user_namespace *
dnl # to support idmapped mounts
dnl #
AC_DEFUN([ZFS_AC_KERNEL_SRC_INODE_OWNER_OR_CAPABLE], [
	ZFS_LINUX_TEST_SRC([inode_owner_or_capable], [
		#include <linux/fs.h>
	],[
		struct inode *ip = NULL;
		(void) inode_owner_or_capable(ip);
	])

	ZFS_LINUX_TEST_SRC([inode_owner_or_capable_userns], [
		#include <linux/fs.h>
	],[
		struct inode *ip = NULL;
		(void) inode_owner_or_capable(&init_user_ns, ip);
	])

	ZFS_LINUX_TEST_SRC([inode_owner_or_capable_mnt_idmap], [
		#include <linux/fs.h>
		#include <linux/mnt_idmapping.h>
	],[
		struct inode *ip = NULL;
		(void) inode_owner_or_capable(&nop_mnt_idmap, ip);
	])
])

AC_DEFUN([ZFS_AC_KERNEL_INODE_OWNER_OR_CAPABLE], [
	AC_MSG_CHECKING([whether inode_owner_or_capable() exists])
	ZFS_LINUX_TEST_RESULT([inode_owner_or_capable], [
		AC_MSG_RESULT(yes)
		AC_DEFINE(HAVE_INODE_OWNER_OR_CAPABLE, 1,
		    [inode_owner_or_capable() exists])
	], [
		AC_MSG_RESULT(no)

		AC_MSG_CHECKING(
		    [whether inode_owner_or_capable() takes user_ns])
		ZFS_LINUX_TEST_RESULT([inode_owner_or_capable_userns], [
			AC_MSG_RESULT(yes)
			AC_DEFINE(HAVE_INODE_OWNER_OR_CAPABLE_USERNS, 1,
			    [inode_owner_or_capable() takes user_ns])
		],[
			AC_MSG_RESULT(no)
			AC_MSG_CHECKING(
			    [whether inode_owner_or_capable() takes mnt_idmap])
			ZFS_LINUX_TEST_RESULT([inode_owner_or_capable_mnt_idmap], [
				AC_MSG_RESULT(yes)
				AC_DEFINE(HAVE_INODE_OWNER_OR_CAPABLE_IDMAP, 1,
				    [inode_owner_or_capable() takes mnt_idmap])
			], [
				ZFS_LINUX_TEST_ERROR([capability])
			])
		])
	])
])