diff options
author | Can Guo <cang@codeaurora.org> | 2020-09-22 00:09:04 -0700 |
---|---|---|
committer | Martin K. Petersen <martin.petersen@oracle.com> | 2020-11-18 22:59:09 -0500 |
commit | 73cc291c270248567245f084dcdf5078069af6b5 (patch) | |
tree | 940cc7b27c3e3657e850ea407cdb43a345bb3889 /fs/fs_types.c | |
parent | 1699f980d87fb678a669490462cf0b9517c1fb47 (diff) | |
download | lwn-73cc291c270248567245f084dcdf5078069af6b5.tar.gz lwn-73cc291c270248567245f084dcdf5078069af6b5.zip |
scsi: ufs: Make sure clk scaling happens only when HBA is runtime ACTIVE
If someone plays with the UFS clk scaling devfreq governor through sysfs,
ufshcd_devfreq_scale may be called even when HBA is not runtime ACTIVE.
This can lead to unexpected error. We cannot just protect it by calling
pm_runtime_get_sync() because that may cause a race condition since HBA
runtime suspend ops need to suspend clk scaling. To fix this call
pm_runtime_get_noresume() and check HBA's runtime status. Only proceed if
HBA is runtime ACTIVE, otherwise just bail.
governor_store
devfreq_performance_handler
update_devfreq
devfreq_set_target
ufshcd_devfreq_target
ufshcd_devfreq_scale
Link: https://lore.kernel.org/r/1600758548-28576-1-git-send-email-cang@codeaurora.org
Reviewed-by: Stanley Chu <stanley.chu@mediatek.com>
Signed-off-by: Can Guo <cang@codeaurora.org>
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
Diffstat (limited to 'fs/fs_types.c')
0 files changed, 0 insertions, 0 deletions