mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2026-02-21 21:12:25 -05:00
scsi: ufs: exynos: Add check inside exynos_ufs_config_smu()
Move the EXYNOS_UFS_OPT_UFSPR_SECURE check inside
exynos_ufs_config_smu().
This way all call sites will benefit from the check. This fixes a bug
currently in the exynos_ufs_resume() path on gs101 as it calls
exynos_ufs_config_smu() and we end up accessing registers that can only
be accessed from secure world which results in a serror.
Fixes: d11e0a318d ("scsi: ufs: exynos: Add support for Tensor gs101 SoC")
Signed-off-by: Peter Griffin <peter.griffin@linaro.org>
Link: https://lore.kernel.org/r/20241031150033.3440894-5-peter.griffin@linaro.org
Cc: stable@vger.kernel.org
Reviewed-by: Tudor Ambarus <tudor.ambarus@linaro.org>
Signed-off-by: Martin K. Petersen <martin.petersen@oracle.com>
This commit is contained in:
committed by
Martin K. Petersen
parent
516ceaaf53
commit
c662cedea1
@@ -719,6 +719,9 @@ static void exynos_ufs_config_smu(struct exynos_ufs *ufs)
|
||||
{
|
||||
u32 reg, val;
|
||||
|
||||
if (ufs->opts & EXYNOS_UFS_OPT_UFSPR_SECURE)
|
||||
return;
|
||||
|
||||
exynos_ufs_disable_auto_ctrl_hcc_save(ufs, &val);
|
||||
|
||||
/* make encryption disabled by default */
|
||||
@@ -1454,8 +1457,8 @@ static int exynos_ufs_init(struct ufs_hba *hba)
|
||||
if (ret)
|
||||
goto out;
|
||||
exynos_ufs_specify_phy_time_attr(ufs);
|
||||
if (!(ufs->opts & EXYNOS_UFS_OPT_UFSPR_SECURE))
|
||||
exynos_ufs_config_smu(ufs);
|
||||
|
||||
exynos_ufs_config_smu(ufs);
|
||||
|
||||
hba->host->dma_alignment = DATA_UNIT_SIZE - 1;
|
||||
return 0;
|
||||
|
||||
Reference in New Issue
Block a user