Received: by 2002:a05:6a10:1287:0:0:0:0 with SMTP id d7csp3777256pxv; Mon, 19 Jul 2021 08:30:36 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzzpr5wnwp8PdTSsraU+jkpMoPaOcGa/8PJT+D96vgXi1cJ0JWFb9Wu/GOvTXu7elHJD9oY X-Received: by 2002:a05:6402:c17:: with SMTP id co23mr24952892edb.377.1626708636007; Mon, 19 Jul 2021 08:30:36 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1626708636; cv=none; d=google.com; s=arc-20160816; b=AL8LI5QqtGg7rZaLMHuKa+UAaiIMHWIaD5943vx7KIH1ds5sMqCxUhxlY6ZMprwnKB KQymj+1D9w4XAlOrhm1lCs0IHCG9RKSpKP08gCQJi/uRReiwi89h2yUx7iFWeEhrVUB5 qeqy5LCaNtT6E9k8HsyF1rz0Aswtm2BReLb67nHKuSRFPwMBcLiblq50+FWyYDHoKBmZ czTUG8jQnhHg+rNaAbhkJyVAWJqXj4atkHhvqQ2YLYdTIDhsBDOXcIhXXAKrqvLZXG1+ 33NMZg98LHCMKZaKuonSYawQYj45FFN4mJETriw2JNbV5SnrOfgeAJMeRSmrwQMJLVJQ jC1g== 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=6T0ubzkT8IYiI8il5XioG/vptR6FU/SnWt690EHumnE=; b=rwc66JXYHv0cUhsml6Iiwk0ymZ1CxCVmAne9cU10oIZh9Y7j9K1tOEI+lha6NXKQSV 0LX79iwxh7V1dfjmPUzdys/AOOFmNAtdI3lb8UsDKtAGpmZ748/YM3vaIc/dTvgllDi1 8W6TkrtK6CmC6VYDcawMNkkWrQvpOp4Chdm/Vl8Y0Tku8iFERoVisy7AYXVzh+jAMGtn yFHXPss+jMHz8aP4waxD+2geubNG8sovb1KI+72vwNZ5p1RpkuSvB7bbvnlx+J5SvuWb Y44RTGxshnSUg/EHIBWGQz3f9yBQkavNxkjyCfX1XDN6uuzjWQf+sdpFEPRQTbiYvYog R2Cg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=VTi9v0nt; 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 la20si25071352ejc.685.2021.07.19.08.30.10; Mon, 19 Jul 2021 08:30: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=@linuxfoundation.org header.s=korg header.b=VTi9v0nt; 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 S244203AbhGSOmZ (ORCPT + 99 others); Mon, 19 Jul 2021 10:42:25 -0400 Received: from mail.kernel.org ([198.145.29.99]:46038 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S245118AbhGSObF (ORCPT ); Mon, 19 Jul 2021 10:31:05 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 21CAC610D2; Mon, 19 Jul 2021 15:11:42 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1626707503; bh=UPcY7p/xBM474osapEx9fb+98A24OINPFDQEPCC2jIE=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=VTi9v0ntZQKPsHNsSvVCy3O60ax6URoqOsRsZEGeGxJ1E3vxzm2BfeJCh+wk44m0w Qn1kvhg5b1O4hze+d0WUtXPJJlVAnbV3Cmtcxe3woE0K9c/DdPYO6MAeobE2DKQJRk 3KK08ZeFgR5rrD/aBq+hHmryzqDUdG/O8BWWZ+L8= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Lee Duncan , Mike Christie , "Martin K. Petersen" , Sasha Levin Subject: [PATCH 4.9 191/245] scsi: iscsi: Add iscsi_cls_conn refcount helpers Date: Mon, 19 Jul 2021 16:52:13 +0200 Message-Id: <20210719144946.577964255@linuxfoundation.org> X-Mailer: git-send-email 2.32.0 In-Reply-To: <20210719144940.288257948@linuxfoundation.org> References: <20210719144940.288257948@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: Mike Christie [ Upstream commit b1d19e8c92cfb0ded180ef3376c20e130414e067 ] There are a couple places where we could free the iscsi_cls_conn while it's still in use. This adds some helpers to get/put a refcount on the struct and converts an exiting user. Subsequent commits will then use the helpers to fix 2 bugs in the eh code. Link: https://lore.kernel.org/r/20210525181821.7617-11-michael.christie@oracle.com Reviewed-by: Lee Duncan Signed-off-by: Mike Christie Signed-off-by: Martin K. Petersen Signed-off-by: Sasha Levin --- drivers/scsi/libiscsi.c | 7 ++----- drivers/scsi/scsi_transport_iscsi.c | 12 ++++++++++++ include/scsi/scsi_transport_iscsi.h | 2 ++ 3 files changed, 16 insertions(+), 5 deletions(-) diff --git a/drivers/scsi/libiscsi.c b/drivers/scsi/libiscsi.c index 50e2943c3337..30e954bb6c81 100644 --- a/drivers/scsi/libiscsi.c +++ b/drivers/scsi/libiscsi.c @@ -1384,7 +1384,6 @@ void iscsi_session_failure(struct iscsi_session *session, enum iscsi_err err) { struct iscsi_conn *conn; - struct device *dev; spin_lock_bh(&session->frwd_lock); conn = session->leadconn; @@ -1393,10 +1392,8 @@ void iscsi_session_failure(struct iscsi_session *session, return; } - dev = get_device(&conn->cls_conn->dev); + iscsi_get_conn(conn->cls_conn); spin_unlock_bh(&session->frwd_lock); - if (!dev) - return; /* * if the host is being removed bypass the connection * recovery initialization because we are going to kill @@ -1406,7 +1403,7 @@ void iscsi_session_failure(struct iscsi_session *session, iscsi_conn_error_event(conn->cls_conn, err); else iscsi_conn_failure(conn, err); - put_device(dev); + iscsi_put_conn(conn->cls_conn); } EXPORT_SYMBOL_GPL(iscsi_session_failure); diff --git a/drivers/scsi/scsi_transport_iscsi.c b/drivers/scsi/scsi_transport_iscsi.c index 4f4d2d65a4a7..337aad0660fa 100644 --- a/drivers/scsi/scsi_transport_iscsi.c +++ b/drivers/scsi/scsi_transport_iscsi.c @@ -2327,6 +2327,18 @@ int iscsi_destroy_conn(struct iscsi_cls_conn *conn) } EXPORT_SYMBOL_GPL(iscsi_destroy_conn); +void iscsi_put_conn(struct iscsi_cls_conn *conn) +{ + put_device(&conn->dev); +} +EXPORT_SYMBOL_GPL(iscsi_put_conn); + +void iscsi_get_conn(struct iscsi_cls_conn *conn) +{ + get_device(&conn->dev); +} +EXPORT_SYMBOL_GPL(iscsi_get_conn); + /* * iscsi interface functions */ diff --git a/include/scsi/scsi_transport_iscsi.h b/include/scsi/scsi_transport_iscsi.h index 6183d20a01fb..e673c7c9c5fb 100644 --- a/include/scsi/scsi_transport_iscsi.h +++ b/include/scsi/scsi_transport_iscsi.h @@ -437,6 +437,8 @@ extern void iscsi_free_session(struct iscsi_cls_session *session); extern int iscsi_destroy_session(struct iscsi_cls_session *session); extern struct iscsi_cls_conn *iscsi_create_conn(struct iscsi_cls_session *sess, int dd_size, uint32_t cid); +extern void iscsi_put_conn(struct iscsi_cls_conn *conn); +extern void iscsi_get_conn(struct iscsi_cls_conn *conn); extern int iscsi_destroy_conn(struct iscsi_cls_conn *conn); extern void iscsi_unblock_session(struct iscsi_cls_session *session); extern void iscsi_block_session(struct iscsi_cls_session *session); -- 2.30.2