[PATCH v1] ufs: core: bypass get rpm when err handling with pm_op_in_progress
Peter Wang
peter.wang at mediatek.com
Mon Sep 19 19:00:48 PDT 2022
On 9/20/22 00:25, Bart Van Assche wrote:
> On 9/19/22 07:47, Peter Wang wrote:
>> If the scsi error happened and need do ufshcd_eh_host_reset_handler,
>> the rpm state should in RPM_ACTIVE.
>> Because scsi need wakeup suspended LUN, and send command to LUN then
>> get error, right?
>
> The following sequence may activate the SCSI error handler while the
> RPM state is RPM_RESUMING:
> * The RPM state is RPM_SUSPENDED.
> * The RPM state is changed into RPM_RESUMING and ufshcd_wl_resume() is
> called.
> * ufshcd_set_dev_pwr_mode() calls scsi_execute() and the START STOP
> UNIT command times out.
> * Because of this timeout the SCSI error handler is activated.
This case will not get rpm, because pm_op_in_progress is true.
So it won't hang with ufshcd_rpm_get_sync.
Thanks
Peter
More information about the Linux-mediatek
mailing list