From: "Asutosh Das (asd)" <asutoshd@codeaurora.org>
To: cang@codeaurora.org, martin.petersen@oracle.com,
adrian.hunter@intel.com, linux-scsi@vger.kernel.org
Cc: linux-arm-msm@vger.kernel.org,
Matthias Brugger <matthias.bgg@gmail.com>,
"moderated list:ARM/Mediatek SoC support"
<linux-arm-kernel@lists.infradead.org>,
"moderated list:ARM/Mediatek SoC support"
<linux-mediatek@lists.infradead.org>
Subject: Re: [PATCH v13 0/2] Enable power management for ufs wlun
Date: Mon, 29 Mar 2021 15:48:05 -0700 [thread overview]
Message-ID: <e2aec2ba-b0ed-a478-7c01-1784f755a805@codeaurora.org> (raw)
In-Reply-To: <cover.1616633712.git.asutoshd@codeaurora.org>
On 3/24/2021 6:39 PM, Asutosh Das wrote:
> This patch attempts to fix a deadlock in ufs while sending SSU.
> Recently, blk_queue_enter() added a check to not process requests if the
> queue is suspended. That leads to a resume of the associated device which
> is suspended. In ufs, that device is ufs device wlun and it's parent is
> ufs_hba. This resume tries to resume ufs device wlun which in turn tries
> to resume ufs_hba, which is already in the process of suspending, thus
> causing a deadlock.
>
> This patch takes care of:
> * Suspending the ufs device lun only after all other luns are suspended
> * Sending SSU during ufs device wlun suspend
> * Clearing uac for rpmb and ufs device wlun
> * Not sending commands to the device during host suspend
>
> v12 -> v13:
> - Addressed Adrian's comments
> * Paired pm_runtime_get_noresume() with pm_runtime_put()
> * no rpm_autosuspend for ufs device wlun
> * Moved runtime-pm init functionality to ufshcd_wl_probe()
> - Addressed Bart's comments
> * Expanded abbrevs in commit message
>
Hi Adrian
I did a limited testing on your fix in the pm framework along with this
v13 patchset. I couldn't reproduce the issue.
I'd appreciate if you can please take a look at the v13 changes.
If all looks good in that, I'd do an extensive testing.
Thanks,
-asd
> v11 -> v12:
> - Addressed Adrian's comments
> * Fixed ahit for Mediatek driver
> * Fixed error handling in ufshcd_core_init()
> * Tested this patch and the issue is still seen.
>
> v10 -> v11:
> - Fixed supplier suspending before consumer race
> - Addressed Adrian's comments
> * Added proper resume/suspend cb to ufshcd_auto_hibern8_update()
> * Cosmetic changes to ufshcd-pci.c
> * Cleaned up ufshcd_system_suspend()
> * Added ufshcd_debugfs_eh_exit to ufshcd_core_init()
>
> v9 -> v10:
> - Addressed Adrian's comments
> * Moved suspend/resume vops to __ufshcd_wl_[suspend/resume]()
> * Added correct resume in ufs_bsg
>
> v8 -> v9:
> - Addressed Adrian's comments
> * Moved link transition to __ufshcd_wl_[suspend/resume]()
> * Fixed the other minor comments
>
> v7 -> v8:
> - Addressed Adrian's comments
> * Removed separate autosuspend delay for ufs-device lun
> * Fixed the ee handler getting scheduled during pm
> * Always runtime resume in suspend_prepare()
> * Added CONFIG_PM_SLEEP where needed
>
> v6 -> v7:
> * Resume the ufs device before shutting it down
>
> v5 -> v6:
> - Addressed Adrian's comments
> * Added complete() cb
> * Added suspend_prepare() and complete() to all drivers
> * Moved suspend_prepare() and complete() to ufshcd
> * .poweroff() uses ufhcd_wl_poweroff()
> * Removed several forward declarations
> * Moved scsi_register_driver() to ufshcd_core_init()
>
> v4 -> v5:
> - Addressed Adrian's comments
> * Used the rpmb driver contributed by Adrian
> * Runtime-resume the ufs device during suspend to honor spm-lvl
> * Unregister the scsi_driver in ufshcd_remove()
> * Currently shutdown() puts the ufs device to power-down mode
> so, just removed ufshcd_pci_poweroff()
> * Quiesce the scsi device during shutdown instead of remove
>
> v3 RFC -> v4:
> - Addressed Bart's comments
> * Except that I didn't get any checkpatch failures
> - Addressed Avri's comments
> - Addressed Adrian's comments
> * Added a check for deepsleep power mode
> * Removed a couple of forward declarations
> * Didn't separate the scsi drivers because in rpmb case it just sends uac
> in resume and it seemed pretty neat to me.
> - Added sysfs changes to resume the devices before accessing
>
> Asutosh Das (2):
> scsi: ufs: Enable power management for wlun
> ufs: sysfs: Resume the proper scsi device
>
> drivers/scsi/ufs/cdns-pltfrm.c | 2 +
> drivers/scsi/ufs/tc-dwc-g210-pci.c | 2 +
> drivers/scsi/ufs/ufs-debugfs.c | 2 +-
> drivers/scsi/ufs/ufs-debugfs.h | 2 +-
> drivers/scsi/ufs/ufs-exynos.c | 2 +
> drivers/scsi/ufs/ufs-hisi.c | 2 +
> drivers/scsi/ufs/ufs-mediatek.c | 12 +-
> drivers/scsi/ufs/ufs-qcom.c | 2 +
> drivers/scsi/ufs/ufs-sysfs.c | 30 +-
> drivers/scsi/ufs/ufs_bsg.c | 6 +-
> drivers/scsi/ufs/ufshcd-pci.c | 36 +--
> drivers/scsi/ufs/ufshcd.c | 627 ++++++++++++++++++++++++++-----------
> drivers/scsi/ufs/ufshcd.h | 6 +
> include/trace/events/ufs.h | 20 ++
> 14 files changed, 513 insertions(+), 238 deletions(-)
>
--
The Qualcomm Innovation Center, Inc. is a member of the Code Aurora Forum,
Linux Foundation Collaborative Project
next prev parent reply other threads:[~2021-03-29 22:49 UTC|newest]
Thread overview: 6+ messages / expand[flat|nested] mbox.gz Atom feed top
2021-03-25 1:39 [PATCH v13 0/2] Enable power management for ufs wlun Asutosh Das
2021-03-25 1:39 ` [PATCH v13 1/2] scsi: ufs: Enable power management for wlun Asutosh Das
2021-03-30 10:03 ` Adrian Hunter
2021-03-25 1:39 ` [PATCH v13 2/2] ufs: sysfs: Resume the proper scsi device Asutosh Das
2021-03-29 22:48 ` Asutosh Das (asd) [this message]
2021-03-30 10:07 ` [PATCH v13 0/2] Enable power management for ufs wlun Adrian Hunter
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=e2aec2ba-b0ed-a478-7c01-1784f755a805@codeaurora.org \
--to=asutoshd@codeaurora.org \
--cc=adrian.hunter@intel.com \
--cc=cang@codeaurora.org \
--cc=linux-arm-kernel@lists.infradead.org \
--cc=linux-arm-msm@vger.kernel.org \
--cc=linux-mediatek@lists.infradead.org \
--cc=linux-scsi@vger.kernel.org \
--cc=martin.petersen@oracle.com \
--cc=matthias.bgg@gmail.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).