Received: by 2002:a17:90a:88:0:0:0:0 with SMTP id a8csp516509pja; Thu, 7 Nov 2019 00:46:15 -0800 (PST) X-Google-Smtp-Source: APXvYqwmA0D8yNsK6ZL6cn8Y33hqTevCic2mCXuAk5hMFxoF9c3+1muLVM4cb6A0R7S3qvvKbI6u X-Received: by 2002:a50:cc42:: with SMTP id n2mr2186514edi.289.1573116375261; Thu, 07 Nov 2019 00:46:15 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1573116375; cv=none; d=google.com; s=arc-20160816; b=zr2WH6MZHvU37Vcom3Y3Zgy8J7+jRNN8qkCKsjVm9/mgqdCizs7X91+jBwDp2WF1Bl KQoGbdK/lzqkjyHUgdcI7x24SfGALvi2xjr/YyndXdfk7w1tkyhK6lJXWiyphoIrlgcQ nPN6qfrlVV3nyA98Y+rvfwMQP0c9GlUjAGXkM6A6rjz4V6TeEJcx3Aywqj40QppzKcSa rH1kRSzTThcRpZgRmmw4btY0gQsNbvBa7K57UTmn6E/+d8pTHLiftoyj5ZR4l/LWrSZE tuXgeuT/41WqyrWgVWkJkKaZCe4Mxnk3dldWyoc5uEcNSOV4MfAPe9QpUm9FGMZlocTO IycA== 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:dkim-signature; bh=9S0QIlbYmQAb+fbkT7yD3PV4Zf5YseEdwAjssYu+PQ8=; b=aeoja0E/66UZt4G0ykLpg5zSESkzsxnUcGE3NlzDbKXm4x6zU7OTbEyz69ZlFVzSBg qutNy7Jd314fv4toZCchWLC1cWNdUp/ia3j104Ej3Fa6jsz/IdMkT1zCxUOV4GaXtj1v 9C+G1tlwv4lEdnk5FbdoQwwxJEQ/tjStvYFf2oqa+WMqzjjUWDt5GDeeEj9BcIiXoxcr Dus8BHwcekTKGlxtTaZWhjpeWQn6O7la7tA9HdZfWH65E53WWUCdNo5WP1rEWrm9glBv t3cftiYVE09Amc7Q80u0fhW9nXMccNmtALJTowPpJ7matWMj1tobLQz49+JqnEX8/3fD jg6A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@codeaurora.org header.s=default header.b=QUU1tdqj; dkim=pass header.i=@codeaurora.org header.s=default header.b=HGXcey1f; 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 b25si1019820ejb.68.2019.11.07.00.45.52; Thu, 07 Nov 2019 00:46:15 -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=pass header.i=@codeaurora.org header.s=default header.b=QUU1tdqj; dkim=pass header.i=@codeaurora.org header.s=default header.b=HGXcey1f; 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 S1733285AbfKGImn (ORCPT + 99 others); Thu, 7 Nov 2019 03:42:43 -0500 Received: from smtp.codeaurora.org ([198.145.29.96]:33042 "EHLO smtp.codeaurora.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727120AbfKGImn (ORCPT ); Thu, 7 Nov 2019 03:42:43 -0500 Received: by smtp.codeaurora.org (Postfix, from userid 1000) id 0120D608FC; Thu, 7 Nov 2019 08:42:40 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1573116161; bh=FtDInhzlNbMYnaah34JKXnQVyTO/o1xFZ/slgp6EYrQ=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=QUU1tdqjx9o19obxJT26tMZaboE9qEr8UHYQQ+5C+JXCCbSGairwNLSvpqpQ5z4kD 0zluAuVJzLptT8N8lp21AYZPDRNcmImv2QQEWrgu+TB3Y4mcKL6Y4Uk4vqeZQlRuA8 MatQYJz+GHtO7V4mvS5qkodaoQ8cjPGDQd48TMyI= X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on pdx-caf-mail.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-2.7 required=2.0 tests=ALL_TRUSTED,BAYES_00, DKIM_INVALID,DKIM_SIGNED,SPF_NONE autolearn=no 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@smtp.codeaurora.org) by smtp.codeaurora.org (Postfix) with ESMTPSA id 37C7B60779; Thu, 7 Nov 2019 08:42:38 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=codeaurora.org; s=default; t=1573116159; bh=FtDInhzlNbMYnaah34JKXnQVyTO/o1xFZ/slgp6EYrQ=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=HGXcey1f6BYXCUSdubFAHI3ITrH7n5tkn9SjOKVaebwSNvm8tQ+BPeGDoWt99EMMk a4ZMjlNjUR7B3ppPKltuOMBvBXEc1E11shjU3MNjtQVU2fJC74TWAQB6t8h+9MQeIM THtAl+jYy90EKuONisWGdURGW/0TuCLWUBRLAOuw= DMARC-Filter: OpenDMARC Filter v1.3.2 smtp.codeaurora.org 37C7B60779 Authentication-Results: pdx-caf-mail.web.codeaurora.org; dmarc=none (p=none dis=none) header.from=codeaurora.org Authentication-Results: pdx-caf-mail.web.codeaurora.org; spf=none smtp.mailfrom=cang@codeaurora.org From: Can Guo To: asutoshd@codeaurora.org, nguyenb@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 , Pedro Sousa , "James E.J. Bottomley" , "Martin K. Petersen" , Stanley Chu , Tomas Winkler , Venkat Gopalakrishnan , Subhash Jadavani , linux-kernel@vger.kernel.org (open list) Subject: [PATCH v1 1/6] scsi: ufs: Flush exception event before suspend Date: Thu, 7 Nov 2019 00:42:08 -0800 Message-Id: <1573116140-22408-2-git-send-email-cang@codeaurora.org> X-Mailer: git-send-email 1.9.1 In-Reply-To: <1573116140-22408-1-git-send-email-cang@codeaurora.org> References: <1573116140-22408-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 --- 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 1201578..c2de29f 100644 --- a/drivers/scsi/ufs/ufshcd.c +++ b/drivers/scsi/ufs/ufshcd.c @@ -4760,8 +4760,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)) { + /* + * Prevent suspend once eeh_work is scheduled + * to avoid deadlock between ufshcd_suspend + * and exception event handler. + */ + if (schedule_work(&hba->eeh_work)) + pm_runtime_get_noresume(hba->dev); + } break; case UPIU_TRANSACTION_REJECT_UPIU: /* TODO: handle Reject UPIU Response */ @@ -5215,7 +5222,14 @@ static void ufshcd_exception_event_handler(struct work_struct *work) out: scsi_unblock_requests(hba->host); - 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; } @@ -7901,6 +7915,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