Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp2457130pxj; Mon, 10 May 2021 03:31:30 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwLvXHkFL1VZBltYipN1CS00dlF1kjSsGJVo0/9DIuhqdJnxpQaMYeRzhiTEJ/L8Da81m6X X-Received: by 2002:a5d:87c4:: with SMTP id q4mr16574840ios.141.1620642689931; Mon, 10 May 2021 03:31:29 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1620642689; cv=none; d=google.com; s=arc-20160816; b=ypQbniucdOidAUGdFZX4aLyOKESU4sdn6zUY0pTK+CC5nYzu3AI7kJtHBFMlBEnbeI 79QEJSVMkj8lHr2Ochrxef1nguArTk2dl4Sprs33mVQ63dvysFDu2v78K5TnpWRsppt6 jg9CXTYYVKv7dR3E0wkuLNfBbE4Atmxowqn5/BiMrTvk1J0slyXL4iS9wTsZinyZ5bdg FndPnIk7RNEGW/lTNOJxxmFeygxRJL3Vl1AvdSkD8Drk4srYd2Rc4WKAAuheyXIUndRG 3wtAQcc2nXTfHq4jelSrR4FaCCNYH4wF1vLh6kwQ77WFFnBTKhTelcYJaPGfdOmDmVTr LhYg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=WuZZIgSfgUHxruj90ZScDI7r+4oggXyWnhtOtECBGbI=; b=Hq/D9S9MN3zQi4spiaoQBSCF6nMmt95nR8bDI3wWnP3RUd+ES0k1LZEoBnxHhiWNmV RUTLgtjFrVrAvaqoydvzxrZTzGEZSfIoLCZQ0Qi0D/NJS35o3fj2bp7L8fxHN6lVD7gO XP1GlkiazY8oFhy/LaQbJ22iUqDxFAafK3iOsCtRi5cECPzCUKrp0kIUo5noFegzh3pI dGea+wFDnswlcIyrfRmt8NCbAEcpwkmQ27Z2MO7LHeb0tDWg6MPtFlFpJO3rr1vgXfBR LAsTsjP7qknWyAanskZUHq8VoqjFQPqpT7JvURzpitOqOab+EJjn0RbHNv/LKmUUV/lv A49g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=mZQ6qBlH; 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=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id j6si2551622ilr.104.2021.05.10.03.31.17; Mon, 10 May 2021 03:31:29 -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=@linuxfoundation.org header.s=korg header.b=mZQ6qBlH; 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=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231897AbhEJKaz (ORCPT + 99 others); Mon, 10 May 2021 06:30:55 -0400 Received: from mail.kernel.org ([198.145.29.99]:33952 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231660AbhEJK1w (ORCPT ); Mon, 10 May 2021 06:27:52 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id A7B74610C9; Mon, 10 May 2021 10:26:35 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1620642396; bh=t9f/7bHCVTgR+AuzpestGI9KgiTNtjS/ARaBFz0PumU=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=mZQ6qBlHvQZTFIVXOegTibUwAsD5iHPlcoBxKTQpVVTSPidh49NR/AnM207i8xxOQ ICMBxMRuuvbVurzR8owrMX1q3fqJ0Bbqls9BxFxjvuWWMjiTXLmFZHgoOM3HyqWQ7w /pbgW2aCHaXZ6rOOEGogNhR7UFbaBtz2xN/pWmKc= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Dick Kennedy , James Smart , "Martin K. Petersen" , Sasha Levin Subject: [PATCH 5.4 076/184] scsi: lpfc: Fix pt2pt connection does not recover after LOGO Date: Mon, 10 May 2021 12:19:30 +0200 Message-Id: <20210510101952.679968628@linuxfoundation.org> X-Mailer: git-send-email 2.31.1 In-Reply-To: <20210510101950.200777181@linuxfoundation.org> References: <20210510101950.200777181@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: James Smart [ Upstream commit bd4f5100424d17d4e560d6653902ef8e49b2fc1f ] On a pt2pt setup, between 2 initiators, if one side issues a a LOGO, there is no relogin attempt. The FC specs are grey in this area on which port (higher wwn or not) is to re-login. As there is no spec guidance, unconditionally re-PLOGI after the logout to ensure a login is re-established. Link: https://lore.kernel.org/r/20210301171821.3427-8-jsmart2021@gmail.com Co-developed-by: Dick Kennedy Signed-off-by: Dick Kennedy Signed-off-by: James Smart Signed-off-by: Martin K. Petersen Signed-off-by: Sasha Levin --- drivers/scsi/lpfc/lpfc_nportdisc.c | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) diff --git a/drivers/scsi/lpfc/lpfc_nportdisc.c b/drivers/scsi/lpfc/lpfc_nportdisc.c index 418d62e94554..ea31711b1aeb 100644 --- a/drivers/scsi/lpfc/lpfc_nportdisc.c +++ b/drivers/scsi/lpfc/lpfc_nportdisc.c @@ -888,9 +888,14 @@ lpfc_rcv_logo(struct lpfc_vport *vport, struct lpfc_nodelist *ndlp, } } else if ((!(ndlp->nlp_type & NLP_FABRIC) && ((ndlp->nlp_type & NLP_FCP_TARGET) || - !(ndlp->nlp_type & NLP_FCP_INITIATOR))) || + (ndlp->nlp_type & NLP_NVME_TARGET) || + (vport->fc_flag & FC_PT2PT))) || (ndlp->nlp_state == NLP_STE_ADISC_ISSUE)) { - /* Only try to re-login if this is NOT a Fabric Node */ + /* Only try to re-login if this is NOT a Fabric Node + * AND the remote NPORT is a FCP/NVME Target or we + * are in pt2pt mode. NLP_STE_ADISC_ISSUE is a special + * case for LOGO as a response to ADISC behavior. + */ mod_timer(&ndlp->nlp_delayfunc, jiffies + msecs_to_jiffies(1000 * 1)); spin_lock_irq(shost->host_lock); -- 2.30.2