提交 842d3fba 编写于 作者: S Stefan Bader 提交者: Linus Torvalds

[PATCH] s390: tape retry flooding by deferred CC in interrupt

If a deferred CC happens there will be lots of messages, because the retry is
done immediatly in the interrupt handler which can be too fast.  To avoid this
requeue the request and schedule the queue to be processed.
Signed-off-by: NStefan Bader <shbader@de.ibm.com>
Signed-off-by: NMartin Schwidefsky <schwidefsky@de.ibm.com>
Signed-off-by: NAndrew Morton <akpm@osdl.org>
Signed-off-by: NLinus Torvalds <torvalds@osdl.org>
上级 20c64468
...@@ -1064,15 +1064,16 @@ __tape_do_irq (struct ccw_device *cdev, unsigned long intparm, struct irb *irb) ...@@ -1064,15 +1064,16 @@ __tape_do_irq (struct ccw_device *cdev, unsigned long intparm, struct irb *irb)
/* /*
* If the condition code is not zero and the start function bit is * If the condition code is not zero and the start function bit is
* still set, this is an deferred error and the last start I/O did * still set, this is an deferred error and the last start I/O did
* not succeed. Restart the request now. * not succeed. At this point the condition that caused the deferred
* error might still apply. So we just schedule the request to be
* started later.
*/ */
if (irb->scsw.cc != 0 && (irb->scsw.fctl & SCSW_FCTL_START_FUNC)) { if (irb->scsw.cc != 0 && (irb->scsw.fctl & SCSW_FCTL_START_FUNC)) {
PRINT_WARN("(%s): deferred cc=%i. restaring\n", PRINT_WARN("(%s): deferred cc=%i. restaring\n",
cdev->dev.bus_id, cdev->dev.bus_id,
irb->scsw.cc); irb->scsw.cc);
rc = __tape_start_io(device, request); request->status = TAPE_REQUEST_QUEUED;
if (rc) schedule_work(&device->tape_dnr);
__tape_end_request(device, request, rc);
return; return;
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册