2019-10-01 22:50:34 +03:00
|
|
|
dnl #
|
|
|
|
dnl # Check for make_request_fn interface.
|
|
|
|
dnl #
|
|
|
|
AC_DEFUN([ZFS_AC_KERNEL_SRC_MAKE_REQUEST_FN], [
|
|
|
|
ZFS_LINUX_TEST_SRC([make_request_fn_void], [
|
|
|
|
#include <linux/blkdev.h>
|
2024-01-23 02:50:53 +03:00
|
|
|
static void make_request(struct request_queue *q,
|
2019-10-01 22:50:34 +03:00
|
|
|
struct bio *bio) { return; }
|
|
|
|
],[
|
|
|
|
blk_queue_make_request(NULL, &make_request);
|
|
|
|
])
|
|
|
|
|
|
|
|
ZFS_LINUX_TEST_SRC([make_request_fn_blk_qc_t], [
|
|
|
|
#include <linux/blkdev.h>
|
2024-01-23 02:50:53 +03:00
|
|
|
static blk_qc_t make_request(struct request_queue *q,
|
2019-10-01 22:50:34 +03:00
|
|
|
struct bio *bio) { return (BLK_QC_T_NONE); }
|
|
|
|
],[
|
|
|
|
blk_queue_make_request(NULL, &make_request);
|
|
|
|
])
|
2020-04-09 19:16:46 +03:00
|
|
|
|
|
|
|
ZFS_LINUX_TEST_SRC([blk_alloc_queue_request_fn], [
|
|
|
|
#include <linux/blkdev.h>
|
2024-01-23 02:50:53 +03:00
|
|
|
static blk_qc_t make_request(struct request_queue *q,
|
2020-04-09 19:16:46 +03:00
|
|
|
struct bio *bio) { return (BLK_QC_T_NONE); }
|
|
|
|
],[
|
|
|
|
struct request_queue *q __attribute__ ((unused));
|
|
|
|
q = blk_alloc_queue(make_request, NUMA_NO_NODE);
|
|
|
|
])
|
2020-08-09 19:12:25 +03:00
|
|
|
|
2020-12-21 21:11:56 +03:00
|
|
|
ZFS_LINUX_TEST_SRC([blk_alloc_queue_request_fn_rh], [
|
|
|
|
#include <linux/blkdev.h>
|
2024-01-23 02:50:53 +03:00
|
|
|
static blk_qc_t make_request(struct request_queue *q,
|
2020-12-21 21:11:56 +03:00
|
|
|
struct bio *bio) { return (BLK_QC_T_NONE); }
|
|
|
|
],[
|
|
|
|
struct request_queue *q __attribute__ ((unused));
|
|
|
|
q = blk_alloc_queue_rh(make_request, NUMA_NO_NODE);
|
|
|
|
])
|
|
|
|
|
2020-08-09 19:12:25 +03:00
|
|
|
ZFS_LINUX_TEST_SRC([block_device_operations_submit_bio], [
|
|
|
|
#include <linux/blkdev.h>
|
|
|
|
],[
|
|
|
|
struct block_device_operations o;
|
|
|
|
o.submit_bio = NULL;
|
|
|
|
])
|
2021-07-24 01:28:03 +03:00
|
|
|
|
|
|
|
ZFS_LINUX_TEST_SRC([blk_alloc_disk], [
|
|
|
|
#include <linux/blkdev.h>
|
|
|
|
],[
|
|
|
|
struct gendisk *disk __attribute__ ((unused));
|
|
|
|
disk = blk_alloc_disk(NUMA_NO_NODE);
|
|
|
|
])
|
2022-08-04 03:37:52 +03:00
|
|
|
|
2024-03-27 03:24:57 +03:00
|
|
|
ZFS_LINUX_TEST_SRC([blk_alloc_disk_2arg], [
|
|
|
|
#include <linux/blkdev.h>
|
|
|
|
],[
|
|
|
|
struct queue_limits *lim = NULL;
|
|
|
|
struct gendisk *disk __attribute__ ((unused));
|
|
|
|
disk = blk_alloc_disk(lim, NUMA_NO_NODE);
|
|
|
|
])
|
|
|
|
|
2024-07-30 14:40:35 +03:00
|
|
|
ZFS_LINUX_TEST_SRC([blkdev_queue_limits_features], [
|
|
|
|
#include <linux/blkdev.h>
|
|
|
|
],[
|
|
|
|
struct queue_limits *lim = NULL;
|
|
|
|
lim->features = 0;
|
|
|
|
])
|
|
|
|
|
2022-08-04 03:37:52 +03:00
|
|
|
ZFS_LINUX_TEST_SRC([blk_cleanup_disk], [
|
|
|
|
#include <linux/blkdev.h>
|
|
|
|
],[
|
|
|
|
struct gendisk *disk __attribute__ ((unused));
|
|
|
|
blk_cleanup_disk(disk);
|
|
|
|
])
|
2019-10-01 22:50:34 +03:00
|
|
|
])
|
|
|
|
|
|
|
|
AC_DEFUN([ZFS_AC_KERNEL_MAKE_REQUEST_FN], [
|
2020-08-09 19:12:25 +03:00
|
|
|
dnl # Checked as part of the blk_alloc_queue_request_fn test
|
2019-10-01 22:50:34 +03:00
|
|
|
dnl #
|
2020-08-09 19:12:25 +03:00
|
|
|
dnl # Linux 5.9 API Change
|
|
|
|
dnl # make_request_fn was moved into block_device_operations->submit_bio
|
2019-10-01 22:50:34 +03:00
|
|
|
dnl #
|
2020-08-09 19:12:25 +03:00
|
|
|
AC_MSG_CHECKING([whether submit_bio is member of struct block_device_operations])
|
|
|
|
ZFS_LINUX_TEST_RESULT([block_device_operations_submit_bio], [
|
2019-10-01 22:50:34 +03:00
|
|
|
AC_MSG_RESULT(yes)
|
2020-04-09 19:16:46 +03:00
|
|
|
|
2020-08-09 19:12:25 +03:00
|
|
|
AC_DEFINE(HAVE_SUBMIT_BIO_IN_BLOCK_DEVICE_OPERATIONS, 1,
|
|
|
|
[submit_bio is member of struct block_device_operations])
|
2021-07-24 01:28:03 +03:00
|
|
|
|
|
|
|
dnl #
|
|
|
|
dnl # Linux 5.14 API Change:
|
|
|
|
dnl # blk_alloc_queue() + alloc_disk() combo replaced by
|
|
|
|
dnl # a single call to blk_alloc_disk().
|
|
|
|
dnl #
|
|
|
|
AC_MSG_CHECKING([whether blk_alloc_disk() exists])
|
|
|
|
ZFS_LINUX_TEST_RESULT([blk_alloc_disk], [
|
|
|
|
AC_MSG_RESULT(yes)
|
|
|
|
AC_DEFINE([HAVE_BLK_ALLOC_DISK], 1, [blk_alloc_disk() exists])
|
2022-08-04 03:37:52 +03:00
|
|
|
|
|
|
|
dnl #
|
|
|
|
dnl # 5.20 API change,
|
|
|
|
dnl # Removed blk_cleanup_disk(), put_disk() should be used.
|
|
|
|
dnl #
|
|
|
|
AC_MSG_CHECKING([whether blk_cleanup_disk() exists])
|
|
|
|
ZFS_LINUX_TEST_RESULT([blk_cleanup_disk], [
|
|
|
|
AC_MSG_RESULT(yes)
|
|
|
|
AC_DEFINE([HAVE_BLK_CLEANUP_DISK], 1,
|
|
|
|
[blk_cleanup_disk() exists])
|
|
|
|
], [
|
|
|
|
AC_MSG_RESULT(no)
|
|
|
|
])
|
2021-07-24 01:28:03 +03:00
|
|
|
], [
|
|
|
|
AC_MSG_RESULT(no)
|
|
|
|
])
|
2024-03-27 03:24:57 +03:00
|
|
|
|
|
|
|
dnl #
|
|
|
|
dnl # Linux 6.9 API Change:
|
|
|
|
dnl # blk_alloc_queue() takes a nullable queue_limits arg.
|
|
|
|
dnl #
|
|
|
|
AC_MSG_CHECKING([whether blk_alloc_disk() exists and takes 2 args])
|
|
|
|
ZFS_LINUX_TEST_RESULT([blk_alloc_disk_2arg], [
|
|
|
|
AC_MSG_RESULT(yes)
|
|
|
|
AC_DEFINE([HAVE_BLK_ALLOC_DISK_2ARG], 1, [blk_alloc_disk() exists and takes 2 args])
|
|
|
|
|
2024-07-30 14:40:35 +03:00
|
|
|
dnl #
|
|
|
|
dnl # Linux 6.11 API change:
|
|
|
|
dnl # struct queue_limits gains a 'features' field,
|
|
|
|
dnl # used to set flushing options
|
|
|
|
dnl #
|
|
|
|
AC_MSG_CHECKING([whether struct queue_limits has a features field])
|
|
|
|
ZFS_LINUX_TEST_RESULT([blkdev_queue_limits_features], [
|
|
|
|
AC_MSG_RESULT(yes)
|
|
|
|
AC_DEFINE([HAVE_BLKDEV_QUEUE_LIMITS_FEATURES], 1,
|
|
|
|
[struct queue_limits has a features field])
|
|
|
|
], [
|
|
|
|
AC_MSG_RESULT(no)
|
|
|
|
])
|
|
|
|
|
2024-03-27 03:24:57 +03:00
|
|
|
dnl #
|
|
|
|
dnl # 5.20 API change,
|
|
|
|
dnl # Removed blk_cleanup_disk(), put_disk() should be used.
|
|
|
|
dnl #
|
|
|
|
AC_MSG_CHECKING([whether blk_cleanup_disk() exists])
|
|
|
|
ZFS_LINUX_TEST_RESULT([blk_cleanup_disk], [
|
|
|
|
AC_MSG_RESULT(yes)
|
|
|
|
AC_DEFINE([HAVE_BLK_CLEANUP_DISK], 1,
|
|
|
|
[blk_cleanup_disk() exists])
|
|
|
|
], [
|
|
|
|
AC_MSG_RESULT(no)
|
|
|
|
])
|
|
|
|
], [
|
|
|
|
AC_MSG_RESULT(no)
|
|
|
|
])
|
2020-12-21 21:11:56 +03:00
|
|
|
],[
|
|
|
|
AC_MSG_RESULT(no)
|
|
|
|
|
2020-04-09 19:16:46 +03:00
|
|
|
dnl # Checked as part of the blk_alloc_queue_request_fn test
|
2019-10-01 22:50:34 +03:00
|
|
|
dnl #
|
2020-08-09 19:12:25 +03:00
|
|
|
dnl # Linux 5.7 API Change
|
|
|
|
dnl # blk_alloc_queue() expects request function.
|
2019-10-01 22:50:34 +03:00
|
|
|
dnl #
|
2020-08-09 19:12:25 +03:00
|
|
|
AC_MSG_CHECKING([whether blk_alloc_queue() expects request function])
|
|
|
|
ZFS_LINUX_TEST_RESULT([blk_alloc_queue_request_fn], [
|
2020-12-21 21:11:56 +03:00
|
|
|
AC_MSG_RESULT(yes)
|
|
|
|
|
|
|
|
dnl # This is currently always the case.
|
2020-08-09 19:12:25 +03:00
|
|
|
AC_MSG_CHECKING([whether make_request_fn() returns blk_qc_t])
|
2019-10-01 22:50:34 +03:00
|
|
|
AC_MSG_RESULT(yes)
|
2020-08-09 19:12:25 +03:00
|
|
|
|
|
|
|
AC_DEFINE(HAVE_BLK_ALLOC_QUEUE_REQUEST_FN, 1,
|
|
|
|
[blk_alloc_queue() expects request function])
|
|
|
|
AC_DEFINE(MAKE_REQUEST_FN_RET, blk_qc_t,
|
2019-10-01 22:50:34 +03:00
|
|
|
[make_request_fn() return type])
|
2020-08-09 19:12:25 +03:00
|
|
|
AC_DEFINE(HAVE_MAKE_REQUEST_FN_RET_QC, 1,
|
|
|
|
[Noting that make_request_fn() returns blk_qc_t])
|
2019-10-01 22:50:34 +03:00
|
|
|
],[
|
2020-04-09 19:16:46 +03:00
|
|
|
dnl #
|
2020-12-21 21:11:56 +03:00
|
|
|
dnl # CentOS Stream 4.18.0-257 API Change
|
|
|
|
dnl # The Linux 5.7 blk_alloc_queue() change was back-
|
|
|
|
dnl # ported and the symbol renamed blk_alloc_queue_rh().
|
|
|
|
dnl # As of this kernel version they're not providing
|
|
|
|
dnl # any compatibility code in the kernel for this.
|
2020-04-09 19:16:46 +03:00
|
|
|
dnl #
|
2020-12-21 21:11:56 +03:00
|
|
|
ZFS_LINUX_TEST_RESULT([blk_alloc_queue_request_fn_rh], [
|
2020-04-09 19:16:46 +03:00
|
|
|
AC_MSG_RESULT(yes)
|
2020-12-21 21:11:56 +03:00
|
|
|
|
|
|
|
dnl # This is currently always the case.
|
|
|
|
AC_MSG_CHECKING([whether make_request_fn_rh() returns blk_qc_t])
|
|
|
|
AC_MSG_RESULT(yes)
|
|
|
|
|
|
|
|
AC_DEFINE(HAVE_BLK_ALLOC_QUEUE_REQUEST_FN_RH, 1,
|
|
|
|
[blk_alloc_queue_rh() expects request function])
|
|
|
|
AC_DEFINE(MAKE_REQUEST_FN_RET, blk_qc_t,
|
2020-04-09 19:16:46 +03:00
|
|
|
[make_request_fn() return type])
|
2020-12-21 21:11:56 +03:00
|
|
|
AC_DEFINE(HAVE_MAKE_REQUEST_FN_RET_QC, 1,
|
|
|
|
[Noting that make_request_fn() returns blk_qc_t])
|
2020-04-09 19:16:46 +03:00
|
|
|
],[
|
2020-08-09 19:12:25 +03:00
|
|
|
AC_MSG_RESULT(no)
|
|
|
|
|
|
|
|
dnl #
|
2020-12-21 21:11:56 +03:00
|
|
|
dnl # Linux 3.2 API Change
|
|
|
|
dnl # make_request_fn returns void.
|
2020-08-09 19:12:25 +03:00
|
|
|
dnl #
|
|
|
|
AC_MSG_CHECKING(
|
2020-12-21 21:11:56 +03:00
|
|
|
[whether make_request_fn() returns void])
|
|
|
|
ZFS_LINUX_TEST_RESULT([make_request_fn_void], [
|
2020-08-09 19:12:25 +03:00
|
|
|
AC_MSG_RESULT(yes)
|
2020-12-21 21:11:56 +03:00
|
|
|
AC_DEFINE(MAKE_REQUEST_FN_RET, void,
|
2020-08-09 19:12:25 +03:00
|
|
|
[make_request_fn() return type])
|
2020-12-21 21:11:56 +03:00
|
|
|
AC_DEFINE(HAVE_MAKE_REQUEST_FN_RET_VOID, 1,
|
|
|
|
[Noting that make_request_fn() returns void])
|
2020-08-09 19:12:25 +03:00
|
|
|
],[
|
2020-12-21 21:11:56 +03:00
|
|
|
AC_MSG_RESULT(no)
|
|
|
|
|
|
|
|
dnl #
|
|
|
|
dnl # Linux 4.4 API Change
|
|
|
|
dnl # make_request_fn returns blk_qc_t.
|
|
|
|
dnl #
|
|
|
|
AC_MSG_CHECKING(
|
|
|
|
[whether make_request_fn() returns blk_qc_t])
|
|
|
|
ZFS_LINUX_TEST_RESULT([make_request_fn_blk_qc_t], [
|
|
|
|
AC_MSG_RESULT(yes)
|
|
|
|
AC_DEFINE(MAKE_REQUEST_FN_RET, blk_qc_t,
|
|
|
|
[make_request_fn() return type])
|
|
|
|
AC_DEFINE(HAVE_MAKE_REQUEST_FN_RET_QC, 1,
|
|
|
|
[Noting that make_request_fn() ]
|
|
|
|
[returns blk_qc_t])
|
|
|
|
],[
|
|
|
|
ZFS_LINUX_TEST_ERROR([make_request_fn])
|
|
|
|
])
|
2020-08-09 19:12:25 +03:00
|
|
|
])
|
2020-04-09 19:16:46 +03:00
|
|
|
])
|
2019-10-01 22:50:34 +03:00
|
|
|
])
|
|
|
|
])
|
|
|
|
])
|