Commit 13cb5042 authored by Peter Zijlstra's avatar Peter Zijlstra Committed by Ingo Molnar

sched/wait: Collapse __wait_event_lock_irq()

Reduce macro complexity by using the new ___wait_event() helper.
No change in behaviour, identical generated code.
Reviewed-by: default avatarOleg Nesterov <oleg@redhat.com>
Signed-off-by: default avatarPeter Zijlstra <peterz@infradead.org>
Link: http://lkml.kernel.org/r/20131002092528.612813379@infradead.orgSigned-off-by: default avatarIngo Molnar <mingo@kernel.org>
parent 48c25217
...@@ -624,20 +624,12 @@ do { \ ...@@ -624,20 +624,12 @@ do { \
#define __wait_event_lock_irq(wq, condition, lock, cmd) \ #define __wait_event_lock_irq(wq, condition, lock, cmd) \
do { \ ___wait_event(wq, condition, TASK_UNINTERRUPTIBLE, 0, \
DEFINE_WAIT(__wait); \ ___wait_nop_ret, \
\
for (;;) { \
prepare_to_wait(&wq, &__wait, TASK_UNINTERRUPTIBLE); \
if (condition) \
break; \
spin_unlock_irq(&lock); \ spin_unlock_irq(&lock); \
cmd; \ cmd; \
schedule(); \ schedule(); \
spin_lock_irq(&lock); \ spin_lock_irq(&lock))
} \
finish_wait(&wq, &__wait); \
} while (0)
/** /**
* wait_event_lock_irq_cmd - sleep until a condition gets true. The * wait_event_lock_irq_cmd - sleep until a condition gets true. The
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment