0a6b03d3b8
Gentoo Hardened kernels include the PaX/GRSecurity patches. They use a dialect of C that relies on a GCC plugin. In particular, struct file_operations has been marked do_const in the PaX/GRSecurity dialect, which causes GCC to consider all instances of it as const. This caused failures in the autotools checks and the ZFS source code. To address this, we modify the autotools checks to take into account differences between the PaX C dialect and the regular C dialect. We also modify struct zfs_acl's z_ops member to be a pointer to a function pointer table. Lastly, we modify zpl_put_link() to address a PaX change to the function prototype of nd_get_link(). This avoids compiler errors in the PaX/GRSecurity dialect. Note that the change in zpl_put_link() causes a warning that becomes a build failure when debugging is enabled. Fixing that warning requires ryao/spl@5ca50ef459. Signed-off-by: Richard Yao <ryao@cs.stonybrook.edu> Signed-off-by: Brian Behlendorf <behlendorf1@llnl.gov> Closes #484
22 lines
586 B
Plaintext
22 lines
586 B
Plaintext
dnl #
|
|
dnl # 2.6.36 API change
|
|
dnl # The sops->delete_inode() and sops->clear_inode() callbacks have
|
|
dnl # replaced by a single sops->evict_inode() callback.
|
|
dnl #
|
|
AC_DEFUN([ZFS_AC_KERNEL_EVICT_INODE], [
|
|
AC_MSG_CHECKING([whether sops->evict_inode() exists])
|
|
ZFS_LINUX_TRY_COMPILE([
|
|
#include <linux/fs.h>
|
|
void evict_inode (struct inode * t) { return; }
|
|
static struct super_operations sops __attribute__ ((unused)) = {
|
|
.evict_inode = evict_inode,
|
|
};
|
|
],[
|
|
],[
|
|
AC_MSG_RESULT(yes)
|
|
AC_DEFINE(HAVE_EVICT_INODE, 1, [sops->evict_inode() exists])
|
|
],[
|
|
AC_MSG_RESULT(no)
|
|
])
|
|
])
|