mirror of
https://git.proxmox.com/git/mirror_zfs.git
synced 2025-01-26 18:04:22 +03:00
d6b8c17f1d
See torvalds/linux@a2b80ce87a. It claims the task arg is always `current`, and so it is with us, so this is a safe change to make. The only spanner is that we also support the older pre-5.17 3-arg dequeue_signal() which had different meaning, so we have to check the types to get the right one. Sponsored-by: https://despairlabs.com/sponsor/ Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov> Signed-off-by: Rob Norris <robn@despairlabs.com> Closes #16582
92 lines
2.9 KiB
Plaintext
92 lines
2.9 KiB
Plaintext
AC_DEFUN([ZFS_AC_KERNEL_KTHREAD_COMPLETE_AND_EXIT], [
|
|
dnl #
|
|
dnl # 5.17 API,
|
|
dnl # cead18552660702a4a46f58e65188fe5f36e9dfe ("exit: Rename complete_and_exit to kthread_complete_and_exit")
|
|
dnl #
|
|
dnl # Also moves the definition from include/linux/kernel.h to include/linux/kthread.h
|
|
dnl #
|
|
AC_MSG_CHECKING([whether kthread_complete_and_exit() is available])
|
|
ZFS_LINUX_TEST_RESULT([kthread_complete_and_exit], [
|
|
AC_MSG_RESULT(yes)
|
|
AC_DEFINE(SPL_KTHREAD_COMPLETE_AND_EXIT, kthread_complete_and_exit, [kthread_complete_and_exit() available])
|
|
], [
|
|
AC_MSG_RESULT(no)
|
|
AC_DEFINE(SPL_KTHREAD_COMPLETE_AND_EXIT, complete_and_exit, [using complete_and_exit() instead])
|
|
])
|
|
])
|
|
|
|
AC_DEFUN([ZFS_AC_KERNEL_KTHREAD_DEQUEUE_SIGNAL], [
|
|
dnl #
|
|
dnl # 5.17 API: enum pid_type * as new 4th dequeue_signal() argument,
|
|
dnl # 5768d8906bc23d512b1a736c1e198aa833a6daa4 ("signal: Requeue signals in the appropriate queue")
|
|
dnl #
|
|
dnl # int dequeue_signal(struct task_struct *task, sigset_t *mask, kernel_siginfo_t *info);
|
|
dnl # int dequeue_signal(struct task_struct *task, sigset_t *mask, kernel_siginfo_t *info, enum pid_type *type);
|
|
dnl #
|
|
dnl # 6.12 API: first arg struct_task* removed
|
|
dnl # int dequeue_signal(sigset_t *mask, kernel_siginfo_t *info, enum pid_type *type);
|
|
dnl #
|
|
AC_MSG_CHECKING([whether dequeue_signal() takes 4 arguments])
|
|
ZFS_LINUX_TEST_RESULT([kthread_dequeue_signal_4arg], [
|
|
AC_MSG_RESULT(yes)
|
|
AC_DEFINE(HAVE_DEQUEUE_SIGNAL_4ARG, 1,
|
|
[dequeue_signal() takes 4 arguments])
|
|
], [
|
|
AC_MSG_RESULT(no)
|
|
AC_MSG_CHECKING([whether dequeue_signal() a task argument])
|
|
ZFS_LINUX_TEST_RESULT([kthread_dequeue_signal_3arg_task], [
|
|
AC_MSG_RESULT(yes)
|
|
AC_DEFINE(HAVE_DEQUEUE_SIGNAL_3ARG_TASK, 1,
|
|
[dequeue_signal() takes a task argument])
|
|
], [
|
|
AC_MSG_RESULT(no)
|
|
])
|
|
])
|
|
])
|
|
|
|
AC_DEFUN([ZFS_AC_KERNEL_SRC_KTHREAD_COMPLETE_AND_EXIT], [
|
|
ZFS_LINUX_TEST_SRC([kthread_complete_and_exit], [
|
|
#include <linux/kthread.h>
|
|
], [
|
|
struct completion *completion = NULL;
|
|
long code = 0;
|
|
|
|
kthread_complete_and_exit(completion, code);
|
|
])
|
|
])
|
|
|
|
AC_DEFUN([ZFS_AC_KERNEL_SRC_KTHREAD_DEQUEUE_SIGNAL], [
|
|
ZFS_LINUX_TEST_SRC([kthread_dequeue_signal_3arg_task], [
|
|
#include <linux/sched/signal.h>
|
|
], [
|
|
struct task_struct *task = NULL;
|
|
sigset_t *mask = NULL;
|
|
kernel_siginfo_t *info = NULL;
|
|
int error __attribute__ ((unused));
|
|
|
|
error = dequeue_signal(task, mask, info);
|
|
])
|
|
|
|
ZFS_LINUX_TEST_SRC([kthread_dequeue_signal_4arg], [
|
|
#include <linux/sched/signal.h>
|
|
], [
|
|
struct task_struct *task = NULL;
|
|
sigset_t *mask = NULL;
|
|
kernel_siginfo_t *info = NULL;
|
|
enum pid_type *type = NULL;
|
|
int error __attribute__ ((unused));
|
|
|
|
error = dequeue_signal(task, mask, info, type);
|
|
])
|
|
])
|
|
|
|
AC_DEFUN([ZFS_AC_KERNEL_KTHREAD], [
|
|
ZFS_AC_KERNEL_KTHREAD_COMPLETE_AND_EXIT
|
|
ZFS_AC_KERNEL_KTHREAD_DEQUEUE_SIGNAL
|
|
])
|
|
|
|
AC_DEFUN([ZFS_AC_KERNEL_SRC_KTHREAD], [
|
|
ZFS_AC_KERNEL_SRC_KTHREAD_COMPLETE_AND_EXIT
|
|
ZFS_AC_KERNEL_SRC_KTHREAD_DEQUEUE_SIGNAL
|
|
])
|