Received: by 2002:a25:8b91:0:0:0:0:0 with SMTP id j17csp5635993ybl; Tue, 10 Dec 2019 09:05:34 -0800 (PST) X-Google-Smtp-Source: APXvYqyxwnWxF6oUmOSuS7sgkg+WvR7h/y/W0uDYnMKUGoa5abtHs2Q5o7P7rVCbt6uPaZBQV2DB X-Received: by 2002:a05:6830:11c3:: with SMTP id v3mr27929228otq.74.1575997534204; Tue, 10 Dec 2019 09:05:34 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1575997534; cv=none; d=google.com; s=arc-20160816; b=qgC1XE6S0vZS6XxhddA9kYE/lTeeqLha/RdTswpC1Kf1a0dIx+J+u5jxtDd7VM1pNx ayg0OLSyAbSiNCbf72TG7I158HRvG/tG+fdNKD/e47RDxZutTrzbFGO5IgSCP6PSvoQC 4uc7Jg5btWYV1B+E8bZe4aHspbuV9sQEe/YkbcLPObNnzWihLcolz/p8KXZUrPSEzwAK NGJYAxhQ4re0ts1ciTi1fOizuLrNIA+0ByrKdmlcYwvEtVQszMzJh3IkY8vI8liiwdE+ YTzWxE0ADE5XWeoehY2UnCpeuf8wpEUgGN/s/DuqdHsIE60MbwwNUxoRY9+Mm5ifd6Wx hffw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:references:in-reply-to :message-id:date:subject:cc:to:from:ironport-sdr:dkim-signature; bh=jsQLWljZzrOXr0hMo3w7QDSXB3pl/GSdQ9mRS4ZgnKg=; b=cZuFddiWzVjEFzfmB8gi6fbnzkctM3k/qVVarTpk3qUQPFggf6Gc4WrGaUIF3Q+E+o UrKtM0dIXk1jwFGYX2jJzbbdnu7Wka+aXAGdRcuAyDb1o3kJFGsW1bMwLvOjvej+dA0p BQxuJZq8pjyOt0+RdvxIZstMovGmuIm34e0ejYHYm9XTh6Rt3YWzM4GKWePRyFZqauSx w9tyM7dfkOdg5HyF8V0WbLVx3l9KWfqTY2BUEYJuTXzmUEM2TpqKIxsmr0I3RiQnm3Yn 3RNmc9E/4LL228LgbY8LW2VlPJbZ3zTC+KjvsAc1JT0sNH8qFmjni77Gw1+kuLe+uet7 9vOw== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@citrix.com header.s=securemail header.b=LpECj5s0; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=citrix.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id q6si2773658otg.248.2019.12.10.09.05.20; Tue, 10 Dec 2019 09:05:34 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=fail header.i=@citrix.com header.s=securemail header.b=LpECj5s0; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=citrix.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727656AbfLJREp (ORCPT + 99 others); Tue, 10 Dec 2019 12:04:45 -0500 Received: from esa2.hc3370-68.iphmx.com ([216.71.145.153]:39689 "EHLO esa2.hc3370-68.iphmx.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727525AbfLJREp (ORCPT ); Tue, 10 Dec 2019 12:04:45 -0500 X-Greylist: delayed 426 seconds by postgrey-1.27 at vger.kernel.org; Tue, 10 Dec 2019 12:04:43 EST DKIM-Signature: v=1; a=rsa-sha256; c=simple/simple; d=citrix.com; s=securemail; t=1575997484; h=from:to:cc:subject:date:message-id:in-reply-to: references:mime-version; bh=LmLcwm7ETBP99P7FEc+YIc1hsYwuyPtB6gvyIrxiSLc=; b=LpECj5s0QAYKGP/jzogs02EIo3M0fH7PNroqEuc+UCjHtB/jbmDMMfqg ya6XbARHZcSevtYhxXWZu99WrVwcbVxM4pPWkdxCFflzrOCaZQXsE3mxI 923pV31mFHtRZW8kt9DXyWE11qEXl0moxwcpxDnK0dtS6C4c9ACkRZJVd w=; Authentication-Results: esa2.hc3370-68.iphmx.com; dkim=none (message not signed) header.i=none; spf=None smtp.pra=igor.druzhinin@citrix.com; spf=Pass smtp.mailfrom=igor.druzhinin@citrix.com; spf=None smtp.helo=postmaster@mail.citrix.com Received-SPF: None (esa2.hc3370-68.iphmx.com: no sender authenticity information available from domain of igor.druzhinin@citrix.com) identity=pra; client-ip=162.221.158.21; receiver=esa2.hc3370-68.iphmx.com; envelope-from="igor.druzhinin@citrix.com"; x-sender="igor.druzhinin@citrix.com"; x-conformance=sidf_compatible Received-SPF: Pass (esa2.hc3370-68.iphmx.com: domain of igor.druzhinin@citrix.com designates 162.221.158.21 as permitted sender) identity=mailfrom; client-ip=162.221.158.21; receiver=esa2.hc3370-68.iphmx.com; envelope-from="igor.druzhinin@citrix.com"; x-sender="igor.druzhinin@citrix.com"; x-conformance=sidf_compatible; x-record-type="v=spf1"; x-record-text="v=spf1 ip4:209.167.231.154 ip4:178.63.86.133 ip4:195.66.111.40/30 ip4:85.115.9.32/28 ip4:199.102.83.4 ip4:192.28.146.160 ip4:192.28.146.107 ip4:216.52.6.88 ip4:216.52.6.188 ip4:162.221.158.21 ip4:162.221.156.83 ip4:168.245.78.127 ~all" Received-SPF: None (esa2.hc3370-68.iphmx.com: no sender authenticity information available from domain of postmaster@mail.citrix.com) identity=helo; client-ip=162.221.158.21; receiver=esa2.hc3370-68.iphmx.com; envelope-from="igor.druzhinin@citrix.com"; x-sender="postmaster@mail.citrix.com"; x-conformance=sidf_compatible IronPort-SDR: ZuoikandVuC0rBPfb3zNS375Kcj9GDcFEeiQFxx5UQc5+J0/obTYt2MgjF7gEDlbI3T3wjD0lR AJaiVjUkFEOJu5TMMrLkDBHckXgVClu/V5Fr8aI34YCih3IT1BZs6ytA92D2bJwuLOZTVSJwyI loi4Accyn7VV45hgHe94j7SgTsK91DNdzuwNWZ4mqBloq5uj5Z/QBpuFxr/tJGxccNK+fSluIs b7QaTDxsv8acjnEY7OMRafK7Yyic4Rz3q5ogelaewrUEOERHIbx/zok9p9XlnhcQJewAPy7dLf ffg= X-SBRS: 2.7 X-MesageID: 9479234 X-Ironport-Server: esa2.hc3370-68.iphmx.com X-Remote-IP: 162.221.158.21 X-Policy: $RELAYED X-IronPort-AV: E=Sophos;i="5.69,300,1571716800"; d="scan'208";a="9479234" From: Igor Druzhinin To: , CC: , , , "Igor Druzhinin" Subject: [PATCH 2/2] scsi: libfc: drop extra rport reference in fc_rport_create() Date: Tue, 10 Dec 2019 16:57:30 +0000 Message-ID: <1575997050-12959-3-git-send-email-igor.druzhinin@citrix.com> X-Mailer: git-send-email 2.7.4 In-Reply-To: <1575997050-12959-1-git-send-email-igor.druzhinin@citrix.com> References: <1575997050-12959-1-git-send-email-igor.druzhinin@citrix.com> MIME-Version: 1.0 Content-Type: text/plain Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The callers of this function seem to assume the reference is not taken in case rport already exists. This results in one extra reference taken on each rport re-discovery that will eventually get to inability to free rport structure on port removal. Signed-off-by: Igor Druzhinin --- drivers/scsi/libfc/fc_rport.c | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/drivers/scsi/libfc/fc_rport.c b/drivers/scsi/libfc/fc_rport.c index da6e97d..a43f9dd 100644 --- a/drivers/scsi/libfc/fc_rport.c +++ b/drivers/scsi/libfc/fc_rport.c @@ -133,8 +133,10 @@ struct fc_rport_priv *fc_rport_create(struct fc_lport *lport, u32 port_id) lockdep_assert_held(&lport->disc.disc_mutex); rdata = fc_rport_lookup(lport, port_id); - if (rdata) + if (rdata) { + kref_put(&rdata->kref, fc_rport_destroy); return rdata; + } if (lport->rport_priv_size > 0) rport_priv_size = lport->rport_priv_size; -- 2.7.4