Received: by 2002:a05:6a10:6744:0:0:0:0 with SMTP id w4csp4565882pxu; Tue, 13 Oct 2020 01:15:35 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxY87p0RE+vT0YRGn/vP6RD5tgvYULMe/r+xjTyCRW6OxqC7JkdG74CSBtE3P14EIZjkxgq X-Received: by 2002:a50:b063:: with SMTP id i90mr19254308edd.187.1602576935236; Tue, 13 Oct 2020 01:15:35 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1602576935; cv=none; d=google.com; s=arc-20160816; b=ZXATp27Ao8JNMEtRt0WGg9t8aOlEY5aeYM0uGCLwTLDAKi4RAFAHiQtDkiANAibcuv SsS4JtmVXQq5xaatpYHFT/XPwMI5lOWPPVFuYKm3K7ooMWOMWGVy6n1UA3JfWNe0G5qb pMd+HIKIQqJ7dhDMFBOZgb6i8nei6zpAa4+Tqh7RcWC2+SzppqdMn8emTOGuF6cA26NM DEh4ONXeH6B6tZ5O3Z1+caldnqlMahMLdMHYkrSPJVhgUM7AYP44kl5Qsn7M4v/E5D/p tFMFltEx6TGFyMSYsK5ZtDfA4J1gURzPEnlUJx0eniMVH7/0y3QuKJXXzuBtz1ywL3mf C1jg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:user-agent:references:message-id :in-reply-to:subject:cc:to:from:date:dkim-signature; bh=UV0SLMIx7JaopIv2ZAhKIw+hB9L3LepZSLHKUw4yt1s=; b=uFxgldtSv0oS6QnkUfClPdxI/n233twFUpuZshhnO8QsmGTcsV/YhuREdXbUF9aUFP JYuPTE3woz6OGhkRrMcxdgLZ+Vz+DxRTgHTDAWRRZBvTG1w91NplJ7T9O0ZB3XvsMBDZ KcJt1AvDGTkAuzO2sjIeoakEQhaPid46Teda08+sFEOs3k7zpXSUTvr0uPRaloO+tO9V TJqmjpQkcY8yP5PM+5hdD/pKL1pCUQS6buRe/ZShoo2KKH15E/FfnuR6Oc65otOTLJb1 4D3PaHFFovB/oxkTJ+gRd92Dk8Jf3HMl5EeUecKRBUKFt7UgSM06wqw6SnL5wHRQ05v6 UOYQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@marvell.com header.s=pfpt0220 header.b=Tf9Aqn7c; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=marvell.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id x18si13429992ejn.61.2020.10.13.01.15.13; Tue, 13 Oct 2020 01:15:35 -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; dkim=pass header.i=@marvell.com header.s=pfpt0220 header.b=Tf9Aqn7c; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=marvell.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2404167AbgJLSOK (ORCPT + 99 others); Mon, 12 Oct 2020 14:14:10 -0400 Received: from mx0b-0016f401.pphosted.com ([67.231.156.173]:3346 "EHLO mx0b-0016f401.pphosted.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2404102AbgJLSOK (ORCPT ); Mon, 12 Oct 2020 14:14:10 -0400 Received: from pps.filterd (m0045851.ppops.net [127.0.0.1]) by mx0b-0016f401.pphosted.com (8.16.0.42/8.16.0.42) with SMTP id 09CI1nUZ010698; Mon, 12 Oct 2020 11:14:08 -0700 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=marvell.com; h=date : from : to : cc : subject : in-reply-to : message-id : references : mime-version : content-type; s=pfpt0220; bh=UV0SLMIx7JaopIv2ZAhKIw+hB9L3LepZSLHKUw4yt1s=; b=Tf9Aqn7cz2JYQ9K0UbjOkcUXc0tz+BF4j0TodUZQkAPL1SPcO/6aJjmAZXJeZDeAoewW +dqZVmLbRogKOez4Os+35c2MjzFHbLCNe3vZvEUGN8Fa/IALVlCvbDFewt0CfZNsvsSX dmH1n76FfEriueeko5RRglTMRKWfA0bVluQZ1N4cRgYlghJCn14sEvNdvSl4pcKTB9x9 uj4Gaem9b9nsvsyC6MnwsjzgUZVHa8Jn76GpfwQ9JJMHmhXR2AF19Nb2oVVBTa1lbott v1lI6r6jsgdCfsjFlfXhlApKPG/yG4BU88+GTSECmDwW2z+VLt6AoZkmI+lnQxtGBW4z FA== Received: from sc-exch03.marvell.com ([199.233.58.183]) by mx0b-0016f401.pphosted.com with ESMTP id 343cfj6uk5-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-SHA384 bits=256 verify=NOT); Mon, 12 Oct 2020 11:14:08 -0700 Received: from DC5-EXCH01.marvell.com (10.69.176.38) by SC-EXCH03.marvell.com (10.93.176.83) with Microsoft SMTP Server (TLS) id 15.0.1497.2; Mon, 12 Oct 2020 11:14:06 -0700 Received: from maili.marvell.com (10.69.176.80) by DC5-EXCH01.marvell.com (10.69.176.38) with Microsoft SMTP Server id 15.0.1497.2 via Frontend Transport; Mon, 12 Oct 2020 11:14:06 -0700 Received: from irv1user01.caveonetworks.com (unknown [10.104.116.179]) by maili.marvell.com (Postfix) with ESMTP id 88AA83F703F; Mon, 12 Oct 2020 11:14:06 -0700 (PDT) Received: from localhost (aeasi@localhost) by irv1user01.caveonetworks.com (8.14.4/8.14.4/Submit) with ESMTP id 09CIE5Zw007905; Mon, 12 Oct 2020 11:14:06 -0700 X-Authentication-Warning: irv1user01.caveonetworks.com: aeasi owned process doing -bs Date: Mon, 12 Oct 2020 11:14:05 -0700 From: Arun Easi X-X-Sender: aeasi@irv1user01.caveonetworks.com To: Daniel Wagner CC: Nilesh Javali , , Subject: Re: [EXT] [PATCH v3] qla2xxx: Return EBUSY on fcport deletion In-Reply-To: <20201012173524.46544-1-dwagner@suse.de> Message-ID: References: <20201012173524.46544-1-dwagner@suse.de> User-Agent: Alpine 2.21.9999 (LRH 334 2019-03-29) MIME-Version: 1.0 Content-Type: text/plain; charset="US-ASCII" X-Proofpoint-Virus-Version: vendor=fsecure engine=2.50.10434:6.0.235,18.0.687 definitions=2020-10-12_14:2020-10-12,2020-10-12 signatures=0 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Mon, 12 Oct 2020, 10:35am, Daniel Wagner wrote: > ---------------------------------------------------------------------- > When the fcport is about to be deleted we should return EBUSY instead > of ENODEV. Only for EBUSY the request will be requeued in a multipath > setup. > > Also in case we have a valid qpair but the firmware has not yet > started return EBUSY to avoid dropping the request. > > Signed-off-by: Daniel Wagner > --- > > v3: simplify test logic as suggested by Arun. > v2: rebased on mkp/staging > > drivers/scsi/qla2xxx/qla_nvme.c | 6 ++++-- > 1 file changed, 4 insertions(+), 2 deletions(-) > > diff --git a/drivers/scsi/qla2xxx/qla_nvme.c b/drivers/scsi/qla2xxx/qla_nvme.c > index 2cd9bd288910..1fa457a5736e 100644 > --- a/drivers/scsi/qla2xxx/qla_nvme.c > +++ b/drivers/scsi/qla2xxx/qla_nvme.c > @@ -555,10 +555,12 @@ static int qla_nvme_post_cmd(struct nvme_fc_local_port *lport, > > fcport = qla_rport->fcport; > > - if (!qpair || !fcport || (qpair && !qpair->fw_started) || > - (fcport && fcport->deleted)) > + if (!qpair || !fcport) > return -ENODEV; > > + if (!qpair->fw_started || fcport->deleted) > + return -EBUSY; > + > vha = fcport->vha; > > if (!(fcport->nvme_flag & NVME_FLAG_REGISTERED)) > Thanks Daniel. Reviewed-by: Arun Easi