Received: by 2002:a05:6a10:6d10:0:0:0:0 with SMTP id gq16csp1371701pxb; Thu, 14 Apr 2022 04:54:20 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxGm2mhLIzNq5fDCb45DlSMyfm4HKJNPNX4juQ/5BOyLpQIVmLM1GXJpISKsHhCmxAyKA3/ X-Received: by 2002:a05:6402:1b07:b0:41d:7abf:8337 with SMTP id by7-20020a0564021b0700b0041d7abf8337mr2477009edb.185.1649937260342; Thu, 14 Apr 2022 04:54:20 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1649937260; cv=none; d=google.com; s=arc-20160816; b=tKriq9ayEl0q//UQiP85BIpuxVHKHvxEr17myF9axxcZD3hPnVhCSDGRM965hU+LHR iGM7rD2HQY2/CJB1GsYTHS1nWdmpzThSnfflkoVsN56/5wE581MhAlE0XTFLZH0PloAe Fyd1G+KH0Vxp5l8f/KMfleIxwa/N5XtZ6lSWLNL/uKPx117WWQzaQIzDdcFrEmJ1mh3P l/vdBOgye67MsahoHjka/2G96vCgyrtCIVT5BeTaWy1ySLYchBuG0g0zX61iQLfTGmnp CAVJO8x/ZVXXk8GQoQbDcVotuj+c/GDXQI3KWougJVqTnHgR+EKhrBa1kNjKkm57iJXe FAyA== 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 :references:in-reply-to:message-id:date:subject:cc:to:from; bh=0gBk7s8zwhqZ/9/j0jD8HRYwt6BT6WDvRj4KICe5LIw=; b=0lo1KFAOtZ+udqj+Q/w2T82+E8u38IDbkROjz/b76MQmeJ0Cs5+A4u2Z6KF0yuFLBe VHMtMvQ2/qFcwx9Q2kOoiayD4rBqDiNIL/9tTzVzj1syPXo7d7L95nzEhWyQaugh354q f5qHHNB4JXA8QfX0UZ1cgu5tIHEUBMn+eXJ8AGig1Nl0UZAT585Wm3tkmI1PpQ4FNIzB oThOFOg1rYQZMyhlvitKR2io8qqGiviVbtdTAlmdbdE/4Oerpw7IJsn7LVUrABYb+u6Q ilP3qkOKInlj9rnDbq35/hvWupyLVexrvwkUzV1QCCTPL0Fia2bTpUP5clFCKRGmXSmn vXew== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=huawei.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id f23-20020a17090660d700b006df76385d13si1763703ejk.435.2022.04.14.04.53.55; Thu, 14 Apr 2022 04:54:20 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=QUARANTINE sp=QUARANTINE dis=NONE) header.from=huawei.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S235583AbiDMMl2 (ORCPT + 99 others); Wed, 13 Apr 2022 08:41:28 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:44144 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233208AbiDMMlS (ORCPT ); Wed, 13 Apr 2022 08:41:18 -0400 Received: from szxga03-in.huawei.com (szxga03-in.huawei.com [45.249.212.189]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 3F11550E35; Wed, 13 Apr 2022 05:38:56 -0700 (PDT) Received: from dggpemm500023.china.huawei.com (unknown [172.30.72.53]) by szxga03-in.huawei.com (SkyGuard) with ESMTP id 4Kdhqc1xJgzBsKf; Wed, 13 Apr 2022 20:34:36 +0800 (CST) Received: from dggpemm500017.china.huawei.com (7.185.36.178) by dggpemm500023.china.huawei.com (7.185.36.83) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2375.24; Wed, 13 Apr 2022 20:38:54 +0800 Received: from huawei.com (10.175.101.6) by dggpemm500017.china.huawei.com (7.185.36.178) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2375.24; Wed, 13 Apr 2022 20:38:53 +0800 From: Wenchao Hao To: Mike Christie , Lee Duncan , Chris Leech , "James E . J . Bottomley" , "Martin K . Petersen" , , , CC: , Wenchao Hao Subject: [PATCH 2/2] iscsi: set session to FREE state after unbind session in remove session Date: Wed, 13 Apr 2022 21:49:47 -0400 Message-ID: <20220414014947.4168447-3-haowenchao@huawei.com> X-Mailer: git-send-email 2.32.0 In-Reply-To: <20220414014947.4168447-1-haowenchao@huawei.com> References: <20220414014947.4168447-1-haowenchao@huawei.com> MIME-Version: 1.0 Content-Transfer-Encoding: 7BIT Content-Type: text/plain; charset=US-ASCII X-Originating-IP: [10.175.101.6] X-ClientProxiedBy: dggems704-chm.china.huawei.com (10.3.19.181) To dggpemm500017.china.huawei.com (7.185.36.178) X-CFilter-Loop: Reflected X-Spam-Status: No, score=-1.0 required=5.0 tests=BAYES_00,DATE_IN_FUTURE_12_24, RCVD_IN_DNSWL_MED,RCVD_IN_MSPIKE_H5,RCVD_IN_MSPIKE_WL,SPF_HELO_NONE, SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=no autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org __iscsi_unbind_session() set session state to ISCSI_SESSION_UNBOUND, which would overwrite the ISCSI_SESSION_FREE state. Signed-off-by: Wenchao Hao --- drivers/scsi/scsi_transport_iscsi.c | 26 ++++++++++++++++---------- 1 file changed, 16 insertions(+), 10 deletions(-) diff --git a/drivers/scsi/scsi_transport_iscsi.c b/drivers/scsi/scsi_transport_iscsi.c index 97a9fee02efa..d8dd9279cea8 100644 --- a/drivers/scsi/scsi_transport_iscsi.c +++ b/drivers/scsi/scsi_transport_iscsi.c @@ -2173,6 +2173,22 @@ void iscsi_remove_session(struct iscsi_cls_session *session) if (!cancel_work_sync(&session->block_work)) cancel_delayed_work_sync(&session->recovery_work); cancel_work_sync(&session->unblock_work); + + scsi_target_unblock(&session->dev, SDEV_TRANSPORT_OFFLINE); + /* + * qla4xxx can perform it's own scans when it runs in kernel only + * mode. Make sure to flush those scans. + */ + flush_work(&session->scan_work); + + /* + * flush running unbind operations + * if unbind work did not queued, call __iscsi_unbind_session + * directly to perform target remove + */ + if (!flush_work(&session->unbind_work)) + __iscsi_unbind_session(&session->unbind_work); + /* * If we are blocked let commands flow again. The lld or iscsi * layer should set up the queuecommand to fail commands. @@ -2183,16 +2199,6 @@ void iscsi_remove_session(struct iscsi_cls_session *session) session->state = ISCSI_SESSION_FREE; spin_unlock_irqrestore(&session->lock, flags); - scsi_target_unblock(&session->dev, SDEV_TRANSPORT_OFFLINE); - /* - * qla4xxx can perform it's own scans when it runs in kernel only - * mode. Make sure to flush those scans. - */ - flush_work(&session->scan_work); - /* flush running unbind operations */ - flush_work(&session->unbind_work); - __iscsi_unbind_session(&session->unbind_work); - /* hw iscsi may not have removed all connections from session */ err = device_for_each_child(&session->dev, NULL, iscsi_iter_destroy_conn_fn); -- 2.32.0