Since Coverity cannot know that rport != NULL in qla2xxx_queuecommand()
and since there is code in that function that dereferences the rport
pointer, modify qla2xxx_queuecommand() such that it fails SCSI commands
if rport == NULL.

Cc: Himanshu Madhani <hmadh...@marvell.com>
Cc: Giridhar Malavali <gmalav...@marvell.com>
Signed-off-by: Bart Van Assche <bvanass...@acm.org>
---
 drivers/scsi/qla2xxx/qla_os.c | 5 +++--
 1 file changed, 3 insertions(+), 2 deletions(-)

diff --git a/drivers/scsi/qla2xxx/qla_os.c b/drivers/scsi/qla2xxx/qla_os.c
index a3561e461aa5..5cfdf0cc3846 100644
--- a/drivers/scsi/qla2xxx/qla_os.c
+++ b/drivers/scsi/qla2xxx/qla_os.c
@@ -859,7 +859,8 @@ qla2xxx_queuecommand(struct Scsi_Host *host, struct 
scsi_cmnd *cmd)
        uint32_t tag;
        uint16_t hwq;
 
-       if (unlikely(test_bit(UNLOADING, &base_vha->dpc_flags))) {
+       if (unlikely(test_bit(UNLOADING, &base_vha->dpc_flags)) ||
+           WARN_ON_ONCE(!rport)) {
                cmd->result = DID_NO_CONNECT << 16;
                goto qc24_fail_command;
        }
@@ -982,7 +983,7 @@ qla2xxx_mqueuecommand(struct Scsi_Host *host, struct 
scsi_cmnd *cmd,
        srb_t *sp;
        int rval;
 
-       rval = fc_remote_port_chkready(rport);
+       rval = rport ? fc_remote_port_chkready(rport) : FC_PORTSTATE_OFFLINE;
        if (rval) {
                cmd->result = rval;
                ql_dbg(ql_dbg_io + ql_dbg_verbose, vha, 0x3076,
-- 
2.21.0.196.g041f5ea1cf98

Reply via email to