simple-wait: rename and export the equivalent of waitqueue_active()
The function "swait_head_has_waiters()" was internalized into wait-simple.c but it parallels the waitqueue_active of normal waitqueue support. Given that there are over 150 waitqueue_active users in drivers/ fs/ kernel/ and the like, lets make it globally visible, and rename it to parallel the waitqueue_active accordingly. We'll need to do this if we expect to expand its usage beyond RT. Signed-off-by: Paul Gortmaker <paul.gortmaker@windriver.com> Signed-off-by: Sebastian Andrzej Siewior <bigeasy@linutronix.de>
This commit is contained in:
parent
65870d64d3
commit
ca0179a36a
|
@ -47,6 +47,14 @@ extern void swait_prepare(struct swait_head *head, struct swaiter *w, int state)
|
||||||
extern void swait_finish_locked(struct swait_head *head, struct swaiter *w);
|
extern void swait_finish_locked(struct swait_head *head, struct swaiter *w);
|
||||||
extern void swait_finish(struct swait_head *head, struct swaiter *w);
|
extern void swait_finish(struct swait_head *head, struct swaiter *w);
|
||||||
|
|
||||||
|
/* Check whether a head has waiters enqueued */
|
||||||
|
static inline bool swaitqueue_active(struct swait_head *h)
|
||||||
|
{
|
||||||
|
/* Make sure the condition is visible before checking list_empty() */
|
||||||
|
smp_mb();
|
||||||
|
return !list_empty(&h->list);
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Wakeup functions
|
* Wakeup functions
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -26,14 +26,6 @@ static inline void __swait_dequeue(struct swaiter *w)
|
||||||
list_del_init(&w->node);
|
list_del_init(&w->node);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Check whether a head has waiters enqueued */
|
|
||||||
static inline bool swait_head_has_waiters(struct swait_head *h)
|
|
||||||
{
|
|
||||||
/* Make sure the condition is visible before checking list_empty() */
|
|
||||||
smp_mb();
|
|
||||||
return !list_empty(&h->list);
|
|
||||||
}
|
|
||||||
|
|
||||||
void __init_swait_head(struct swait_head *head, struct lock_class_key *key)
|
void __init_swait_head(struct swait_head *head, struct lock_class_key *key)
|
||||||
{
|
{
|
||||||
raw_spin_lock_init(&head->lock);
|
raw_spin_lock_init(&head->lock);
|
||||||
|
@ -112,7 +104,7 @@ __swait_wake(struct swait_head *head, unsigned int state, unsigned int num)
|
||||||
unsigned long flags;
|
unsigned long flags;
|
||||||
int woken;
|
int woken;
|
||||||
|
|
||||||
if (!swait_head_has_waiters(head))
|
if (!swaitqueue_active(head))
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
raw_spin_lock_irqsave(&head->lock, flags);
|
raw_spin_lock_irqsave(&head->lock, flags);
|
||||||
|
|
Loading…
Reference in New Issue