Skip to content

Commit

Permalink
soc: xtensa: intel_adsp: restore bootctl with per-core state
Browse files Browse the repository at this point in the history
When exiting PM_STATE_SOFT_OFF, the primary core state is always
used to restore bootctl register and the clock and power gating
settings.

This can lead to problems if non-primary core is powered up and down
many times before primary core 0 is powered down the first time.
The saved state in core_desc[0].bctl will be null, and as a result-
power gating and clock gating is not disabled correctly for
non-primary cores.

Link: thesofproject/sof#8642
Signed-off-by: Kai Vehmanen <[email protected]>
(cherry picked from commit a8af622)
  • Loading branch information
kv2019i committed Mar 4, 2024
1 parent 3441525 commit 684fe0d
Showing 1 changed file with 1 addition and 1 deletion.
2 changes: 1 addition & 1 deletion soc/xtensa/intel_adsp/ace/power.c
Original file line number Diff line number Diff line change
Expand Up @@ -326,7 +326,7 @@ void pm_state_exit_post_ops(enum pm_state state, uint8_t substate_id)
if (state == PM_STATE_SOFT_OFF) {
/* restore clock gating state */
DSPCS.bootctl[cpu].bctl |=
(core_desc[0].bctl & DSPBR_BCTL_WAITIPCG);
(core_desc[cpu].bctl & DSPBR_BCTL_WAITIPCG);

#ifdef CONFIG_ADSP_IMR_CONTEXT_SAVE
if (cpu == 0) {
Expand Down

0 comments on commit 684fe0d

Please sign in to comment.