Commit 268dd4ed authored by Vladimir Lypak's avatar Vladimir Lypak Committed by Will Deacon

iommu/qcom: restore IOMMU state if needed

If the IOMMU has a power domain then some state will be lost in
qcom_iommu_suspend and TZ will reset device if we don't call
qcom_scm_restore_sec_cfg before accessing it again.
Signed-off-by: default avatarVladimir Lypak <vladimir.lypak@gmail.com>
[luca@z3ntu.xyz: reword commit message a bit]
Signed-off-by: default avatarLuca Weiss <luca@z3ntu.xyz>
Link: https://lore.kernel.org/r/20231011-msm8953-iommu-restore-v1-1-48a0c93809a2@z3ntu.xyzSigned-off-by: default avatarWill Deacon <will@kernel.org>
parent 28af105c
...@@ -900,8 +900,16 @@ static void qcom_iommu_device_remove(struct platform_device *pdev) ...@@ -900,8 +900,16 @@ static void qcom_iommu_device_remove(struct platform_device *pdev)
static int __maybe_unused qcom_iommu_resume(struct device *dev) static int __maybe_unused qcom_iommu_resume(struct device *dev)
{ {
struct qcom_iommu_dev *qcom_iommu = dev_get_drvdata(dev); struct qcom_iommu_dev *qcom_iommu = dev_get_drvdata(dev);
int ret;
ret = clk_bulk_prepare_enable(CLK_NUM, qcom_iommu->clks);
if (ret < 0)
return ret;
if (dev->pm_domain)
return qcom_scm_restore_sec_cfg(qcom_iommu->sec_id, 0);
return clk_bulk_prepare_enable(CLK_NUM, qcom_iommu->clks); return ret;
} }
static int __maybe_unused qcom_iommu_suspend(struct device *dev) static int __maybe_unused qcom_iommu_suspend(struct device *dev)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment