diff options
author | Johan Hedberg <johan.hedberg@intel.com> | 2015-01-30 06:14:36 -0500 |
---|---|---|
committer | Ingo Molnar <mingo@kernel.org> | 2015-02-04 01:52:32 -0500 |
commit | 44fc0e5eec00db5fba748803c95920098089c4cc (patch) | |
tree | bfd318700c9e487ad35ac0d855ea864f089f211a /include/linux/wait.h | |
parent | bfd9b2b5f80e7289fdd50210afe4d9ca5952a865 (diff) |
sched/wait: Introduce wait_on_bit_timeout()
Add a new wait_on_bit_timeout() helper, basically the same as
wait_on_bit() except that it also takes a 'timeout' parameter.
All the building blocks like bit_wait_timeout() and
out_of_line_wait_on_bit_timeout() are already in place so the
addition is rather simple.
Signed-off-by: Johan Hedberg <johan.hedberg@intel.com>
Signed-off-by: Peter Zijlstra (Intel) <peterz@infradead.org>
Cc: davem@davemloft.net
Cc: Linus Torvalds <torvalds@linux-foundation.org>
Link: http://lkml.kernel.org/r/1422616476-2917-2-git-send-email-johan.hedberg@gmail.com
Signed-off-by: Ingo Molnar <mingo@kernel.org>
Diffstat (limited to 'include/linux/wait.h')
-rw-r--r-- | include/linux/wait.h | 26 |
1 files changed, 26 insertions, 0 deletions
diff --git a/include/linux/wait.h b/include/linux/wait.h index 37423e0e1379..537d58eea8a0 100644 --- a/include/linux/wait.h +++ b/include/linux/wait.h | |||
@@ -990,6 +990,32 @@ wait_on_bit_io(void *word, int bit, unsigned mode) | |||
990 | } | 990 | } |
991 | 991 | ||
992 | /** | 992 | /** |
993 | * wait_on_bit_timeout - wait for a bit to be cleared or a timeout elapses | ||
994 | * @word: the word being waited on, a kernel virtual address | ||
995 | * @bit: the bit of the word being waited on | ||
996 | * @mode: the task state to sleep in | ||
997 | * @timeout: timeout, in jiffies | ||
998 | * | ||
999 | * Use the standard hashed waitqueue table to wait for a bit | ||
1000 | * to be cleared. This is similar to wait_on_bit(), except also takes a | ||
1001 | * timeout parameter. | ||
1002 | * | ||
1003 | * Returned value will be zero if the bit was cleared before the | ||
1004 | * @timeout elapsed, or non-zero if the @timeout elapsed or process | ||
1005 | * received a signal and the mode permitted wakeup on that signal. | ||
1006 | */ | ||
1007 | static inline int | ||
1008 | wait_on_bit_timeout(void *word, int bit, unsigned mode, unsigned long timeout) | ||
1009 | { | ||
1010 | might_sleep(); | ||
1011 | if (!test_bit(bit, word)) | ||
1012 | return 0; | ||
1013 | return out_of_line_wait_on_bit_timeout(word, bit, | ||
1014 | bit_wait_timeout, | ||
1015 | mode, timeout); | ||
1016 | } | ||
1017 | |||
1018 | /** | ||
993 | * wait_on_bit_action - wait for a bit to be cleared | 1019 | * wait_on_bit_action - wait for a bit to be cleared |
994 | * @word: the word being waited on, a kernel virtual address | 1020 | * @word: the word being waited on, a kernel virtual address |
995 | * @bit: the bit of the word being waited on | 1021 | * @bit: the bit of the word being waited on |