diff options
| author | Theodore Ts'o <tytso@mit.edu> | 2015-01-22 13:05:19 -0500 |
|---|---|---|
| committer | Mister Oyster <oysterized@gmail.com> | 2017-05-27 19:39:50 +0200 |
| commit | 6afe5ff62318fa752a965332d39e0033cd5b0d6e (patch) | |
| tree | 32500605970cfba8189e26f737c2085a3dae4ac3 /include/linux/wait.h | |
| parent | 0a313f06382a89f03ebcbc7de2b1b6926bf0923d (diff) | |
sched: add bit_wait_io for 3.18 ext4 backport
Excerpted from commit 743162013: "sched: Remove proliferation of
wait_on_bit() action functions"
Signed-off-by: Theodore Ts'o <tytso@mit.edu>
Diffstat (limited to 'include/linux/wait.h')
| -rw-r--r-- | include/linux/wait.h | 30 |
1 files changed, 29 insertions, 1 deletions
diff --git a/include/linux/wait.h b/include/linux/wait.h index c8e576022..569d33b6b 100644 --- a/include/linux/wait.h +++ b/include/linux/wait.h @@ -959,5 +959,33 @@ static inline int wait_on_bit_lock(void *word, int bit, return 0; return out_of_line_wait_on_bit_lock(word, bit, action, mode); } - + +/* 3.18 backport */ +extern int bit_wait_io(void *); + +/** + * wait_on_bit_io - wait for a bit to be cleared + * @word: the word being waited on, a kernel virtual address + * @bit: the bit of the word being waited on + * @mode: the task state to sleep in + * + * Use the standard hashed waitqueue table to wait for a bit + * to be cleared. This is similar to wait_on_bit(), but calls + * io_schedule() instead of schedule() for the actual waiting. + * + * Returned value will be zero if the bit was cleared, or non-zero + * if the process received a signal and the mode permitted wakeup + * on that signal. + */ +static inline int +wait_on_bit_io(void *word, int bit, unsigned mode) +{ + might_sleep(); + if (!test_bit(bit, word)) + return 0; + return out_of_line_wait_on_bit(word, bit, + bit_wait_io, + mode); +} + #endif |
