[SCSI] qla2xxx: Avoid invalid request queue dereference for bad response packets.
authorArun Easi <arun.easi@qlogic.com>
Thu, 9 Feb 2012 19:16:01 +0000 (11:16 -0800)
committerJames Bottomley <JBottomley@Parallels.com>
Sun, 19 Feb 2012 14:35:19 +0000 (08:35 -0600)
Signed-off-by: Arun Easi <arun.easi@qlogic.com>
Signed-off-by: Chad Dupuis <chad.dupuis@qlogic.com>
Signed-off-by: James Bottomley <JBottomley@Parallels.com>
drivers/scsi/qla2xxx/qla_isr.c

index fdead64eb7d18b56a96be31d36859524ca4bdeb8..f79844ce7122d6026c703d64045caa418389c995 100644 (file)
@@ -1883,28 +1883,34 @@ qla2x00_error_entry(scsi_qla_host_t *vha, struct rsp_que *rsp, sts_entry_t *pkt)
        struct qla_hw_data *ha = vha->hw;
        const char func[] = "ERROR-IOCB";
        uint16_t que = MSW(pkt->handle);
-       struct req_que *req = ha->req_q_map[que];
+       struct req_que *req = NULL;
        int res = DID_ERROR << 16;
 
        ql_dbg(ql_dbg_async, vha, 0x502a,
            "type of error status in response: 0x%x\n", pkt->entry_status);
 
+       if (que >= ha->max_req_queues || !ha->req_q_map[que])
+               goto fatal;
+
+       req = ha->req_q_map[que];
+
        if (pkt->entry_status & RF_BUSY)
                res = DID_BUS_BUSY << 16;
 
        sp = qla2x00_get_sp_from_handle(vha, func, req, pkt);
-       if (sp)
+       if (sp) {
                sp->done(ha, sp, res);
-       else {
-               ql_log(ql_log_warn, vha, 0x5030,
-                   "Error entry - invalid handle.\n");
-
-               if (IS_QLA82XX(ha))
-                       set_bit(FCOE_CTX_RESET_NEEDED, &vha->dpc_flags);
-               else
-                       set_bit(ISP_ABORT_NEEDED, &vha->dpc_flags);
-               qla2xxx_wake_dpc(vha);
+               return;
        }
+fatal:
+       ql_log(ql_log_warn, vha, 0x5030,
+           "Error entry - invalid handle/queue.\n");
+
+       if (IS_QLA82XX(ha))
+               set_bit(FCOE_CTX_RESET_NEEDED, &vha->dpc_flags);
+       else
+               set_bit(ISP_ABORT_NEEDED, &vha->dpc_flags);
+       qla2xxx_wake_dpc(vha);
 }
 
 /**