diff options
Diffstat (limited to 'plat/imx/imx8m/imx8m_psci_common.c')
-rw-r--r-- | plat/imx/imx8m/imx8m_psci_common.c | 9 |
1 files changed, 7 insertions, 2 deletions
diff --git a/plat/imx/imx8m/imx8m_psci_common.c b/plat/imx/imx8m/imx8m_psci_common.c index d6416288..fd5e7147 100644 --- a/plat/imx/imx8m/imx8m_psci_common.c +++ b/plat/imx/imx8m/imx8m_psci_common.c @@ -13,6 +13,7 @@ #include <lib/mmio.h> #include <lib/psci/psci.h> +#include <dram.h> #include <gpc.h> #include <imx8m_psci.h> #include <plat_imx8.h> @@ -118,8 +119,10 @@ void imx_domain_suspend(const psci_power_state_t *target_state) if (!is_local_state_run(CLUSTER_PWR_STATE(target_state))) imx_set_cluster_powerdown(core_id, CLUSTER_PWR_STATE(target_state)); - if (is_local_state_off(SYSTEM_PWR_STATE(target_state))) + if (is_local_state_off(SYSTEM_PWR_STATE(target_state))) { imx_set_sys_lpm(core_id, true); + dram_enter_retention(); + } } void imx_domain_suspend_finish(const psci_power_state_t *target_state) @@ -127,8 +130,10 @@ void imx_domain_suspend_finish(const psci_power_state_t *target_state) uint64_t mpidr = read_mpidr_el1(); unsigned int core_id = MPIDR_AFFLVL0_VAL(mpidr); - if (is_local_state_off(SYSTEM_PWR_STATE(target_state))) + if (is_local_state_off(SYSTEM_PWR_STATE(target_state))) { + dram_exit_retention(); imx_set_sys_lpm(core_id, false); + } if (!is_local_state_run(CLUSTER_PWR_STATE(target_state))) { imx_clear_rbc_count(); |