Commit c0691f9d authored by Shreyas B. Prabhu's avatar Shreyas B. Prabhu Committed by Michael Ellerman

powerpc/powernv: Use deepest stop state when cpu is offlined

If hardware supports stop state, use the deepest stop state when
the cpu is offlined.
Reviewed-by: default avatarGautham R. Shenoy <ego@linux.vnet.ibm.com>
Signed-off-by: default avatarShreyas B. Prabhu <shreyas@linux.vnet.ibm.com>
Signed-off-by: default avatarMichael Ellerman <mpe@ellerman.id.au>
parent 3005c597
...@@ -252,6 +252,11 @@ static void power9_idle(void) ...@@ -252,6 +252,11 @@ static void power9_idle(void)
*/ */
u64 pnv_first_deep_stop_state = MAX_STOP_STATE; u64 pnv_first_deep_stop_state = MAX_STOP_STATE;
/*
* Deepest stop idle state. Used when a cpu is offlined
*/
u64 pnv_deepest_stop_state;
/* /*
* Power ISA 3.0 idle initialization. * Power ISA 3.0 idle initialization.
* *
...@@ -314,8 +319,11 @@ static int __init pnv_arch300_idle_init(struct device_node *np, u32 *flags, ...@@ -314,8 +319,11 @@ static int __init pnv_arch300_idle_init(struct device_node *np, u32 *flags,
} }
/* /*
* Set pnv_first_deep_stop_state to the first stop level * Set pnv_first_deep_stop_state and pnv_deepest_stop_state.
* to cause hypervisor state loss * pnv_first_deep_stop_state should be set to the first stop
* level to cause hypervisor state loss.
* pnv_deepest_stop_state should be set to the deepest stop
* stop state.
*/ */
pnv_first_deep_stop_state = MAX_STOP_STATE; pnv_first_deep_stop_state = MAX_STOP_STATE;
for (i = 0; i < dt_idle_states; i++) { for (i = 0; i < dt_idle_states; i++) {
...@@ -324,6 +332,9 @@ static int __init pnv_arch300_idle_init(struct device_node *np, u32 *flags, ...@@ -324,6 +332,9 @@ static int __init pnv_arch300_idle_init(struct device_node *np, u32 *flags,
if ((flags[i] & OPAL_PM_LOSE_FULL_CONTEXT) && if ((flags[i] & OPAL_PM_LOSE_FULL_CONTEXT) &&
(pnv_first_deep_stop_state > psscr_rl)) (pnv_first_deep_stop_state > psscr_rl))
pnv_first_deep_stop_state = psscr_rl; pnv_first_deep_stop_state = psscr_rl;
if (pnv_deepest_stop_state < psscr_rl)
pnv_deepest_stop_state = psscr_rl;
} }
out: out:
......
...@@ -18,6 +18,7 @@ static inline void pnv_pci_shutdown(void) { } ...@@ -18,6 +18,7 @@ static inline void pnv_pci_shutdown(void) { }
#endif #endif
extern u32 pnv_get_supported_cpuidle_states(void); extern u32 pnv_get_supported_cpuidle_states(void);
extern u64 pnv_deepest_stop_state;
extern void pnv_lpc_init(void); extern void pnv_lpc_init(void);
......
...@@ -182,7 +182,9 @@ static void pnv_smp_cpu_kill_self(void) ...@@ -182,7 +182,9 @@ static void pnv_smp_cpu_kill_self(void)
ppc64_runlatch_off(); ppc64_runlatch_off();
if (idle_states & OPAL_PM_WINKLE_ENABLED) if (cpu_has_feature(CPU_FTR_ARCH_300))
srr1 = power9_idle_stop(pnv_deepest_stop_state);
else if (idle_states & OPAL_PM_WINKLE_ENABLED)
srr1 = power7_winkle(); srr1 = power7_winkle();
else if ((idle_states & OPAL_PM_SLEEP_ENABLED) || else if ((idle_states & OPAL_PM_SLEEP_ENABLED) ||
(idle_states & OPAL_PM_SLEEP_ENABLED_ER1)) (idle_states & OPAL_PM_SLEEP_ENABLED_ER1))
......
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