Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit b7882093 authored by Jens Axboe's avatar Jens Axboe
Browse files

blk-wbt: use wq_has_sleeper() for wq active check



We need the memory barrier before checking the list head,
use the appropriate helper for this. The matching queue
side memory barrier is provided by set_current_state().

Tested-by: default avatarAnchal Agarwal <anchalag@amazon.com>
Signed-off-by: default avatarJens Axboe <axboe@kernel.dk>
parent ffa358dc
Loading
Loading
Loading
Loading
+4 −4
Original line number Original line Diff line number Diff line
@@ -118,7 +118,7 @@ static void rwb_wake_all(struct rq_wb *rwb)
	for (i = 0; i < WBT_NUM_RWQ; i++) {
	for (i = 0; i < WBT_NUM_RWQ; i++) {
		struct rq_wait *rqw = &rwb->rq_wait[i];
		struct rq_wait *rqw = &rwb->rq_wait[i];


		if (waitqueue_active(&rqw->wait))
		if (wq_has_sleeper(&rqw->wait))
			wake_up_all(&rqw->wait);
			wake_up_all(&rqw->wait);
	}
	}
}
}
@@ -162,7 +162,7 @@ static void __wbt_done(struct rq_qos *rqos, enum wbt_flags wb_acct)
	if (inflight && inflight >= limit)
	if (inflight && inflight >= limit)
		return;
		return;


	if (waitqueue_active(&rqw->wait)) {
	if (wq_has_sleeper(&rqw->wait)) {
		int diff = limit - inflight;
		int diff = limit - inflight;


		if (!inflight || diff >= rwb->wb_background / 2)
		if (!inflight || diff >= rwb->wb_background / 2)
@@ -493,8 +493,8 @@ static void __wbt_wait(struct rq_wb *rwb, enum wbt_flags wb_acct,
	struct rq_wait *rqw = get_rq_wait(rwb, wb_acct);
	struct rq_wait *rqw = get_rq_wait(rwb, wb_acct);
	DECLARE_WAITQUEUE(wait, current);
	DECLARE_WAITQUEUE(wait, current);


	if (!waitqueue_active(&rqw->wait)
	if (!wq_has_sleeper(&rqw->wait) &&
		&& rq_wait_inc_below(rqw, get_limit(rwb, rw)))
	    rq_wait_inc_below(rqw, get_limit(rwb, rw)))
		return;
		return;


	add_wait_queue_exclusive(&rqw->wait, &wait);
	add_wait_queue_exclusive(&rqw->wait, &wait);