Received: by 2002:a25:1506:0:0:0:0:0 with SMTP id 6csp4395630ybv; Mon, 10 Feb 2020 18:38:36 -0800 (PST) X-Google-Smtp-Source: APXvYqzqQbb6M8DFUpaYJ7J33Ntr93+5AF70/wM6l1oUavqmihonISVp3fgNEOiQp3hlfXHE8hDh X-Received: by 2002:a05:6830:154a:: with SMTP id l10mr3565336otp.44.1581388716031; Mon, 10 Feb 2020 18:38:36 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1581388716; cv=none; d=google.com; s=arc-20160816; b=ncsFw1OwFkcAskhPsTQFXo5lwa6SACWtzR0MfhVzN2v9un8Xw1laysHBQcbS6B1Jx0 hKM2bZ9cy803tFtn046Sjbyb4F4qQEALI29nDGV4jpKSMUiwjjk3Zoa3SFUjijLDStnd XR+QHnEAkW65Qm48dXpRz2yoqImZrcslQzAyS7ieq0cB65MRRr7v5+Pw5cPe87c9U2Lp qKFZ8m+L4sf6WD2IqGachNcqZrhD6rvWv6gaMsDHd5BXdpGFghZklcOk42S/uXYgO04u HaJGsrtR4m8LuaFx3iVulRn395MVdWTBUA7DJ5cRX9kFKHwCCVYeJxMdbeuCSpgm6a86 INgA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:dmarc-filter:dkim-signature; bh=f1HTEkpxUdDYbFLcYWFshQ3BL0C5vGP4FbG4ywXAapM=; b=glmp4T9ZsA8kCJpG0AJVLOQcqB49Ohvyi1qQdCXZGIGK1xuufN2KevCrPZCUSsoj3F TivKnV875yB3KtwOPImYxohara1FNtRvvSXsEKVLN4KyPJCC5eh5v2aaJPen7WjFM2Vd GzhVhTODCsEQyizXoD1qx6SzNcUWNpjc+0uEfXMoX4XFIZfwgNhb358bJSeMYDe0xPnk 4C7PMGq6AErqVEKQ4SoY7GxYs26fFAXnCH/obd558pZ12+FyE6SzcaLE3TC72MT1ziBY PKa7krnCBnnfan6qYihHc8HGEVSGGgPNju1HQ6AwleZWt4mcpuQNFv86Q6KETl5+ARfz kBkA== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@mg.codeaurora.org header.s=smtp header.b=t+hZVEgp; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id v11si1205708otp.279.2020.02.10.18.38.23; Mon, 10 Feb 2020 18:38:36 -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=@mg.codeaurora.org header.s=smtp header.b=t+hZVEgp; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727831AbgBKCiL (ORCPT + 99 others); Mon, 10 Feb 2020 21:38:11 -0500 Received: from mail26.static.mailgun.info ([104.130.122.26]:32233 "EHLO mail26.static.mailgun.info" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727493AbgBKCiL (ORCPT ); Mon, 10 Feb 2020 21:38:11 -0500 DKIM-Signature: a=rsa-sha256; v=1; c=relaxed/relaxed; d=mg.codeaurora.org; q=dns/txt; s=smtp; t=1581388690; h=References: In-Reply-To: Message-Id: Date: Subject: Cc: To: From: Sender; bh=f1HTEkpxUdDYbFLcYWFshQ3BL0C5vGP4FbG4ywXAapM=; b=t+hZVEgpIM8qdg7FpcQIcxEdy4TtBjOxA32sLBvLHh08nw1yts+I6ppAyFnpa1yoyzZfwbxp Z5md50A/cq3wQRvXPSLyk5l343rSm1nH7//eB8X7fIrvWnpXKRNcfmaQXuTFSzQRaDO3zxAm f9kYHK1/4IJKAdACrPEZwuDBeMA= X-Mailgun-Sending-Ip: 104.130.122.26 X-Mailgun-Sid: WyI0MWYwYSIsICJsaW51eC1rZXJuZWxAdmdlci5rZXJuZWwub3JnIiwgImJlOWU0YSJd Received: from smtp.codeaurora.org (ec2-35-166-182-171.us-west-2.compute.amazonaws.com [35.166.182.171]) by mxa.mailgun.org with ESMTP id 5e42138f.7fcc910c16c0-smtp-out-n01; Tue, 11 Feb 2020 02:38:07 -0000 (UTC) Received: by smtp.codeaurora.org (Postfix, from userid 1001) id 5969EC447A5; Tue, 11 Feb 2020 02:38:05 +0000 (UTC) X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-caf-mail-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-1.0 required=2.0 tests=ALL_TRUSTED,SPF_NONE, URIBL_BLOCKED autolearn=unavailable autolearn_force=no version=3.4.0 Received: from pacamara-linux.qualcomm.com (i-global254.qualcomm.com [199.106.103.254]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-SHA256 (128/128 bits)) (No client certificate requested) (Authenticated sender: cang) by smtp.codeaurora.org (Postfix) with ESMTPSA id 8D1DFC433A2; Tue, 11 Feb 2020 02:38:03 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.3.2 smtp.codeaurora.org 8D1DFC433A2 Authentication-Results: aws-us-west-2-caf-mail-1.web.codeaurora.org; dmarc=none (p=none dis=none) header.from=codeaurora.org Authentication-Results: aws-us-west-2-caf-mail-1.web.codeaurora.org; spf=none smtp.mailfrom=cang@codeaurora.org From: Can Guo To: asutoshd@codeaurora.org, nguyenb@codeaurora.org, hongwus@codeaurora.org, rnayak@codeaurora.org, linux-scsi@vger.kernel.org, kernel-team@android.com, saravanak@google.com, salyzyn@google.com, cang@codeaurora.org Cc: Sayali Lokhande , Alim Akhtar , Avri Altman , "James E.J. Bottomley" , "Martin K. Petersen" , Stanley Chu , Bean Huo , Bart Van Assche , Venkat Gopalakrishnan , Tomas Winkler , linux-kernel@vger.kernel.org (open list) Subject: [PATCH v9 1/7] scsi: ufs: Flush exception event before suspend Date: Mon, 10 Feb 2020 18:37:43 -0800 Message-Id: <1581388671-18078-2-git-send-email-cang@codeaurora.org> X-Mailer: git-send-email 1.9.1 In-Reply-To: <1581388671-18078-1-git-send-email-cang@codeaurora.org> References: <1581388671-18078-1-git-send-email-cang@codeaurora.org> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Sayali Lokhande Exception event can be raised by the device when system suspend is in progress. This will result in unclocked register access in exception event handler as clocks will be turned off during suspend. This change makes sure to flush exception event handler work in suspend before disabling clocks to avoid unclocked register access issue. Signed-off-by: Sayali Lokhande Signed-off-by: Asutosh Das Signed-off-by: Can Guo Reviewed-by: Bean Huo --- drivers/scsi/ufs/ufshcd.c | 21 ++++++++++++++++++--- 1 file changed, 18 insertions(+), 3 deletions(-) diff --git a/drivers/scsi/ufs/ufshcd.c b/drivers/scsi/ufs/ufshcd.c index abd0e6b..10dbc0c 100644 --- a/drivers/scsi/ufs/ufshcd.c +++ b/drivers/scsi/ufs/ufshcd.c @@ -4730,8 +4730,15 @@ static void ufshcd_slave_destroy(struct scsi_device *sdev) * UFS device needs urgent BKOPs. */ if (!hba->pm_op_in_progress && - ufshcd_is_exception_event(lrbp->ucd_rsp_ptr)) - schedule_work(&hba->eeh_work); + ufshcd_is_exception_event(lrbp->ucd_rsp_ptr) && + schedule_work(&hba->eeh_work)) { + /* + * Prevent suspend once eeh_work is scheduled + * to avoid deadlock between ufshcd_suspend + * and exception event handler. + */ + pm_runtime_get_noresume(hba->dev); + } break; case UPIU_TRANSACTION_REJECT_UPIU: /* TODO: handle Reject UPIU Response */ @@ -5184,7 +5191,14 @@ static void ufshcd_exception_event_handler(struct work_struct *work) out: ufshcd_scsi_unblock_requests(hba); - pm_runtime_put_sync(hba->dev); + /* + * pm_runtime_get_noresume is called while scheduling + * eeh_work to avoid suspend racing with exception work. + * Hence decrement usage counter using pm_runtime_put_noidle + * to allow suspend on completion of exception event handler. + */ + pm_runtime_put_noidle(hba->dev); + pm_runtime_put(hba->dev); return; } @@ -7924,6 +7938,7 @@ static int ufshcd_suspend(struct ufs_hba *hba, enum ufs_pm_op pm_op) goto enable_gating; } + flush_work(&hba->eeh_work); ret = ufshcd_link_state_transition(hba, req_link_state, 1); if (ret) goto set_dev_active; -- The Qualcomm Innovation Center, Inc. is a member of the Code Aurora Forum, a Linux Foundation Collaborative Project