diff options
author | Paul Mackerras <paulus@samba.org> | 2013-11-16 07:46:03 +0100 |
---|---|---|
committer | Alexander Graf <agraf@suse.de> | 2013-11-18 22:38:30 +0100 |
commit | f019b7ad76e6bdbc8462cbe17ad5b86a25fcdf24 (patch) | |
tree | 03a6ed2ce877bb17576ac8337305828d16b8a3bc /lib/cordic.c | |
parent | KVM: PPC: Book3S HV: Fix physical address calculations (diff) | |
download | linux-f019b7ad76e6bdbc8462cbe17ad5b86a25fcdf24.tar.xz linux-f019b7ad76e6bdbc8462cbe17ad5b86a25fcdf24.zip |
KVM: PPC: Book3S HV: Refine barriers in guest entry/exit
Some users have reported instances of the host hanging with secondary
threads of a core waiting for the primary thread to exit the guest,
and the primary thread stuck in nap mode. This prompted a review of
the memory barriers in the guest entry/exit code, and this is the
result. Most of these changes are the suggestions of Dean Burdick
<deanburdick@us.ibm.com>.
The barriers between updating napping_threads and reading the
entry_exit_count on the one hand, and updating entry_exit_count and
reading napping_threads on the other, need to be isync not lwsync,
since we need to ensure that either the napping_threads update or the
entry_exit_count update get seen. It is not sufficient to order the
load vs. lwarx, as lwsync does; we need to order the load vs. the
stwcx., so we need isync.
In addition, we need a full sync before sending IPIs to wake other
threads from nap, to ensure that the write to the entry_exit_count is
visible before the IPI occurs.
Signed-off-by: Paul Mackerras <paulus@samba.org>
Signed-off-by: Alexander Graf <agraf@suse.de>
Diffstat (limited to 'lib/cordic.c')
0 files changed, 0 insertions, 0 deletions