diff options
author | Brian King <brking@linux.vnet.ibm.com> | 2011-04-27 11:27:08 -0400 |
---|---|---|
committer | James Bottomley <James.Bottomley@suse.de> | 2011-05-01 13:09:58 -0400 |
commit | 201aed678482f247aa96bd8fcd9e960fefd82d59 (patch) | |
tree | 206d28c41b43265a5abaf651b04fa503765b9101 /drivers/scsi | |
parent | 4d4dd7065572225bf6d97e5eb9915d94f9d53548 (diff) |
[SCSI] ibmvscsi: Improve CRQ reset reliability
This patch fixes an issue seen where an event occurs
which causes the ibmvscsi driver to reset its CRQ. Upon
re-registering its CRQ, it receives H_CLOSED, indicating
the Virtual I/O Server is not yet ready to receive commands.
This resulted in the ibmvscsi driver essentially offlining
the adapter and not recovering. The fix is to re-enable
our interrupt so that when the Virtual I/O server is ready
and sends a CRQ init, we will be able to receive it and
resume initialization of the VSCSI adapter.
Signed-off-by: Brian King <brking@linux.vnet.ibm.com>
Signed-off-by: James Bottomley <James.Bottomley@suse.de>
Diffstat (limited to 'drivers/scsi')
-rw-r--r-- | drivers/scsi/ibmvscsi/ibmvscsi.c | 3 |
1 files changed, 1 insertions, 2 deletions
diff --git a/drivers/scsi/ibmvscsi/ibmvscsi.c b/drivers/scsi/ibmvscsi/ibmvscsi.c index 041958453e2a..3d391dc3f11f 100644 --- a/drivers/scsi/ibmvscsi/ibmvscsi.c +++ b/drivers/scsi/ibmvscsi/ibmvscsi.c | |||
@@ -1849,8 +1849,7 @@ static void ibmvscsi_do_work(struct ibmvscsi_host_data *hostdata) | |||
1849 | rc = ibmvscsi_ops->reset_crq_queue(&hostdata->queue, hostdata); | 1849 | rc = ibmvscsi_ops->reset_crq_queue(&hostdata->queue, hostdata); |
1850 | if (!rc) | 1850 | if (!rc) |
1851 | rc = ibmvscsi_ops->send_crq(hostdata, 0xC001000000000000LL, 0); | 1851 | rc = ibmvscsi_ops->send_crq(hostdata, 0xC001000000000000LL, 0); |
1852 | if (!rc) | 1852 | vio_enable_interrupts(to_vio_dev(hostdata->dev)); |
1853 | rc = vio_enable_interrupts(to_vio_dev(hostdata->dev)); | ||
1854 | } else if (hostdata->reenable_crq) { | 1853 | } else if (hostdata->reenable_crq) { |
1855 | smp_rmb(); | 1854 | smp_rmb(); |
1856 | action = "enable"; | 1855 | action = "enable"; |