mirror of
https://git.proxmox.com/git/mirror_zfs.git
synced 2025-01-28 10:54:21 +03:00
config: remove HAVE_1ARG_BIO_END_IO_T
Sponsored-by: https://despairlabs.com/sponsor/ Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov> Reviewed-by: Tony Hutter <hutter2@llnl.gov> Reviewed-by: Tino Reichardt <milky-zfs@mcmilk.de> Signed-off-by: Rob Norris <robn@despairlabs.com> Closes #16479
This commit is contained in:
parent
02f4b63db9
commit
233bed67a8
@ -237,32 +237,6 @@ AC_DEFUN([ZFS_AC_KERNEL_BIO_SET_DEV], [
|
|||||||
])
|
])
|
||||||
])
|
])
|
||||||
|
|
||||||
dnl #
|
|
||||||
dnl # 4.3 API change
|
|
||||||
dnl # Error argument dropped from bio_endio in favor of newly introduced
|
|
||||||
dnl # bio->bi_error. This also replaces bio->bi_flags value BIO_UPTODATE.
|
|
||||||
dnl # Introduced by torvalds/linux@4246a0b63bd8f56a1469b12eafeb875b1041a451
|
|
||||||
dnl # ("block: add a bi_error field to struct bio").
|
|
||||||
dnl #
|
|
||||||
AC_DEFUN([ZFS_AC_KERNEL_SRC_BIO_END_IO_T_ARGS], [
|
|
||||||
ZFS_LINUX_TEST_SRC([bio_end_io_t_args], [
|
|
||||||
#include <linux/bio.h>
|
|
||||||
static void wanted_end_io(struct bio *bio) { return; }
|
|
||||||
bio_end_io_t *end_io __attribute__ ((unused)) = wanted_end_io;
|
|
||||||
], [])
|
|
||||||
])
|
|
||||||
|
|
||||||
AC_DEFUN([ZFS_AC_KERNEL_BIO_END_IO_T_ARGS], [
|
|
||||||
AC_MSG_CHECKING([whether bio_end_io_t wants 1 arg])
|
|
||||||
ZFS_LINUX_TEST_RESULT([bio_end_io_t_args], [
|
|
||||||
AC_MSG_RESULT(yes)
|
|
||||||
AC_DEFINE(HAVE_1ARG_BIO_END_IO_T, 1,
|
|
||||||
[bio_end_io_t wants 1 arg])
|
|
||||||
], [
|
|
||||||
AC_MSG_RESULT(no)
|
|
||||||
])
|
|
||||||
])
|
|
||||||
|
|
||||||
dnl #
|
dnl #
|
||||||
dnl # 4.13 API change
|
dnl # 4.13 API change
|
||||||
dnl # The bio->bi_error field was replaced with bio->bi_status which is an
|
dnl # The bio->bi_error field was replaced with bio->bi_status which is an
|
||||||
@ -513,7 +487,6 @@ AC_DEFUN([ZFS_AC_KERNEL_SRC_BIO], [
|
|||||||
ZFS_AC_KERNEL_SRC_REQ
|
ZFS_AC_KERNEL_SRC_REQ
|
||||||
ZFS_AC_KERNEL_SRC_BIO_OPS
|
ZFS_AC_KERNEL_SRC_BIO_OPS
|
||||||
ZFS_AC_KERNEL_SRC_BIO_SET_DEV
|
ZFS_AC_KERNEL_SRC_BIO_SET_DEV
|
||||||
ZFS_AC_KERNEL_SRC_BIO_END_IO_T_ARGS
|
|
||||||
ZFS_AC_KERNEL_SRC_BIO_BI_STATUS
|
ZFS_AC_KERNEL_SRC_BIO_BI_STATUS
|
||||||
ZFS_AC_KERNEL_SRC_BIO_BVEC_ITER
|
ZFS_AC_KERNEL_SRC_BIO_BVEC_ITER
|
||||||
ZFS_AC_KERNEL_SRC_BIO_SUBMIT_BIO
|
ZFS_AC_KERNEL_SRC_BIO_SUBMIT_BIO
|
||||||
@ -539,7 +512,6 @@ AC_DEFUN([ZFS_AC_KERNEL_BIO], [
|
|||||||
ZFS_AC_KERNEL_BIO_SET_OP_ATTRS
|
ZFS_AC_KERNEL_BIO_SET_OP_ATTRS
|
||||||
|
|
||||||
ZFS_AC_KERNEL_BIO_SET_DEV
|
ZFS_AC_KERNEL_BIO_SET_DEV
|
||||||
ZFS_AC_KERNEL_BIO_END_IO_T_ARGS
|
|
||||||
ZFS_AC_KERNEL_BIO_BI_STATUS
|
ZFS_AC_KERNEL_BIO_BI_STATUS
|
||||||
ZFS_AC_KERNEL_BIO_BVEC_ITER
|
ZFS_AC_KERNEL_BIO_BVEC_ITER
|
||||||
ZFS_AC_KERNEL_BIO_SUBMIT_BIO
|
ZFS_AC_KERNEL_BIO_SUBMIT_BIO
|
||||||
|
@ -276,12 +276,6 @@ errno_to_bi_status(int error)
|
|||||||
}
|
}
|
||||||
#endif /* HAVE_BIO_BI_STATUS */
|
#endif /* HAVE_BIO_BI_STATUS */
|
||||||
|
|
||||||
/*
|
|
||||||
* 4.3 API change
|
|
||||||
* The bio_endio() prototype changed slightly. These are helper
|
|
||||||
* macro's to ensure the prototype and invocation are handled.
|
|
||||||
*/
|
|
||||||
#ifdef HAVE_1ARG_BIO_END_IO_T
|
|
||||||
#ifdef HAVE_BIO_BI_STATUS
|
#ifdef HAVE_BIO_BI_STATUS
|
||||||
#define BIO_END_IO_ERROR(bio) bi_status_to_errno(bio->bi_status)
|
#define BIO_END_IO_ERROR(bio) bi_status_to_errno(bio->bi_status)
|
||||||
#define BIO_END_IO_PROTO(fn, x, z) static void fn(struct bio *x)
|
#define BIO_END_IO_PROTO(fn, x, z) static void fn(struct bio *x)
|
||||||
@ -306,11 +300,6 @@ bio_set_bi_error(struct bio *bio, int error)
|
|||||||
}
|
}
|
||||||
#endif /* HAVE_BIO_BI_STATUS */
|
#endif /* HAVE_BIO_BI_STATUS */
|
||||||
|
|
||||||
#else
|
|
||||||
#define BIO_END_IO_PROTO(fn, x, z) static void fn(struct bio *x, int z)
|
|
||||||
#define BIO_END_IO(bio, error) bio_endio(bio, error);
|
|
||||||
#endif /* HAVE_1ARG_BIO_END_IO_T */
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* 5.15 MACRO,
|
* 5.15 MACRO,
|
||||||
* GD_DEAD
|
* GD_DEAD
|
||||||
|
@ -813,15 +813,7 @@ BIO_END_IO_PROTO(vbio_completion, bio, error)
|
|||||||
ASSERT(zio);
|
ASSERT(zio);
|
||||||
|
|
||||||
/* Capture and log any errors */
|
/* Capture and log any errors */
|
||||||
#ifdef HAVE_1ARG_BIO_END_IO_T
|
|
||||||
zio->io_error = BIO_END_IO_ERROR(bio);
|
zio->io_error = BIO_END_IO_ERROR(bio);
|
||||||
#else
|
|
||||||
zio->io_error = 0;
|
|
||||||
if (error)
|
|
||||||
zio->io_error = -(error);
|
|
||||||
else if (!test_bit(BIO_UPTODATE, &bio->bi_flags))
|
|
||||||
zio->io_error = EIO;
|
|
||||||
#endif
|
|
||||||
ASSERT3U(zio->io_error, >=, 0);
|
ASSERT3U(zio->io_error, >=, 0);
|
||||||
|
|
||||||
if (zio->io_error)
|
if (zio->io_error)
|
||||||
@ -1077,14 +1069,7 @@ BIO_END_IO_PROTO(vdev_classic_physio_completion, bio, error)
|
|||||||
dio_request_t *dr = bio->bi_private;
|
dio_request_t *dr = bio->bi_private;
|
||||||
|
|
||||||
if (dr->dr_error == 0) {
|
if (dr->dr_error == 0) {
|
||||||
#ifdef HAVE_1ARG_BIO_END_IO_T
|
|
||||||
dr->dr_error = BIO_END_IO_ERROR(bio);
|
dr->dr_error = BIO_END_IO_ERROR(bio);
|
||||||
#else
|
|
||||||
if (error)
|
|
||||||
dr->dr_error = -(error);
|
|
||||||
else if (!test_bit(BIO_UPTODATE, &bio->bi_flags))
|
|
||||||
dr->dr_error = EIO;
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Drop reference acquired by vdev_classic_physio */
|
/* Drop reference acquired by vdev_classic_physio */
|
||||||
@ -1226,11 +1211,7 @@ retry:
|
|||||||
BIO_END_IO_PROTO(vdev_disk_io_flush_completion, bio, error)
|
BIO_END_IO_PROTO(vdev_disk_io_flush_completion, bio, error)
|
||||||
{
|
{
|
||||||
zio_t *zio = bio->bi_private;
|
zio_t *zio = bio->bi_private;
|
||||||
#ifdef HAVE_1ARG_BIO_END_IO_T
|
|
||||||
zio->io_error = BIO_END_IO_ERROR(bio);
|
zio->io_error = BIO_END_IO_ERROR(bio);
|
||||||
#else
|
|
||||||
zio->io_error = -error;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
if (zio->io_error && (zio->io_error == EOPNOTSUPP))
|
if (zio->io_error && (zio->io_error == EOPNOTSUPP))
|
||||||
zio->io_vd->vdev_nowritecache = B_TRUE;
|
zio->io_vd->vdev_nowritecache = B_TRUE;
|
||||||
@ -1268,11 +1249,8 @@ vdev_disk_io_flush(struct block_device *bdev, zio_t *zio)
|
|||||||
BIO_END_IO_PROTO(vdev_disk_discard_end_io, bio, error)
|
BIO_END_IO_PROTO(vdev_disk_discard_end_io, bio, error)
|
||||||
{
|
{
|
||||||
zio_t *zio = bio->bi_private;
|
zio_t *zio = bio->bi_private;
|
||||||
#ifdef HAVE_1ARG_BIO_END_IO_T
|
|
||||||
zio->io_error = BIO_END_IO_ERROR(bio);
|
zio->io_error = BIO_END_IO_ERROR(bio);
|
||||||
#else
|
|
||||||
zio->io_error = -error;
|
|
||||||
#endif
|
|
||||||
bio_put(bio);
|
bio_put(bio);
|
||||||
if (zio->io_error)
|
if (zio->io_error)
|
||||||
vdev_disk_error(zio);
|
vdev_disk_error(zio);
|
||||||
|
Loading…
Reference in New Issue
Block a user