Received: by 2002:a25:2c96:0:0:0:0:0 with SMTP id s144csp1105810ybs; Mon, 25 May 2020 07:19:49 -0700 (PDT) X-Google-Smtp-Source: ABdhPJy28I5DsoUIbKgSqvXRzaJ0J2Bh12HU39mrxCxM0ip30d+TufcG13RAhCQPzr4usN/1SlfJ X-Received: by 2002:a17:907:94ce:: with SMTP id dn14mr5235624ejc.109.1590416389172; Mon, 25 May 2020 07:19:49 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1590416389; cv=none; d=google.com; s=arc-20160816; b=X6kjXBNiBwM/NlqnufiD4VAvgCDqXJMqiNPNFdKQVwkuJ2QK+6Y/WeModPgMQ9oOHX hA2oL88+VjvipcSTPDsE0BhqR/ZACSM0zO8+6N2rffcylc27YmDnlo2SHvHK+5zygW2W oVb3fOD7l5+0ycFQgVe20o9ymx8a1S5Bq/p07nOzOzgwoIUmVO9K1MiHT00AY71wjt3Y 39t5oZh1jaCZw0G94wfVoCtb+JOqX6erH329RlrmLBoaUc6r51Pa31+hfN9xMdlR6p9/ 60oMoDHoq+RY9yGDIPx/b2TwiTOK4COcRp6YGFaWiPmwjTtx/1CUpdI7b6oxsN8yVT0L Qw+A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from :dkim-signature; bh=2O6pGP6DNuJKD7PSj3wtverNpdShPQdxF/NaVNklVKs=; b=INSGx2wJ/b20vDN4sUYZ+6b8OouAII2gpy+52rQ/ocV93tx3+noKORhN0U/sWexcg2 MVwOX9o96NuyMRpVPqcHZmZIqc9vmXyKWvVDALN+KBEFNqyf/JmNNKQoJD7au1snrOTt WwCjeLAjuHONrA1CBrQFFlRxw99AC1hX0t1rH5aJ2rbvMDyon7tbaCKII6waB4jUOvQE Vu5oyjHD5vO60DbEn9VkwPIug6GEWYtjlfBfk6Te4hMikQ+4LNt1tYML+mW3Bdmtk+YH REJArPX4OFGMf1LxLZlbNeALYDpm2RbogwRxBgI4Vl4LR54jf0PXHOPJytgXyikLRyd9 QDEQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@fudan.edu.cn header.s=dkim header.b=mrONUyUw; 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=REJECT sp=REJECT dis=NONE) header.from=fudan.edu.cn Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id e23si9366565ejr.357.2020.05.25.07.19.26; Mon, 25 May 2020 07:19:49 -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=@fudan.edu.cn header.s=dkim header.b=mrONUyUw; 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=REJECT sp=REJECT dis=NONE) header.from=fudan.edu.cn Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2390921AbgEYORA (ORCPT + 99 others); Mon, 25 May 2020 10:17:00 -0400 Received: from mail.fudan.edu.cn ([202.120.224.73]:50943 "EHLO fudan.edu.cn" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S2388714AbgEYORA (ORCPT ); Mon, 25 May 2020 10:17:00 -0400 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=fudan.edu.cn; s=dkim; h=Received:From:To:Cc:Subject:Date: Message-Id; bh=2O6pGP6DNuJKD7PSj3wtverNpdShPQdxF/NaVNklVKs=; b=m rONUyUw5U6FX4ptJUw7Rtx+UX2XzRRyr87SNfxDcu4E1hgWoPKbsAClP6Mvt6X4q nGNukyMBW1uKb0j3Ym67xuxht6Ry9x653iswWxz+yK12XsUss9NUzEqAYn28BoZw 42ARJlY/pwEirj6rZU/wq47U/KWDww6aNvugbrXtv8= Received: from localhost.localdomain (unknown [223.73.184.21]) by app2 (Coremail) with SMTP id XQUFCgAHueFR08te3BypAg--.6972S3; Mon, 25 May 2020 22:16:52 +0800 (CST) From: Xiyu Yang To: James Smart , Dick Kennedy , "James E.J. Bottomley" , "Martin K. Petersen" , linux-scsi@vger.kernel.org, linux-kernel@vger.kernel.org Cc: yuanxzhang@fudan.edu.cn, kjlu@umn.edu, Xiyu Yang , Xin Tan Subject: [PATCH] scsi: lpfc: Fix lpfc_nodelist leak when processing unsolicited event Date: Mon, 25 May 2020 22:16:24 +0800 Message-Id: <1590416184-52592-1-git-send-email-xiyuyang19@fudan.edu.cn> X-Mailer: git-send-email 2.7.4 X-CM-TRANSID: XQUFCgAHueFR08te3BypAg--.6972S3 X-Coremail-Antispam: 1UD129KBjvJXoW7CryDJry3Gr4xJw15CFyxGrg_yoW8Xr1rpr W5KrWIywnYqF47Kws5Gr15XFyFy3WrXrWxAan0v348uFykGas3tF4rZF1UWF98JF4Utryf XF42grW8uF4DZaUanT9S1TB71UUUUUUqnTZGkaVYY2UrUUUUjbIjqfuFe4nvWSU5nxnvy2 9KBjDU0xBIdaVrnRJUUU9K14x267AKxVW8JVW5JwAFc2x0x2IEx4CE42xK8VAvwI8IcIk0 rVWrJVCq3wAFIxvE14AKwVWUJVWUGwA2ocxC64kIII0Yj41l84x0c7CEw4AK67xGY2AK02 1l84ACjcxK6xIIjxv20xvE14v26w1j6s0DM28EF7xvwVC0I7IYx2IY6xkF7I0E14v26F4U JVW0owA2z4x0Y4vEx4A2jsIE14v26rxl6s0DM28EF7xvwVC2z280aVCY1x0267AKxVW0oV Cq3wAac4AC62xK8xCEY4vEwIxC4wAS0I0E0xvYzxvE52x082IY62kv0487Mc02F40EFcxC 0VAKzVAqx4xG6I80ewAv7VC0I7IYx2IY67AKxVWUAVWUtwAv7VC2z280aVAFwI0_Jr0_Gr 1lOx8S6xCaFVCjc4AY6r1j6r4UM4x0Y48IcxkI7VAKI48JM4x0x7Aq67IIx4CEVc8vx2IE rcIFxwACI402YVCY1x02628vn2kIc2xKxwCY02Avz4vE14v_Xryl42xK82IYc2Ij64vIr4 1l4I8I3I0E4IkC6x0Yz7v_Jr0_Gr1lx2IqxVAqx4xG67AKxVWUJVWUGwC20s026x8GjcxK 67AKxVWUGVWUWwC2zVAF1VAY17CE14v26r1q6r43MIIYrxkI7VAKI48JMIIF0xvE2Ix0cI 8IcVAFwI0_Jr0_JF4lIxAIcVC0I7IYx2IY6xkF7I0E14v26r4j6F4UMIIF0xvE42xK8VAv wI8IcIk0rVW8JVW3JwCI42IY6I8E87Iv67AKxVWUJVW8JwCI42IY6I8E87Iv6xkF7I0E14 v26r4j6r4UJbIYCTnIWIevJa73UjIFyTuYvjfUO2-nDUUUU X-CM-SenderInfo: irzsiiysuqikmy6i3vldqovvfxof0/ Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org In order to create or activate a new node, lpfc_els_unsol_buffer() invokes lpfc_nlp_init() or lpfc_enable_node() or lpfc_nlp_get(), all of them will return a reference of the specified lpfc_nodelist object to "ndlp" with increased refcnt. When lpfc_els_unsol_buffer() returns, local variable "ndlp" becomes invalid, so the refcount should be decreased to keep refcount balanced. The reference counting issue happens in one exception handling path of lpfc_els_unsol_buffer(). When "ndlp" in DEV_LOSS, the function forgets to decrease the refcnt increased by lpfc_nlp_init() or lpfc_enable_node() or lpfc_nlp_get(), causing a refcnt leak. Fix this issue by calling lpfc_nlp_put() when "ndlp" in DEV_LOSS. Signed-off-by: Xiyu Yang Signed-off-by: Xin Tan --- drivers/scsi/lpfc/lpfc_els.c | 2 ++ 1 file changed, 2 insertions(+) diff --git a/drivers/scsi/lpfc/lpfc_els.c b/drivers/scsi/lpfc/lpfc_els.c index 80d1e661b0d4..35fbcb4d52eb 100644 --- a/drivers/scsi/lpfc/lpfc_els.c +++ b/drivers/scsi/lpfc/lpfc_els.c @@ -8514,6 +8514,8 @@ lpfc_els_unsol_buffer(struct lpfc_hba *phba, struct lpfc_sli_ring *pring, spin_lock_irq(shost->host_lock); if (ndlp->nlp_flag & NLP_IN_DEV_LOSS) { spin_unlock_irq(shost->host_lock); + if (newnode) + lpfc_nlp_put(ndlp); goto dropit; } spin_unlock_irq(shost->host_lock); -- 2.7.4