Linux 5.17 compat: dequeue_signal() takes a 4th argument
Linux 5.17's dequeue_signal() takes an additional enum pid_type * output argument Upstream commit 5768d8906bc23d512b1a736c1e198aa833a6daa4 ("signal: Requeue signals in the appropriate queue") Reviewed-by: Tony Hutter <hutter2@llnl.gov> Reviewed-by: Brian Behlendorf <behlendorf1@llnl.gov> Signed-off-by: Ahelenia Ziemiańska <nabijaczleweli@nabijaczleweli.xyz> Closes #12989
This commit is contained in:
parent
2ce06d93a8
commit
f42c126029
|
@ -1,4 +1,4 @@
|
||||||
AC_DEFUN([ZFS_AC_KERNEL_KTHREAD], [
|
AC_DEFUN([ZFS_AC_KERNEL_KTHREAD_COMPLETE_AND_EXIT], [
|
||||||
dnl #
|
dnl #
|
||||||
dnl # 5.17 API,
|
dnl # 5.17 API,
|
||||||
dnl # cead18552660702a4a46f58e65188fe5f36e9dfe ("exit: Rename complete_and_exit to kthread_complete_and_exit")
|
dnl # cead18552660702a4a46f58e65188fe5f36e9dfe ("exit: Rename complete_and_exit to kthread_complete_and_exit")
|
||||||
|
@ -15,7 +15,24 @@ AC_DEFUN([ZFS_AC_KERNEL_KTHREAD], [
|
||||||
])
|
])
|
||||||
])
|
])
|
||||||
|
|
||||||
AC_DEFUN([ZFS_AC_KERNEL_SRC_KTHREAD], [
|
AC_DEFUN([ZFS_AC_KERNEL_KTHREAD_DEQUEUE_SIGNAL_4ARG], [
|
||||||
|
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 #
|
||||||
|
AC_MSG_CHECKING([whether dequeue_signal() takes 4 arguments])
|
||||||
|
ZFS_LINUX_TEST_RESULT([kthread_dequeue_signal], [
|
||||||
|
AC_MSG_RESULT(yes)
|
||||||
|
AC_DEFINE(HAVE_DEQUEUE_SIGNAL_4ARG, 1, [dequeue_signal() takes 4 arguments])
|
||||||
|
], [
|
||||||
|
AC_MSG_RESULT(no)
|
||||||
|
])
|
||||||
|
])
|
||||||
|
|
||||||
|
AC_DEFUN([ZFS_AC_KERNEL_SRC_KTHREAD_COMPLETE_AND_EXIT], [
|
||||||
ZFS_LINUX_TEST_SRC([kthread_complete_and_exit], [
|
ZFS_LINUX_TEST_SRC([kthread_complete_and_exit], [
|
||||||
#include <linux/kthread.h>
|
#include <linux/kthread.h>
|
||||||
], [
|
], [
|
||||||
|
@ -25,3 +42,27 @@ AC_DEFUN([ZFS_AC_KERNEL_SRC_KTHREAD], [
|
||||||
kthread_complete_and_exit(completion, code);
|
kthread_complete_and_exit(completion, code);
|
||||||
])
|
])
|
||||||
])
|
])
|
||||||
|
|
||||||
|
AC_DEFUN([ZFS_AC_KERNEL_SRC_KTHREAD_DEQUEUE_SIGNAL_4ARG], [
|
||||||
|
ZFS_LINUX_TEST_SRC([kthread_dequeue_signal], [
|
||||||
|
#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_4ARG
|
||||||
|
])
|
||||||
|
|
||||||
|
AC_DEFUN([ZFS_AC_KERNEL_SRC_KTHREAD], [
|
||||||
|
ZFS_AC_KERNEL_SRC_KTHREAD_COMPLETE_AND_EXIT
|
||||||
|
ZFS_AC_KERNEL_SRC_KTHREAD_DEQUEUE_SIGNAL_4ARG
|
||||||
|
])
|
||||||
|
|
|
@ -188,7 +188,12 @@ issig(int why)
|
||||||
|
|
||||||
spin_lock_irq(&task->sighand->siglock);
|
spin_lock_irq(&task->sighand->siglock);
|
||||||
int ret;
|
int ret;
|
||||||
|
#ifdef HAVE_DEQUEUE_SIGNAL_4ARG
|
||||||
|
enum pid_type __type;
|
||||||
|
if ((ret = dequeue_signal(task, &set, &__info, &__type)) != 0) {
|
||||||
|
#else
|
||||||
if ((ret = dequeue_signal(task, &set, &__info)) != 0) {
|
if ((ret = dequeue_signal(task, &set, &__info)) != 0) {
|
||||||
|
#endif
|
||||||
#ifdef HAVE_SIGNAL_STOP
|
#ifdef HAVE_SIGNAL_STOP
|
||||||
spin_unlock_irq(&task->sighand->siglock);
|
spin_unlock_irq(&task->sighand->siglock);
|
||||||
kernel_signal_stop();
|
kernel_signal_stop();
|
||||||
|
|
Loading…
Reference in New Issue