diff --git a/qla2x00t-32gbit/qla_init.c b/qla2x00t-32gbit/qla_init.c index ef4c3abcc..1f10663ee 100644 --- a/qla2x00t-32gbit/qla_init.c +++ b/qla2x00t-32gbit/qla_init.c @@ -465,7 +465,7 @@ void qla24xx_handle_adisc_event(scsi_qla_host_t *vha, struct event_arg *ea) fcport->fw_login_state, ea->rc, fcport->login_gen, ea->sp->gen2, fcport->rscn_gen, ea->sp->gen1, fcport->loop_id); - if (ea->data[0] != MBS_COMMAND_COMPLETE) { + if (ea->rc != (MBS_COMMAND_COMPLETE & MBS_MASK)) { ql_dbg(ql_dbg_disc, vha, 0x2066, "%s %s: adisc fail: post delete\n", __func__, wwn_to_str(ea->fcport->port_name)); @@ -1884,7 +1884,7 @@ qla24xx_async_abort_command(srb_t *sp) static void qla24xx_handle_prli_done_event(struct scsi_qla_host *vha, struct event_arg *ea) { - switch (ea->data[0]) { + switch (ea->rc | MBS_COMMAND_COMPLETE) { case MBS_COMMAND_COMPLETE: ql_dbg(ql_dbg_disc, vha, 0x2118, "%s %d %s post gpdb\n", __func__, __LINE__, wwn_to_str(ea->fcport->port_name)); @@ -1965,7 +1965,7 @@ qla24xx_handle_plogi_done_event(struct scsi_qla_host *vha, struct event_arg *ea) return; } - switch (ea->data[0]) { + switch (ea->rc | MBS_COMMAND_COMPLETE) { case MBS_COMMAND_COMPLETE: /* * Driver must validate login state - If PRLI not complete,