powerpc/64s/idle: avoid sync for KVM state when waking from idle
authorNicholas Piggin <npiggin@gmail.com>
Fri, 17 Nov 2017 14:08:06 +0000 (00:08 +1000)
committerMichael Ellerman <mpe@ellerman.id.au>
Sat, 31 Mar 2018 13:47:47 +0000 (00:47 +1100)
When waking from a CPU idle instruction (e.g., nap or stop), the sync
for ordering the KVM secondary thread state can be avoided if there
wakeup is coming from a kernel context rather than KVM context.

This improves performance for ping-pong benchmark with the stop0 idle
state by 0.46% for 2 threads in the same core, and 1.02% for different
cores.

Signed-off-by: Nicholas Piggin <npiggin@gmail.com>
Signed-off-by: Michael Ellerman <mpe@ellerman.id.au>
arch/powerpc/kernel/idle_book3s.S

index 2896ccf3138db026fc60b6de4082d147bea71ece..903ec2a5c76c02b2b606ce791424b8de17b81b0b 100644 (file)
@@ -551,6 +551,9 @@ ALT_FTR_SECTION_END_IFSET(CPU_FTR_ARCH_300)
        mr      r3,r12
 
 #ifdef CONFIG_KVM_BOOK3S_HV_POSSIBLE
+       lbz     r0,HSTATE_HWTHREAD_STATE(r13)
+       cmpwi   r0,KVM_HWTHREAD_IN_KERNEL
+       beq     1f
        li      r0,KVM_HWTHREAD_IN_KERNEL
        stb     r0,HSTATE_HWTHREAD_STATE(r13)
        /* Order setting hwthread_state vs. testing hwthread_req */