Received: by 2002:a05:6a10:f347:0:0:0:0 with SMTP id d7csp4307457pxu; Tue, 1 Dec 2020 01:29:23 -0800 (PST) X-Google-Smtp-Source: ABdhPJwu57GCsOUbPq55LA6A2ye0goLhI1rAqkWZOqzyaeJsOcT5cXeuXYZibPR7SieaHLNMrKRV X-Received: by 2002:a50:d555:: with SMTP id f21mr2046254edj.70.1606814963407; Tue, 01 Dec 2020 01:29:23 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1606814963; cv=none; d=google.com; s=arc-20160816; b=M22ZDbbdbyNgkQNlJ/rSNiRBxVnlqSkn2ALni0BbDQCcYCf+lbf4bQvjTwKVLz2To/ TfUMW8X9GoRSPQYXGnmYV+jG7ZjyqCxFGHjXQGlHrDgO1aywtY14FttaENrEB8MH3N+j 8c3ytUqabxTqdrAJcR7KZEZQr7wjA8gIrTCDZstAkyYDQ2V/nVHsBAanDvJcrE+k0Ms/ 9+ZP7CdU0Ki7js07yMF7CmzErqCmdIH6JNAGkP5l8izC1B3hjaF5lJq5qDRzi5MeuuNB yiECDL7DIC8VZDCfUQYdwk1u1gARhDRSf8r1x4K+bRMKmcAkJ5bG7nx9Wr5cH3vrBlzp zepw== 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=D17yPhY66Mbh5ZgQlLRyeHvDCzm2/dEX8iV6yg7hSGA=; b=ih4OfQqXyEucWDZjlbXvEQ+V4zqTK+3CBxGYKUfd4k/BqqYbmzFmZvPCh+BFhiqBCu JAvNi3+VgZ3+7wfONiu1W5jqIo9VcnNJaiH5Z9PFAjQ06jSYCqul6zUxi0C9YRUl6YHj qjT5OgIJ72/+QOSZ6P1GHGQC+RaP2r7Fl7oguSAoFHM7/IJ54m/7PLOox5c18hk8Brxt XrpXVKk24EysTGkXftJ3KQ6KFncqi27v/vOC3hutqvxP9uCM8QeEpWNNc3unDzdNq6rI xq/mqKWdybzMV2uV3FsKKQeF6lBjktmigRilQU90T+P7wxB/UYN4ppY66psVSwOcstPn LAbw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b="qE/C6atc"; 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 cc22si789564edb.371.2020.12.01.01.29.00; Tue, 01 Dec 2020 01:29:23 -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; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b="qE/C6atc"; 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 S2388673AbgLAJD2 (ORCPT + 99 others); Tue, 1 Dec 2020 04:03:28 -0500 Received: from mail.kernel.org ([198.145.29.99]:39970 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727770AbgLAJCv (ORCPT ); Tue, 1 Dec 2020 04:02:51 -0500 Received: from localhost (83-86-74-64.cable.dynamic.v4.ziggo.nl [83.86.74.64]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 498CE206C1; Tue, 1 Dec 2020 09:02:10 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1606813330; bh=QnqNeQ8YPPwrJ/IQ6gFGEOgIou9X5w4DbBWp2jUcZs4=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=qE/C6atcZcrIATHRfOF57LSu8ThQs19P2BtdkkceCBx5XXW4qTPHrqCX70Z7yZuTj LQqPxoGZ/YEUZ/vThMxIyQFmFIOPBjI5OqUvYEL+5vCw53UUssSb3c/slx4/Is3Jl6 uNDfjbGox7dCNtuOy0EympFIP16kHg+syscXLoYU= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Can Guo , Stanley Chu , "Martin K. Petersen" , Sasha Levin Subject: [PATCH 4.19 31/57] scsi: ufs: Fix race between shutdown and runtime resume flow Date: Tue, 1 Dec 2020 09:53:36 +0100 Message-Id: <20201201084650.657187665@linuxfoundation.org> X-Mailer: git-send-email 2.29.2 In-Reply-To: <20201201084647.751612010@linuxfoundation.org> References: <20201201084647.751612010@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: Stanley Chu [ Upstream commit e92643db514803c2c87d72caf5950b4c0a8faf4a ] If UFS host device is in runtime-suspended state while UFS shutdown callback is invoked, UFS device shall be resumed for register accesses. Currently only UFS local runtime resume function will be invoked to wake up the host. This is not enough because if someone triggers runtime resume from block layer, then race may happen between shutdown and runtime resume flow, and finally lead to unlocked register access. To fix this, in ufshcd_shutdown(), use pm_runtime_get_sync() instead of resuming UFS device by ufshcd_runtime_resume() "internally" to let runtime PM framework manage the whole resume flow. Link: https://lore.kernel.org/r/20201119062916.12931-1-stanley.chu@mediatek.com Fixes: 57d104c153d3 ("ufs: add UFS power management support") Reviewed-by: Can Guo Signed-off-by: Stanley Chu Signed-off-by: Martin K. Petersen Signed-off-by: Sasha Levin --- drivers/scsi/ufs/ufshcd.c | 6 +----- 1 file changed, 1 insertion(+), 5 deletions(-) diff --git a/drivers/scsi/ufs/ufshcd.c b/drivers/scsi/ufs/ufshcd.c index a63119c35fde8..7e4e6e982055e 100644 --- a/drivers/scsi/ufs/ufshcd.c +++ b/drivers/scsi/ufs/ufshcd.c @@ -7926,11 +7926,7 @@ int ufshcd_shutdown(struct ufs_hba *hba) if (ufshcd_is_ufs_dev_poweroff(hba) && ufshcd_is_link_off(hba)) goto out; - if (pm_runtime_suspended(hba->dev)) { - ret = ufshcd_runtime_resume(hba); - if (ret) - goto out; - } + pm_runtime_get_sync(hba->dev); ret = ufshcd_suspend(hba, UFS_SHUTDOWN_PM); out: -- 2.27.0