From deed2b8398ced11d72d90f4811024a5a99dde953 Mon Sep 17 00:00:00 2001 From: "Andrew F. Davis" Date: Mon, 25 Jun 2018 12:36:25 -0500 Subject: [PATCH] ti: k3: common: Enable interrupts before entering standby state To wake a core from wfi interrupts must be enabled, in some cases they may not be and so we can lock up here. Unconditionally enable interrupts before wfi and then restore interrupt state. Signed-off-by: Andrew F. Davis --- plat/ti/k3/common/k3_psci.c | 14 ++++++++++---- 1 file changed, 10 insertions(+), 4 deletions(-) diff --git a/plat/ti/k3/common/k3_psci.c b/plat/ti/k3/common/k3_psci.c index 91602c8c1..4d6428b5c 100644 --- a/plat/ti/k3/common/k3_psci.c +++ b/plat/ti/k3/common/k3_psci.c @@ -17,12 +17,18 @@ uintptr_t k3_sec_entrypoint; static void k3_cpu_standby(plat_local_state_t cpu_state) { - /* - * Enter standby state - * dsb is good practice before using wfi to enter low power states - */ + unsigned int scr; + + scr = read_scr_el3(); + /* Enable the Non secure interrupt to wake the CPU */ + write_scr_el3(scr | SCR_IRQ_BIT | SCR_FIQ_BIT); + isb(); + /* dsb is good practice before using wfi to enter low power states */ dsb(); + /* Enter standby state */ wfi(); + /* Restore SCR */ + write_scr_el3(scr); } static int k3_pwr_domain_on(u_register_t mpidr) -- GitLab