Received: by 2002:a25:1506:0:0:0:0:0 with SMTP id 6csp1210925ybv; Fri, 7 Feb 2020 16:51:58 -0800 (PST) X-Google-Smtp-Source: APXvYqwvJxMWMJ+x0MQ6jPMupHuy3W2ozosLVJdlefpq8C879Ou9sZO12UhHHQtV9MziBUhyqe3r X-Received: by 2002:a9d:5d07:: with SMTP id b7mr1671537oti.209.1581123118022; Fri, 07 Feb 2020 16:51:58 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1581123118; cv=none; d=google.com; s=arc-20160816; b=yM1FAhS6+xCxAU+v2mSuE/QnqsFBTcRjcaEJmqZuTrbfzI0CIPbfh9htYvz/NQuOY9 EVxQi7O03o6MZ2ufbOb3B/+8EIzHqF6wb3kxw/zXGY2enmFYzA+LorPhWzov+xJgYoRD 6cO4Avd0oh8BX0pkAzFybuEZhGnrFyj+1syA2y6wqkoyst9OtrSA0fXGcXGl2RJeb2Yt uLP39jFt632PG2p/hnBcEBeeuVHpHfE0gRZirSIBC+Z/qsM0jN07XLyfNtSECuTRL4Xu DXVFU+Sgwd+1bH0kTju6NUKALllYmeaVXdNUyodyJkD0mur8FcghShnGb4G9y76EawHX 8MWg== 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=qPkoBZcjFDDffVZqOjSoc0Prt/FQJ0KkDvb0IVj8YME=; b=USaZKKJuW82a2zwPoqXVSqhCCByHwRuZxS3A8N82QBPNOl0EbsoO7N6UuA0lE9WbDH WO8zCenHPeRKpvzwkRlAZcXi6JZDUBx7ENU/6RuxfiMWJjLhjsnDrcAJVCR4UDGLBKnK +yfCe29+lOrseCXnD4v9ico2am+JTUhwOTi7ifVyPh63EVEAT7OJaMWnLE5blaEADFLK BFcLuGz1tIvDUvPPuZ5LdmkVjbRSbBZzBnR5OZQBDvSzANywPR0gzuXOgncfIn7Lo4O2 kYF8vjX6m05BCCXVCtRGsezzHNA9WCaSfuKGOjDi4GkYf7ROTdPm+/9nIe52ky88pt6j scww== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@mg.codeaurora.org header.s=smtp header.b=QK8sYbAt; 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 e9si546832otk.318.2020.02.07.16.51.46; Fri, 07 Feb 2020 16:51:58 -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=QK8sYbAt; 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 S1727505AbgBHAuy (ORCPT + 99 others); Fri, 7 Feb 2020 19:50:54 -0500 Received: from mail25.static.mailgun.info ([104.130.122.25]:49099 "EHLO mail25.static.mailgun.info" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727131AbgBHAux (ORCPT ); Fri, 7 Feb 2020 19:50:53 -0500 DKIM-Signature: a=rsa-sha256; v=1; c=relaxed/relaxed; d=mg.codeaurora.org; q=dns/txt; s=smtp; t=1581123052; h=References: In-Reply-To: Message-Id: Date: Subject: Cc: To: From: Sender; bh=qPkoBZcjFDDffVZqOjSoc0Prt/FQJ0KkDvb0IVj8YME=; b=QK8sYbAtDR0aelDU0WulxP+pdBvq3JSyhLFFjAKc2ByaM65WZgFIe4W4/J1TQduiJ2Q/MqQi bXrklhkkd+9T2y7wwHcbYXt0SGaA+zSpfZ3phczKLdHZHOuLU2CRF0QRAov5RhCrNjHN7Wlr 6miUMvZM+4Up9Z1dF5eAS3hugUE= X-Mailgun-Sending-Ip: 104.130.122.25 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 5e3e05e7.7f3ca5d71308-smtp-out-n01; Sat, 08 Feb 2020 00:50:47 -0000 (UTC) Received: by smtp.codeaurora.org (Postfix, from userid 1001) id 78C2AC447A9; Sat, 8 Feb 2020 00:50:45 +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 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 93AD5C43383; Sat, 8 Feb 2020 00:50:43 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.3.2 smtp.codeaurora.org 93AD5C43383 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" , Bean Huo , Stanley Chu , Bart Van Assche , Venkat Gopalakrishnan , Tomas Winkler , linux-kernel@vger.kernel.org (open list) Subject: [PATCH 1/7] scsi: ufs: Flush exception event before suspend Date: Fri, 7 Feb 2020 16:50:23 -0800 Message-Id: <1581123030-12023-2-git-send-email-cang@codeaurora.org> X-Mailer: git-send-email 1.9.1 In-Reply-To: <1581123030-12023-1-git-send-email-cang@codeaurora.org> References: <1581123030-12023-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 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