diff options
author | Paul Mackerras <paulus@samba.org> | 2011-06-28 20:20:58 -0400 |
---|---|---|
committer | Avi Kivity <avi@redhat.com> | 2011-07-12 06:16:53 -0400 |
commit | 3c42bf8a717cb636e0ed2ed77194669e2ac3ed56 (patch) | |
tree | 4f543088e6a64ce7f1a771c1618668ff27752ecc /arch/powerpc/kernel/exceptions-64s.S | |
parent | 923c53caea446d246949c94703be83e68f251af7 (diff) |
KVM: PPC: Split host-state fields out of kvmppc_book3s_shadow_vcpu
There are several fields in struct kvmppc_book3s_shadow_vcpu that
temporarily store bits of host state while a guest is running,
rather than anything relating to the particular guest or vcpu.
This splits them out into a new kvmppc_host_state structure and
modifies the definitions in asm-offsets.c to suit.
On 32-bit, we have a kvmppc_host_state structure inside the
kvmppc_book3s_shadow_vcpu since the assembly code needs to be able
to get to them both with one pointer. On 64-bit they are separate
fields in the PACA. This means that on 64-bit we don't need to
copy the kvmppc_host_state in and out on vcpu load/unload, and
in future will mean that the book3s_hv code doesn't need a
shadow_vcpu struct in the PACA at all. That does mean that we
have to be careful not to rely on any values persisting in the
hstate field of the paca across any point where we could block
or get preempted.
Signed-off-by: Paul Mackerras <paulus@samba.org>
Signed-off-by: Alexander Graf <agraf@suse.de>
Diffstat (limited to 'arch/powerpc/kernel/exceptions-64s.S')
-rw-r--r-- | arch/powerpc/kernel/exceptions-64s.S | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/arch/powerpc/kernel/exceptions-64s.S b/arch/powerpc/kernel/exceptions-64s.S index e76472cbf3b5..6da00550afea 100644 --- a/arch/powerpc/kernel/exceptions-64s.S +++ b/arch/powerpc/kernel/exceptions-64s.S | |||
@@ -298,7 +298,7 @@ data_access_check_stab: | |||
298 | srdi r10,r10,60 | 298 | srdi r10,r10,60 |
299 | rlwimi r10,r9,16,0x20 | 299 | rlwimi r10,r9,16,0x20 |
300 | #ifdef CONFIG_KVM_BOOK3S_64_HANDLER | 300 | #ifdef CONFIG_KVM_BOOK3S_64_HANDLER |
301 | lbz r9,PACA_KVM_SVCPU+SVCPU_IN_GUEST(r13) | 301 | lbz r9,HSTATE_IN_GUEST(r13) |
302 | rlwimi r10,r9,8,0x300 | 302 | rlwimi r10,r9,8,0x300 |
303 | #endif | 303 | #endif |
304 | mfcr r9 | 304 | mfcr r9 |