Received: by 2002:a05:6a10:22f:0:0:0:0 with SMTP id 15csp3755358pxk; Tue, 8 Sep 2020 01:19:04 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwYCLclkQx1iJNZOJ/TVCexgleTxLcooRrRix+K2A/hKinmgvXIRCdsB/QpTqktSRUr7JP2 X-Received: by 2002:a17:906:8690:: with SMTP id g16mr24136174ejx.187.1599553144388; Tue, 08 Sep 2020 01:19:04 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1599553144; cv=none; d=google.com; s=arc-20160816; b=IXXTWgDpJFZwmZ4XMPOvy9TlYUgUL9bU/zJ0vOvAcnyRoCesBJWUvpN1s1aazGn2P0 65Jvb7RMlxe0lhe78p/E2pGkOHGu8nMjzSZ2jbXKvhGNk4ku5A/9KhvuvtTMKgXxKByJ LLXVeCPoWJMU/sRBo3jmLx14F4uCRDtNQfT2hAZhW1LMNeQD3tHEdpm96WaSj0wtysIU GhcTxnJ45+DRyTHA8sz1HkTjwcA7JKtskTk9fXmB6Zgx09yONXEE8Hp9/Hl7rLfhWZuv Aek8GEZCTR2xe4zDZMT+5YA+6EzY3EU+Dzixad68WqiZ4LIkyOpEnT+ACfI5iL3HZyvd 6a3A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from; bh=KEIQpiCArNxvcGw5Yi5zndGbhnRDAMVerueKXA0YvX0=; b=eeEIRRQm2G5EvAhqoD3htYG+XjWRfVee+U0zNWkwhppDBUWZVuB4NS6n92Fmxhdg11 2utO3R/DM27/8dfT1vmx+obBL4Wn+q8YnmZLDyvu3JVJ2YJ5L+/jwLNKN+b2AU27GLpq AsByp8AcW8wFQifIpEHK1IngwEAYgmbi455/OvKxr2TMO3nQt1d55nbccLJuY+t3FPfQ fD66C94yE8qEigPtXOaRPEzy7GcWe1SVmMbklLzObx+oB5z/aXhiFWZ/1HHMTuZVlxMr LNGqJeeauIrYXAHARNxecg5HGzM6qWe2sMZbZMYCxpOHi9+T50cTIBLzUvJzj5uCBrFG F9kg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id y8si9782026edv.438.2020.09.08.01.18.42; Tue, 08 Sep 2020 01:19:04 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729942AbgIHIP7 (ORCPT + 99 others); Tue, 8 Sep 2020 04:15:59 -0400 Received: from mx2.suse.de ([195.135.220.15]:37146 "EHLO mx2.suse.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729733AbgIHIPZ (ORCPT ); Tue, 8 Sep 2020 04:15:25 -0400 X-Virus-Scanned: by amavisd-new at test-mx.suse.de Received: from relay2.suse.de (unknown [195.135.221.27]) by mx2.suse.de (Postfix) with ESMTP id 3E022B732; Tue, 8 Sep 2020 08:15:24 +0000 (UTC) From: Daniel Wagner To: linux-scsi@vger.kernel.org Cc: linux-kernel@vger.kernel.org, Nilesh Javali , Martin Wilck , Arun Easi , Daniel Wagner Subject: [PATCH v3 4/4] qla2xxx: Handle incorrect entry_type entries Date: Tue, 8 Sep 2020 10:15:16 +0200 Message-Id: <20200908081516.8561-5-dwagner@suse.de> X-Mailer: git-send-email 2.16.4 In-Reply-To: <20200908081516.8561-1-dwagner@suse.de> References: <20200908081516.8561-1-dwagner@suse.de> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org It was observed on an ISP8324 16Gb HBA with fw=8.08.203 (d0d5) in a PowerPC64 machine that pkt->entry_type was MBX_IOCB_TYPE/0x39 with an sp->type SRB_SCSI_CMD which is invalid and should not be possible. Reading the entry_type from the crash dump shows the expected value of STATUS_TYPE/0x03 but the call trace shows that qla24xx_mbx_iocb_entry() is used. Add a check to verify for consistency and reset the HBA if an invalid state is reached. Obviously, this is only a workaround until the real problem is solved. Signed-off-by: Daniel Wagner --- drivers/scsi/qla2xxx/qla_isr.c | 29 +++++++++++++++++++++++++++-- 1 file changed, 27 insertions(+), 2 deletions(-) diff --git a/drivers/scsi/qla2xxx/qla_isr.c b/drivers/scsi/qla2xxx/qla_isr.c index b0b6dd2b608d..f953564cbed8 100644 --- a/drivers/scsi/qla2xxx/qla_isr.c +++ b/drivers/scsi/qla2xxx/qla_isr.c @@ -3406,6 +3406,32 @@ void qla24xx_nvme_ls4_iocb(struct scsi_qla_host *vha, sp->done(sp, comp_status); } +static void qla24xx_process_mbx_iocb_response(struct scsi_qla_host *vha, + struct rsp_que *rsp, struct sts_entry_24xx *pkt) +{ + struct qla_hw_data *ha = vha->hw; + srb_t *sp; + const char func[] = "MBX-IOCB2"; + + sp = qla2x00_get_sp_from_handle(vha, func, rsp->req, pkt); + if (!sp) + return; + + if (sp->type == SRB_SCSI_CMD || + sp->type == SRB_NVME_CMD || + sp->type == SRB_TM_CMD) { + ql_log(ql_log_warn, vha, 0x509d, + "Inconsistent event entry type %d\n", sp->type); + if (IS_P3P_TYPE(ha)) + set_bit(FCOE_CTX_RESET_NEEDED, &vha->dpc_flags); + else + set_bit(ISP_ABORT_NEEDED, &vha->dpc_flags); + return; + } + + qla24xx_mbx_iocb_entry(vha, rsp->req, (struct mbx_24xx_entry *)pkt); +} + /** * qla24xx_process_response_queue() - Process response queue entries. * @vha: SCSI driver HA context @@ -3513,8 +3539,7 @@ void qla24xx_process_response_queue(struct scsi_qla_host *vha, (struct abort_entry_24xx *)pkt); break; case MBX_IOCB_TYPE: - qla24xx_mbx_iocb_entry(vha, rsp->req, - (struct mbx_24xx_entry *)pkt); + qla24xx_process_mbx_iocb_response(vha, rsp, pkt); break; case VP_CTRL_IOCB_TYPE: qla_ctrlvp_completed(vha, rsp->req, -- 2.16.4