Received: by 2002:a05:6a10:16a7:0:0:0:0 with SMTP id gp39csp3802157pxb; Mon, 9 Nov 2020 23:40:20 -0800 (PST) X-Google-Smtp-Source: ABdhPJxf6JCd/+QmBtJqNZn0q4DWv+m6L4Fe6+eOLKeEdfNg67EdUkgFy0m8V8YH0Rd0+xlwvDbV X-Received: by 2002:aa7:c313:: with SMTP id l19mr14924267edq.293.1604994020206; Mon, 09 Nov 2020 23:40:20 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1604994020; cv=none; d=google.com; s=arc-20160816; b=e/Uh68ViEjn9E+l6ny7blc8CZTzvMewdzaHBAwkQjx1aCaiAIUbfM7W3JzzkvsnCpe CellN9Nc0hOajB/BJ3/a8IsMcveVtBFaNCHekW4904v0Ea5iels0YhlFNfUqYWqjl9dU j5BIusFvbfFuQt4Ib4630QnMUdHOzBkdlG8z322k0cDEpSgkkJjUSar51t4FL75WHUx0 y3IOGM/7NFfvUyC8XCrvWVex26MaOYm1Gb+0nJi02gs0k6+hNwlvZgHuz2Y8Afl+XPkx uIZLcTDZBrBHtK121D0KCZP0nekYWMyFKBDg31iHkRNqsZo8dwMzjfu6xrbo3mjUU2BO mQKg== 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 :message-id:date:subject:cc:to:from; bh=iw9aPtGNjTHYfg/RAf7ajdNrdETcxHfjk/NIfme62CE=; b=zRkp4hp99vk4PB2QzZu2klzCOwX7RPtOuSP9yk23iTIBdr1hfcjaBWHSlJZXzAcEXF Fc8n5NmxeoLib6mA6ffAJwmiMb3OMQ+4/BAq1mVlAzzXi4KEN6GNtMO2zMPk3CW27hVV w7Ook3CVR5zfi7TKak82xq9o4lktY7QCBlWYZ4Z70S8T2Z5bu8XzauKkL5lJf/0GrmXD fwHobIk0T2mYnlinO9GxtHnVh8RTtP42s65ORRMoHG4TDoFfrmS7kvT5sr1TKE1Hlf7c SMujhG3L00Qnt74tHlRTgGzkyeWOn9vBmmOeETnzOrYzwqFQ4git4Us/DoBUExpNA5ah XTUg== ARC-Authentication-Results: i=1; mx.google.com; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id g9si9450530edn.361.2020.11.09.23.39.55; Mon, 09 Nov 2020 23:40:20 -0800 (PST) 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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730111AbgKJHh1 (ORCPT + 99 others); Tue, 10 Nov 2020 02:37:27 -0500 Received: from szxga04-in.huawei.com ([45.249.212.190]:7200 "EHLO szxga04-in.huawei.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726467AbgKJHh1 (ORCPT ); Tue, 10 Nov 2020 02:37:27 -0500 Received: from DGGEMS407-HUB.china.huawei.com (unknown [172.30.72.58]) by szxga04-in.huawei.com (SkyGuard) with ESMTP id 4CVfnx4HvvzkfR6; Tue, 10 Nov 2020 15:37:09 +0800 (CST) Received: from localhost.localdomain.localdomain (10.175.113.25) by DGGEMS407-HUB.china.huawei.com (10.3.19.207) with Microsoft SMTP Server id 14.3.487.0; Tue, 10 Nov 2020 15:37:10 +0800 From: Qinglang Miao To: Alim Akhtar , Avri Altman , "James E.J. Bottomley" , "Martin K. Petersen" CC: , , "Qinglang Miao" Subject: [PATCH v2] scsi: ufshcd: fix missing destroy_workqueue() Date: Tue, 10 Nov 2020 15:42:23 +0800 Message-ID: <20201110074223.41280-1-miaoqinglang@huawei.com> X-Mailer: git-send-email 2.20.1 MIME-Version: 1.0 Content-Transfer-Encoding: 7BIT Content-Type: text/plain; charset=US-ASCII X-Originating-IP: [10.175.113.25] X-CFilter-Loop: Reflected Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Add the missing destroy_workqueue() before return from ufshcd_init in the error handling case as well as in ufshcd_remove. Fixes: 4db7a2360597 ("scsi: ufs: Fix concurrency of error handler and other error recovery paths") Suggested-by: Avri Altman Signed-off-by: Qinglang Miao --- v2: consider missing destroy_workqueue ufshcd_remove either. drivers/scsi/ufs/ufshcd.c | 2 ++ 1 file changed, 2 insertions(+) diff --git a/drivers/scsi/ufs/ufshcd.c b/drivers/scsi/ufs/ufshcd.c index b8f573a02713..adbdda4f556b 100644 --- a/drivers/scsi/ufs/ufshcd.c +++ b/drivers/scsi/ufs/ufshcd.c @@ -8906,6 +8906,7 @@ void ufshcd_remove(struct ufs_hba *hba) blk_mq_free_tag_set(&hba->tmf_tag_set); blk_cleanup_queue(hba->cmd_queue); scsi_remove_host(hba->host); + destroy_workqueue(hba->eh_wq); /* disable interrupts */ ufshcd_disable_intr(hba, hba->intr_mask); ufshcd_hba_stop(hba); @@ -9206,6 +9207,7 @@ int ufshcd_init(struct ufs_hba *hba, void __iomem *mmio_base, unsigned int irq) exit_gating: ufshcd_exit_clk_scaling(hba); ufshcd_exit_clk_gating(hba); + destroy_workqueue(hba->eh_wq); out_disable: hba->is_irq_enabled = false; ufshcd_hba_exit(hba); -- 2.23.0