powerpc/powernv: Fix SMT4 forcing idle code
authorNicholas Piggin <npiggin@gmail.com>
Sun, 1 Apr 2018 05:38:13 +0000 (15:38 +1000)
committerMichael Ellerman <mpe@ellerman.id.au>
Tue, 3 Apr 2018 12:14:27 +0000 (22:14 +1000)
commita2b5e056b75ee6ef0777817644a456b36b96ce38
tree02711ff4c5dc10a6ab6cb756c4bbbc5d1720e2e8
parentb6f534d1a642a9b6263fd52df30806171fbc331e
powerpc/powernv: Fix SMT4 forcing idle code

The PSSCR value is not stored to PACA_REQ_PSSCR if the CPU does not
have the XER[SO] bug.

Fix this by storing up-front, outside the workaround code. The initial
test is not required because it is a slow path.

The workaround is made to depend on CONFIG_KVM_BOOK3S_HV_POSSIBLE, to
match pnv_power9_force_smt4_catch() where it is used. Drop the comment
on pnv_power9_force_smt4_catch() as it's no longer true.

Fixes: 7672691a08c8 ("powerpc/powernv: Provide a way to force a core into SMT4 mode")
Signed-off-by: Nicholas Piggin <npiggin@gmail.com>
Signed-off-by: Michael Ellerman <mpe@ellerman.id.au>
arch/powerpc/kernel/idle_book3s.S
arch/powerpc/platforms/powernv/idle.c