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

ps3disk: simplify request completion

ps3disk_interrupt() always completes requests fully but it uses
rq->hard_cur_sectors for FLUSH requests for some reason.  Drop them
and simply use __blk_end_request_all().

[ Impact: cleanup ]
Signed-off-by: NTejun Heo <tj@kernel.org>
Signed-off-by: NJens Axboe <jens.axboe@oracle.com>
上级 5b5c5d12
...@@ -231,7 +231,6 @@ static irqreturn_t ps3disk_interrupt(int irq, void *data) ...@@ -231,7 +231,6 @@ static irqreturn_t ps3disk_interrupt(int irq, void *data)
struct request *req; struct request *req;
int res, read, error; int res, read, error;
u64 tag, status; u64 tag, status;
unsigned long num_sectors;
const char *op; const char *op;
res = lv1_storage_get_async_status(dev->sbd.dev_id, &tag, &status); res = lv1_storage_get_async_status(dev->sbd.dev_id, &tag, &status);
...@@ -261,11 +260,9 @@ static irqreturn_t ps3disk_interrupt(int irq, void *data) ...@@ -261,11 +260,9 @@ static irqreturn_t ps3disk_interrupt(int irq, void *data)
if (req->cmd_type == REQ_TYPE_LINUX_BLOCK && if (req->cmd_type == REQ_TYPE_LINUX_BLOCK &&
req->cmd[0] == REQ_LB_OP_FLUSH) { req->cmd[0] == REQ_LB_OP_FLUSH) {
read = 0; read = 0;
num_sectors = req->hard_cur_sectors;
op = "flush"; op = "flush";
} else { } else {
read = !rq_data_dir(req); read = !rq_data_dir(req);
num_sectors = req->nr_sectors;
op = read ? "read" : "write"; op = read ? "read" : "write";
} }
if (status) { if (status) {
...@@ -281,7 +278,7 @@ static irqreturn_t ps3disk_interrupt(int irq, void *data) ...@@ -281,7 +278,7 @@ static irqreturn_t ps3disk_interrupt(int irq, void *data)
} }
spin_lock(&priv->lock); spin_lock(&priv->lock);
__blk_end_request(req, error, num_sectors << 9); __blk_end_request_all(req, error);
priv->req = NULL; priv->req = NULL;
ps3disk_do_request(dev, priv->queue); ps3disk_do_request(dev, priv->queue);
spin_unlock(&priv->lock); spin_unlock(&priv->lock);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册