[SRU B][PATCH 11/13] blk-wbt: abstract out end IO completion handler
Mauricio Faria de Oliveira
mfo at canonical.com
Thu Jan 10 03:12:17 UTC 2019
From: Jens Axboe <axboe at kernel.dk>
BugLink: https://bugs.launchpad.net/bugs/1810998
Prep patch for calling the handler from a different context,
no functional changes in this patch.
Tested-by: Agarwal, Anchal <anchalag at amazon.com>
Signed-off-by: Jens Axboe <axboe at kernel.dk>
(cherry picked from commit 061a5427530633de93ace4ef001b99961984af62)
Signed-off-by: Mauricio Faria de Oliveira <mfo at canonical.com>
---
block/blk-wbt.c | 21 ++++++++++++++-------
1 file changed, 14 insertions(+), 7 deletions(-)
diff --git a/block/blk-wbt.c b/block/blk-wbt.c
index 2d9e0e8b92e1..6180dd527666 100644
--- a/block/blk-wbt.c
+++ b/block/blk-wbt.c
@@ -121,16 +121,11 @@ static void rwb_wake_all(struct rq_wb *rwb)
}
}
-static void __wbt_done(struct rq_qos *rqos, enum wbt_flags wb_acct)
+static void wbt_rqw_done(struct rq_wb *rwb, struct rq_wait *rqw,
+ enum wbt_flags wb_acct)
{
- struct rq_wb *rwb = RQWB(rqos);
- struct rq_wait *rqw;
int inflight, limit;
- if (!(wb_acct & WBT_TRACKED))
- return;
-
- rqw = get_rq_wait(rwb, wb_acct);
inflight = atomic_dec_return(&rqw->inflight);
/*
@@ -165,6 +160,18 @@ static void __wbt_done(struct rq_qos *rqos, enum wbt_flags wb_acct)
}
}
+static void __wbt_done(struct rq_qos *rqos, enum wbt_flags wb_acct)
+{
+ struct rq_wb *rwb = RQWB(rqos);
+ struct rq_wait *rqw;
+
+ if (!(wb_acct & WBT_TRACKED))
+ return;
+
+ rqw = get_rq_wait(rwb, wb_acct);
+ wbt_rqw_done(rwb, rqw, wb_acct);
+}
+
/*
* Called on completion of a request. Note that it's also called when
* a request is merged, when the request gets freed.
--
2.17.1
More information about the kernel-team
mailing list