]> git.hungrycats.org Git - linux/commitdiff
scsi: qla2xxx: Fix driver reload for ISP82xx
authorHimanshu Madhani <hmadhani@marvell.com>
Fri, 30 Aug 2019 22:23:59 +0000 (15:23 -0700)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Tue, 17 Dec 2019 19:08:28 +0000 (20:08 +0100)
[ Upstream commit 32a13df21668b92f70f0673387f29251e0f285ec ]

HINT_MBX_INT_PENDING is not guaranteed to be cleared by firmware. Remove
check that prevent driver load with ISP82XX.

Signed-off-by: Quinn Tran <qutran@marvell.com>
Signed-off-by: Himanshu Madhani <hmadhani@marvell.com>
Reviewed-by: Ewan D. Milne <emilne@redhat.com>
Link: https://lore.kernel.org/r/20190830222402.23688-4-hmadhani@marvell.com
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
Signed-off-by: Sasha Levin <sashal@kernel.org>
drivers/scsi/qla2xxx/qla_mbx.c
drivers/scsi/qla2xxx/qla_nx.c

index ac4640f456786dc3a0828f8fb6f16582ba6256a8..45548628c6f3e566dd9319420586380d1adb2700 100644 (file)
@@ -253,21 +253,9 @@ qla2x00_mailbox_command(scsi_qla_host_t *vha, mbx_cmd_t *mcp)
        if ((!abort_active && io_lock_on) || IS_NOPOLLING_TYPE(ha)) {
                set_bit(MBX_INTR_WAIT, &ha->mbx_cmd_flags);
 
-               if (IS_P3P_TYPE(ha)) {
-                       if (RD_REG_DWORD(&reg->isp82.hint) &
-                               HINT_MBX_INT_PENDING) {
-                               ha->flags.mbox_busy = 0;
-                               spin_unlock_irqrestore(&ha->hardware_lock,
-                                       flags);
-
-                               atomic_dec(&ha->num_pend_mbx_stage2);
-                               ql_dbg(ql_dbg_mbx, vha, 0x1010,
-                                   "Pending mailbox timeout, exiting.\n");
-                               rval = QLA_FUNCTION_TIMEOUT;
-                               goto premature_exit;
-                       }
+               if (IS_P3P_TYPE(ha))
                        WRT_REG_DWORD(&reg->isp82.hint, HINT_MBX_INT_PENDING);
-               else if (IS_FWI2_CAPABLE(ha))
+               else if (IS_FWI2_CAPABLE(ha))
                        WRT_REG_DWORD(&reg->isp24.hccr, HCCRX_SET_HOST_INT);
                else
                        WRT_REG_WORD(&reg->isp.hccr, HCCR_SET_HOST_INT);
index 6ce0f026debb132caba10258a46f018ffc3401dc..3a23827e0f0bc8fab6566ad0746ca478808489fd 100644 (file)
@@ -2287,7 +2287,8 @@ qla82xx_disable_intrs(struct qla_hw_data *ha)
 {
        scsi_qla_host_t *vha = pci_get_drvdata(ha->pdev);
 
-       qla82xx_mbx_intr_disable(vha);
+       if (ha->interrupts_on)
+               qla82xx_mbx_intr_disable(vha);
 
        spin_lock_irq(&ha->hardware_lock);
        if (IS_QLA8044(ha))