[S390] qdio: remove dead timeout handler
The QDIO ccw devices are started by ccw_device_start so no timeout can occur for the interrupt handler. Remove the dead code. In case of an I/O error set the device state to error and wake up a possibly running qdio_shutdown waiter. Signed-off-by: Jan Glauber <jang@linux.vnet.ibm.com> Signed-off-by: Martin Schwidefsky <schwidefsky@de.ibm.com>
This commit is contained in:
parent
43ae8a1b32
commit
75cb71f318
|
@ -881,42 +881,6 @@ static void qdio_handle_activate_check(struct ccw_device *cdev,
|
||||||
qdio_set_state(irq_ptr, QDIO_IRQ_STATE_STOPPED);
|
qdio_set_state(irq_ptr, QDIO_IRQ_STATE_STOPPED);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void qdio_call_shutdown(struct work_struct *work)
|
|
||||||
{
|
|
||||||
struct ccw_device_private *priv;
|
|
||||||
struct ccw_device *cdev;
|
|
||||||
|
|
||||||
priv = container_of(work, struct ccw_device_private, kick_work);
|
|
||||||
cdev = priv->cdev;
|
|
||||||
qdio_shutdown(cdev, QDIO_FLAG_CLEANUP_USING_CLEAR);
|
|
||||||
put_device(&cdev->dev);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void qdio_int_error(struct ccw_device *cdev)
|
|
||||||
{
|
|
||||||
struct qdio_irq *irq_ptr = cdev->private->qdio_data;
|
|
||||||
|
|
||||||
switch (irq_ptr->state) {
|
|
||||||
case QDIO_IRQ_STATE_INACTIVE:
|
|
||||||
case QDIO_IRQ_STATE_CLEANUP:
|
|
||||||
qdio_set_state(irq_ptr, QDIO_IRQ_STATE_ERR);
|
|
||||||
break;
|
|
||||||
case QDIO_IRQ_STATE_ESTABLISHED:
|
|
||||||
case QDIO_IRQ_STATE_ACTIVE:
|
|
||||||
qdio_set_state(irq_ptr, QDIO_IRQ_STATE_STOPPED);
|
|
||||||
if (get_device(&cdev->dev)) {
|
|
||||||
/* Can't call shutdown from interrupt context. */
|
|
||||||
PREPARE_WORK(&cdev->private->kick_work,
|
|
||||||
qdio_call_shutdown);
|
|
||||||
queue_work(ccw_device_work, &cdev->private->kick_work);
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
WARN_ON(1);
|
|
||||||
}
|
|
||||||
wake_up(&cdev->private->wait_q);
|
|
||||||
}
|
|
||||||
|
|
||||||
static int qdio_establish_check_errors(struct ccw_device *cdev, int cstat,
|
static int qdio_establish_check_errors(struct ccw_device *cdev, int cstat,
|
||||||
int dstat)
|
int dstat)
|
||||||
{
|
{
|
||||||
|
@ -973,10 +937,8 @@ void qdio_int_handler(struct ccw_device *cdev, unsigned long intparm,
|
||||||
switch (PTR_ERR(irb)) {
|
switch (PTR_ERR(irb)) {
|
||||||
case -EIO:
|
case -EIO:
|
||||||
DBF_ERROR("%4x IO error", irq_ptr->schid.sch_no);
|
DBF_ERROR("%4x IO error", irq_ptr->schid.sch_no);
|
||||||
return;
|
qdio_set_state(irq_ptr, QDIO_IRQ_STATE_ERR);
|
||||||
case -ETIMEDOUT:
|
wake_up(&cdev->private->wait_q);
|
||||||
DBF_ERROR("%4x IO timeout", irq_ptr->schid.sch_no);
|
|
||||||
qdio_int_error(cdev);
|
|
||||||
return;
|
return;
|
||||||
default:
|
default:
|
||||||
WARN_ON(1);
|
WARN_ON(1);
|
||||||
|
@ -1001,7 +963,6 @@ void qdio_int_handler(struct ccw_device *cdev, unsigned long intparm,
|
||||||
case QDIO_IRQ_STATE_ACTIVE:
|
case QDIO_IRQ_STATE_ACTIVE:
|
||||||
if (cstat & SCHN_STAT_PCI) {
|
if (cstat & SCHN_STAT_PCI) {
|
||||||
qdio_int_handler_pci(irq_ptr);
|
qdio_int_handler_pci(irq_ptr);
|
||||||
/* no state change so no need to wake up wait_q */
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
if ((cstat & ~SCHN_STAT_PCI) || dstat) {
|
if ((cstat & ~SCHN_STAT_PCI) || dstat) {
|
||||||
|
|
Loading…
Reference in New Issue
Block a user