diff options
Diffstat (limited to 'include/linux/rcuwait.h')
| -rw-r--r-- | include/linux/rcuwait.h | 12 | 
1 files changed, 10 insertions, 2 deletions
diff --git a/include/linux/rcuwait.h b/include/linux/rcuwait.h index 75c97e4bbc57..2ffe1ee6d482 100644 --- a/include/linux/rcuwait.h +++ b/include/linux/rcuwait.h @@ -3,6 +3,7 @@  #define _LINUX_RCUWAIT_H_  #include <linux/rcupdate.h> +#include <linux/sched/signal.h>  /*   * rcuwait provides a way of blocking and waking up a single @@ -30,23 +31,30 @@ extern void rcuwait_wake_up(struct rcuwait *w);   * The caller is responsible for locking around rcuwait_wait_event(),   * such that writes to @task are properly serialized.   */ -#define rcuwait_wait_event(w, condition)				\ +#define rcuwait_wait_event(w, condition, state)				\  ({									\ +	int __ret = 0;							\  	rcu_assign_pointer((w)->task, current);				\  	for (;;) {							\  		/*							\  		 * Implicit barrier (A) pairs with (B) in		\  		 * rcuwait_wake_up().					\  		 */							\ -		set_current_state(TASK_UNINTERRUPTIBLE);		\ +		set_current_state(state);				\  		if (condition)						\  			break;						\  									\ +		if (signal_pending_state(state, current)) {		\ +			__ret = -EINTR;					\ +			break;						\ +		}							\ +									\  		schedule();						\  	}								\  									\  	WRITE_ONCE((w)->task, NULL);					\  	__set_current_state(TASK_RUNNING);				\ +	__ret;								\  })  #endif /* _LINUX_RCUWAIT_H_ */  |