提交 1498ada7 编写于 作者: T Tejun Heo 提交者: Jens Axboe

mtd_blkdevs: dequeue in-flight request

mtd_blkdevs processes requests one-by-one synchronously from a kthread
and can be easily converted to dequeueing model.  Convert it.

[ Impact: dequeue in-flight request ]
Signed-off-by: NTejun Heo <tj@kernel.org>
Cc: David Woodhouse <dwmw2@infradead.org>
Signed-off-by: NJens Axboe <jens.axboe@oracle.com>
上级 bab2a807
...@@ -89,18 +89,22 @@ static int mtd_blktrans_thread(void *arg) ...@@ -89,18 +89,22 @@ static int mtd_blktrans_thread(void *arg)
{ {
struct mtd_blktrans_ops *tr = arg; struct mtd_blktrans_ops *tr = arg;
struct request_queue *rq = tr->blkcore_priv->rq; struct request_queue *rq = tr->blkcore_priv->rq;
struct request *req = NULL;
/* we might get involved when memory gets low, so use PF_MEMALLOC */ /* we might get involved when memory gets low, so use PF_MEMALLOC */
current->flags |= PF_MEMALLOC; current->flags |= PF_MEMALLOC;
spin_lock_irq(rq->queue_lock); spin_lock_irq(rq->queue_lock);
while (!kthread_should_stop()) { while (!kthread_should_stop()) {
struct request *req;
struct mtd_blktrans_dev *dev; struct mtd_blktrans_dev *dev;
int res; int res;
req = elv_next_request(rq); if (!req) {
req = elv_next_request(rq);
if (req)
blkdev_dequeue_request(req);
}
if (!req) { if (!req) {
set_current_state(TASK_INTERRUPTIBLE); set_current_state(TASK_INTERRUPTIBLE);
spin_unlock_irq(rq->queue_lock); spin_unlock_irq(rq->queue_lock);
...@@ -120,8 +124,13 @@ static int mtd_blktrans_thread(void *arg) ...@@ -120,8 +124,13 @@ static int mtd_blktrans_thread(void *arg)
spin_lock_irq(rq->queue_lock); spin_lock_irq(rq->queue_lock);
__blk_end_request_cur(req, res); if (!__blk_end_request_cur(req, res))
req = NULL;
} }
if (req)
__blk_end_request_all(req, -EIO);
spin_unlock_irq(rq->queue_lock); spin_unlock_irq(rq->queue_lock);
return 0; return 0;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册