2 dnl # Check for generic io accounting interface.
4 AC_DEFUN([ZFS_AC_KERNEL_SRC_GENERIC_IO_ACCT], [
5 ZFS_LINUX_TEST_SRC([bdev_io_acct_63], [
6 #include <linux/blkdev.h>
8 struct block_device *bdev = NULL;
9 struct bio *bio = NULL;
10 unsigned long passed_time = 0;
11 unsigned long start_time;
13 start_time = bdev_start_io_acct(bdev, bio_op(bio),
15 bdev_end_io_acct(bdev, bio_op(bio), bio_sectors(bio), start_time);
18 ZFS_LINUX_TEST_SRC([bdev_io_acct_old], [
19 #include <linux/blkdev.h>
21 struct block_device *bdev = NULL;
22 struct bio *bio = NULL;
23 unsigned long passed_time = 0;
24 unsigned long start_time;
26 start_time = bdev_start_io_acct(bdev, bio_sectors(bio),
27 bio_op(bio), passed_time);
28 bdev_end_io_acct(bdev, bio_op(bio), start_time);
31 ZFS_LINUX_TEST_SRC([disk_io_acct], [
32 #include <linux/blkdev.h>
34 struct gendisk *disk = NULL;
35 struct bio *bio = NULL;
36 unsigned long start_time;
38 start_time = disk_start_io_acct(disk, bio_sectors(bio), bio_op(bio));
39 disk_end_io_acct(disk, bio_op(bio), start_time);
42 ZFS_LINUX_TEST_SRC([bio_io_acct], [
43 #include <linux/blkdev.h>
45 struct bio *bio = NULL;
46 unsigned long start_time;
48 start_time = bio_start_io_acct(bio);
49 bio_end_io_acct(bio, start_time);
52 ZFS_LINUX_TEST_SRC([generic_acct_3args], [
53 #include <linux/bio.h>
55 void (*generic_start_io_acct_f)(int, unsigned long,
56 struct hd_struct *) = &generic_start_io_acct;
57 void (*generic_end_io_acct_f)(int, struct hd_struct *,
58 unsigned long) = &generic_end_io_acct;
60 generic_start_io_acct(0, 0, NULL);
61 generic_end_io_acct(0, NULL, 0);
64 ZFS_LINUX_TEST_SRC([generic_acct_4args], [
65 #include <linux/bio.h>
67 void (*generic_start_io_acct_f)(struct request_queue *, int,
68 unsigned long, struct hd_struct *) = &generic_start_io_acct;
69 void (*generic_end_io_acct_f)(struct request_queue *, int,
70 struct hd_struct *, unsigned long) = &generic_end_io_acct;
72 generic_start_io_acct(NULL, 0, 0, NULL);
73 generic_end_io_acct(NULL, 0, NULL, 0);
77 AC_DEFUN([ZFS_AC_KERNEL_GENERIC_IO_ACCT], [
79 dnl # Linux 6.3, and then backports thereof, changed
80 dnl # the signatures on bdev_start_io_acct/bdev_end_io_acct
82 AC_MSG_CHECKING([whether 6.3+ bdev_*_io_acct() are available])
83 ZFS_LINUX_TEST_RESULT([bdev_io_acct_63], [
85 AC_DEFINE(HAVE_BDEV_IO_ACCT_63, 1, [bdev_*_io_acct() available])
92 dnl # disk_start_io_acct() and disk_end_io_acct() have been replaced by
93 dnl # bdev_start_io_acct() and bdev_end_io_acct().
95 AC_MSG_CHECKING([whether pre-6.3 bdev_*_io_acct() are available])
96 ZFS_LINUX_TEST_RESULT([bdev_io_acct_old], [
98 AC_DEFINE(HAVE_BDEV_IO_ACCT_OLD, 1, [bdev_*_io_acct() available])
104 dnl # bio_start_io_acct() and bio_end_io_acct() became GPL-exported
105 dnl # so use disk_start_io_acct() and disk_end_io_acct() instead
107 AC_MSG_CHECKING([whether generic disk_*_io_acct() are available])
108 ZFS_LINUX_TEST_RESULT([disk_io_acct], [
110 AC_DEFINE(HAVE_DISK_IO_ACCT, 1, [disk_*_io_acct() available])
117 dnl # Added bio_start_io_acct() and bio_end_io_acct() helpers.
119 AC_MSG_CHECKING([whether generic bio_*_io_acct() are available])
120 ZFS_LINUX_TEST_RESULT([bio_io_acct], [
122 AC_DEFINE(HAVE_BIO_IO_ACCT, 1, [bio_*_io_acct() available])
129 dnl # generic_start_io_acct/generic_end_io_acct now require
130 dnl # request_queue to be provided. No functional changes,
131 dnl # but preparation for inflight accounting.
133 AC_MSG_CHECKING([whether generic_*_io_acct wants 4 args])
134 ZFS_LINUX_TEST_RESULT_SYMBOL([generic_acct_4args],
135 [generic_start_io_acct], [block/bio.c], [
137 AC_DEFINE(HAVE_GENERIC_IO_ACCT_4ARG, 1,
138 [generic_*_io_acct() 4 arg available])
143 dnl # 3.19 API addition
145 dnl # torvalds/linux@394ffa50 allows us to increment
146 dnl # iostat counters without generic_make_request().
149 [whether generic_*_io_acct wants 3 args])
150 ZFS_LINUX_TEST_RESULT_SYMBOL([generic_acct_3args],
151 [generic_start_io_acct], [block/bio.c], [
153 AC_DEFINE(HAVE_GENERIC_IO_ACCT_3ARG, 1,
154 [generic_*_io_acct() 3 arg available])