aboutsummaryrefslogtreecommitdiffstats
path: root/arch/powerpc/include/asm/exception-64s.h
diff options
context:
space:
mode:
authorPaul Mackerras <paulus@samba.org>2011-06-28 20:20:58 -0400
committerAvi Kivity <avi@redhat.com>2011-07-12 06:16:53 -0400
commit3c42bf8a717cb636e0ed2ed77194669e2ac3ed56 (patch)
tree4f543088e6a64ce7f1a771c1618668ff27752ecc /arch/powerpc/include/asm/exception-64s.h
parent923c53caea446d246949c94703be83e68f251af7 (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/include/asm/exception-64s.h')
-rw-r--r--arch/powerpc/include/asm/exception-64s.h10
1 files changed, 5 insertions, 5 deletions
diff --git a/arch/powerpc/include/asm/exception-64s.h b/arch/powerpc/include/asm/exception-64s.h
index b6a3a443fbde..296c9b66c04a 100644
--- a/arch/powerpc/include/asm/exception-64s.h
+++ b/arch/powerpc/include/asm/exception-64s.h
@@ -96,16 +96,16 @@
96 EXCEPTION_PROLOG_PSERIES_1(label, h); 96 EXCEPTION_PROLOG_PSERIES_1(label, h);
97 97
98#define __KVMTEST(n) \ 98#define __KVMTEST(n) \
99 lbz r10,PACA_KVM_SVCPU+SVCPU_IN_GUEST(r13); \ 99 lbz r10,HSTATE_IN_GUEST(r13); \
100 cmpwi r10,0; \ 100 cmpwi r10,0; \
101 bne do_kvm_##n 101 bne do_kvm_##n
102 102
103#define __KVM_HANDLER(area, h, n) \ 103#define __KVM_HANDLER(area, h, n) \
104do_kvm_##n: \ 104do_kvm_##n: \
105 ld r10,area+EX_R10(r13); \ 105 ld r10,area+EX_R10(r13); \
106 stw r9,PACA_KVM_SVCPU+SVCPU_SCRATCH1(r13); \ 106 stw r9,HSTATE_SCRATCH1(r13); \
107 ld r9,area+EX_R9(r13); \ 107 ld r9,area+EX_R9(r13); \
108 std r12,PACA_KVM_SVCPU+SVCPU_SCRATCH0(r13); \ 108 std r12,HSTATE_SCRATCH0(r13); \
109 li r12,n; \ 109 li r12,n; \
110 b kvmppc_interrupt 110 b kvmppc_interrupt
111 111
@@ -114,9 +114,9 @@ do_kvm_##n: \
114 cmpwi r10,KVM_GUEST_MODE_SKIP; \ 114 cmpwi r10,KVM_GUEST_MODE_SKIP; \
115 ld r10,area+EX_R10(r13); \ 115 ld r10,area+EX_R10(r13); \
116 beq 89f; \ 116 beq 89f; \
117 stw r9,PACA_KVM_SVCPU+SVCPU_SCRATCH1(r13); \ 117 stw r9,HSTATE_SCRATCH1(r13); \
118 ld r9,area+EX_R9(r13); \ 118 ld r9,area+EX_R9(r13); \
119 std r12,PACA_KVM_SVCPU+SVCPU_SCRATCH0(r13); \ 119 std r12,HSTATE_SCRATCH0(r13); \
120 li r12,n; \ 120 li r12,n; \
121 b kvmppc_interrupt; \ 121 b kvmppc_interrupt; \
12289: mtocrf 0x80,r9; \ 12289: mtocrf 0x80,r9; \