From 53c9b5bb2c2370e92da7cba4a8dc092d78e05c8e Mon Sep 17 00:00:00 2001 From: Jonathan Gray Date: Wed, 8 May 2019 23:35:24 +0000 Subject: Add wait_event_killable(). In linux TASK_KILLABLE only gets fatal signals, as we don't have an equivalent use PCATCH and check for all signals before and after msleep. Discussed with kettenis@. --- sys/dev/pci/drm/include/linux/wait.h | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) (limited to 'sys/dev/pci/drm') diff --git a/sys/dev/pci/drm/include/linux/wait.h b/sys/dev/pci/drm/include/linux/wait.h index f69a1c91a10..5860e906a5c 100644 --- a/sys/dev/pci/drm/include/linux/wait.h +++ b/sys/dev/pci/drm/include/linux/wait.h @@ -1,4 +1,4 @@ -/* $OpenBSD: wait.h,v 1.3 2019/05/01 07:22:24 jsg Exp $ */ +/* $OpenBSD: wait.h,v 1.4 2019/05/08 23:35:23 jsg Exp $ */ /* * Copyright (c) 2013, 2014, 2015 Mark Kettenis * Copyright (c) 2017 Martin Pieuchot @@ -146,6 +146,12 @@ do { \ __wait_event_intr_timeout(wq, condition, 0, 0); \ } while (0) +#define wait_event_killable(wq, condition) \ +do { \ + if (!(condition)) \ + __wait_event_intr_timeout(wq, condition, 0, PCATCH); \ +} while (0) + #define wait_event_interruptible(wq, condition) \ ({ \ int __ret = 0; \ -- cgit v1.2.3