2011-09-02 11:42:07 +04:00
|
|
|
dnl #
|
|
|
|
dnl # Linux 2.6.38 - 3.x API
|
|
|
|
dnl #
|
|
|
|
AC_DEFUN([ZFS_AC_KERNEL_FILE_FALLOCATE], [
|
|
|
|
AC_MSG_CHECKING([whether fops->fallocate() exists])
|
|
|
|
ZFS_LINUX_TRY_COMPILE([
|
|
|
|
#include <linux/fs.h>
|
2013-02-15 03:54:04 +04:00
|
|
|
|
|
|
|
long test_fallocate(struct file *file, int mode,
|
|
|
|
loff_t offset, loff_t len) { return 0; }
|
|
|
|
|
|
|
|
static const struct file_operations
|
|
|
|
fops __attribute__ ((unused)) = {
|
|
|
|
.fallocate = test_fallocate,
|
2011-09-02 11:42:07 +04:00
|
|
|
};
|
2013-02-15 03:54:04 +04:00
|
|
|
],[
|
2011-09-02 11:42:07 +04:00
|
|
|
],[
|
|
|
|
AC_MSG_RESULT(yes)
|
|
|
|
AC_DEFINE(HAVE_FILE_FALLOCATE, 1, [fops->fallocate() exists])
|
|
|
|
],[
|
|
|
|
AC_MSG_RESULT(no)
|
|
|
|
])
|
|
|
|
])
|
|
|
|
|
|
|
|
dnl #
|
|
|
|
dnl # Linux 2.6.x - 2.6.37 API
|
|
|
|
dnl #
|
|
|
|
AC_DEFUN([ZFS_AC_KERNEL_INODE_FALLOCATE], [
|
|
|
|
AC_MSG_CHECKING([whether iops->fallocate() exists])
|
|
|
|
ZFS_LINUX_TRY_COMPILE([
|
|
|
|
#include <linux/fs.h>
|
|
|
|
|
2013-02-15 03:54:04 +04:00
|
|
|
long test_fallocate(struct inode *inode, int mode,
|
|
|
|
loff_t offset, loff_t len) { return 0; }
|
|
|
|
|
|
|
|
static const struct inode_operations
|
|
|
|
fops __attribute__ ((unused)) = {
|
|
|
|
.fallocate = test_fallocate,
|
2012-05-31 07:25:31 +04:00
|
|
|
};
|
2013-02-15 03:54:04 +04:00
|
|
|
],[
|
2012-05-31 07:25:31 +04:00
|
|
|
],[
|
|
|
|
AC_MSG_RESULT(yes)
|
2013-02-15 03:54:04 +04:00
|
|
|
AC_DEFINE(HAVE_INODE_FALLOCATE, 1, [fops->fallocate() exists])
|
2012-05-31 07:25:31 +04:00
|
|
|
],[
|
|
|
|
AC_MSG_RESULT(no)
|
|
|
|
])
|
|
|
|
])
|
|
|
|
|
2011-09-02 11:42:07 +04:00
|
|
|
dnl #
|
|
|
|
dnl # The fallocate callback was moved from the inode_operations
|
|
|
|
dnl # structure to the file_operations structure.
|
|
|
|
dnl #
|
|
|
|
AC_DEFUN([ZFS_AC_KERNEL_FALLOCATE], [
|
|
|
|
ZFS_AC_KERNEL_FILE_FALLOCATE
|
|
|
|
ZFS_AC_KERNEL_INODE_FALLOCATE
|
|
|
|
])
|