066e825221
Increase the minimum supported kernel version from 2.6.32 to 3.10. This removes support for the following Linux enterprise distributions. Distribution | Kernel | End of Life ---------------- | ------ | ------------- Ubuntu 12.04 LTS | 3.2 | Apr 28, 2017 SLES 11 | 3.0 | Mar 32, 2019 RHEL / CentOS 6 | 2.6.32 | Nov 30, 2020 The following changes were made as part of removing support. * Updated `configure` to enforce a minimum kernel version as specified in the META file (Linux-Minimum: 3.10). configure: error: *** Cannot build against kernel version 2.6.32. *** The minimum supported kernel version is 3.10. * Removed all `configure` kABI checks and matching C code for interfaces which solely predate the Linux 3.10 kernel. * Updated all `configure` kABI checks to fail when an interface is missing which was in the 3.10 kernel up to the latest 5.1 kernel. Removed the HAVE_* preprocessor defines for these checks and updated the code to unconditionally use the verified interface. * Inverted the detection logic in several kABI checks to match the new interface as it appears in 3.10 and newer and not the legacy interface. * Consolidated the following checks in to individual files. Due the large number of changes in the checks it made sense to handle this now. It would be desirable to group other related checks in the same fashion, but this as left as future work. - config/kernel-blkdev.m4 - Block device kABI checks - config/kernel-blk-queue.m4 - Block queue kABI checks - config/kernel-bio.m4 - Bio interface kABI checks * Removed the kABI checks for sops->nr_cached_objects() and sops->free_cached_objects(). These interfaces are currently unused. Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov> Closes #9566
78 lines
1.9 KiB
Plaintext
78 lines
1.9 KiB
Plaintext
dnl #
|
|
dnl # 2.6.38 API change
|
|
dnl # ns_capable() was introduced
|
|
dnl #
|
|
AC_DEFUN([ZFS_AC_KERNEL_SRC_NS_CAPABLE], [
|
|
ZFS_LINUX_TEST_SRC([ns_capable], [
|
|
#include <linux/capability.h>
|
|
],[
|
|
ns_capable((struct user_namespace *)NULL, CAP_SYS_ADMIN);
|
|
])
|
|
])
|
|
|
|
AC_DEFUN([ZFS_AC_KERNEL_NS_CAPABLE], [
|
|
AC_MSG_CHECKING([whether ns_capable exists])
|
|
ZFS_LINUX_TEST_RESULT([ns_capable], [
|
|
AC_MSG_RESULT(yes)
|
|
],[
|
|
ZFS_LINUX_TEST_ERROR([ns_capable()])
|
|
])
|
|
])
|
|
|
|
dnl #
|
|
dnl # 2.6.39 API change
|
|
dnl # struct user_namespace was added to struct cred_t as cred->user_ns member
|
|
dnl #
|
|
AC_DEFUN([ZFS_AC_KERNEL_SRC_CRED_USER_NS], [
|
|
ZFS_LINUX_TEST_SRC([cred_user_ns], [
|
|
#include <linux/cred.h>
|
|
],[
|
|
struct cred cr;
|
|
cr.user_ns = (struct user_namespace *)NULL;
|
|
])
|
|
])
|
|
|
|
AC_DEFUN([ZFS_AC_KERNEL_CRED_USER_NS], [
|
|
AC_MSG_CHECKING([whether cred_t->user_ns exists])
|
|
ZFS_LINUX_TEST_RESULT([cred_user_ns], [
|
|
AC_MSG_RESULT(yes)
|
|
],[
|
|
ZFS_LINUX_TEST_ERROR([cred_t->user_ns()])
|
|
])
|
|
])
|
|
|
|
dnl #
|
|
dnl # 3.4 API change
|
|
dnl # kuid_has_mapping() and kgid_has_mapping() were added to distinguish
|
|
dnl # between internal kernel uids/gids and user namespace uids/gids.
|
|
dnl #
|
|
AC_DEFUN([ZFS_AC_KERNEL_SRC_KUID_HAS_MAPPING], [
|
|
ZFS_LINUX_TEST_SRC([kuid_has_mapping], [
|
|
#include <linux/uidgid.h>
|
|
],[
|
|
kuid_has_mapping((struct user_namespace *)NULL, KUIDT_INIT(0));
|
|
kgid_has_mapping((struct user_namespace *)NULL, KGIDT_INIT(0));
|
|
])
|
|
])
|
|
|
|
AC_DEFUN([ZFS_AC_KERNEL_KUID_HAS_MAPPING], [
|
|
AC_MSG_CHECKING([whether kuid_has_mapping/kgid_has_mapping exist])
|
|
ZFS_LINUX_TEST_RESULT([kuid_has_mapping], [
|
|
AC_MSG_RESULT(yes)
|
|
],[
|
|
ZFS_LINUX_TEST_ERROR([kuid_has_mapping()])
|
|
])
|
|
])
|
|
|
|
AC_DEFUN([ZFS_AC_KERNEL_SRC_USERNS_CAPABILITIES], [
|
|
ZFS_AC_KERNEL_SRC_NS_CAPABLE
|
|
ZFS_AC_KERNEL_SRC_CRED_USER_NS
|
|
ZFS_AC_KERNEL_SRC_KUID_HAS_MAPPING
|
|
])
|
|
|
|
AC_DEFUN([ZFS_AC_KERNEL_USERNS_CAPABILITIES], [
|
|
ZFS_AC_KERNEL_NS_CAPABLE
|
|
ZFS_AC_KERNEL_CRED_USER_NS
|
|
ZFS_AC_KERNEL_KUID_HAS_MAPPING
|
|
])
|