diff options
author | Paul Mackerras <paulus@samba.org> | 2011-04-04 23:59:58 -0400 |
---|---|---|
committer | Benjamin Herrenschmidt <benh@kernel.crashing.org> | 2011-04-19 21:03:23 -0400 |
commit | 673b189a2e3353061fa8c49515d1014dab6ad9b9 (patch) | |
tree | 71d5842f2dcfcd24370ef25f35c97f0f81ebae87 /arch/powerpc/kvm/book3s_rmhandlers.S | |
parent | b3e6b5dfcf0974069a8ddcce7dd071120d20d79c (diff) |
powerpc: Always use SPRN_SPRG_HSCRATCH0 when running in HV mode
This uses feature sections to arrange that we always use HSPRG1
as the scratch register in the interrupt entry code rather than
SPRG2 when we're running in hypervisor mode on POWER7. This will
ensure that we don't trash the guest's SPRG2 when we are running
KVM guests. To simplify the code, we define GET_SCRATCH0() and
SET_SCRATCH0() macros like the GET_PACA/SET_PACA macros.
Signed-off-by: Paul Mackerras <paulus@samba.org>
Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
Diffstat (limited to 'arch/powerpc/kvm/book3s_rmhandlers.S')
-rw-r--r-- | arch/powerpc/kvm/book3s_rmhandlers.S | 6 |
1 files changed, 3 insertions, 3 deletions
diff --git a/arch/powerpc/kvm/book3s_rmhandlers.S b/arch/powerpc/kvm/book3s_rmhandlers.S index 046e1f3d4432..ae99af66ca34 100644 --- a/arch/powerpc/kvm/book3s_rmhandlers.S +++ b/arch/powerpc/kvm/book3s_rmhandlers.S | |||
@@ -70,7 +70,7 @@ | |||
70 | .global kvmppc_trampoline_\intno | 70 | .global kvmppc_trampoline_\intno |
71 | kvmppc_trampoline_\intno: | 71 | kvmppc_trampoline_\intno: |
72 | 72 | ||
73 | mtspr SPRN_SPRG_SCRATCH0, r13 /* Save r13 */ | 73 | SET_SCRATCH0(r13) /* Save r13 */ |
74 | 74 | ||
75 | /* | 75 | /* |
76 | * First thing to do is to find out if we're coming | 76 | * First thing to do is to find out if we're coming |
@@ -89,7 +89,7 @@ kvmppc_trampoline_\intno: | |||
89 | lwz r12, (SHADOW_VCPU_OFF + SVCPU_SCRATCH1)(r13) | 89 | lwz r12, (SHADOW_VCPU_OFF + SVCPU_SCRATCH1)(r13) |
90 | mtcr r12 | 90 | mtcr r12 |
91 | PPC_LL r12, (SHADOW_VCPU_OFF + SVCPU_SCRATCH0)(r13) | 91 | PPC_LL r12, (SHADOW_VCPU_OFF + SVCPU_SCRATCH0)(r13) |
92 | mfspr r13, SPRN_SPRG_SCRATCH0 /* r13 = original r13 */ | 92 | GET_SCRATCH0(r13) /* r13 = original r13 */ |
93 | b kvmppc_resume_\intno /* Get back original handler */ | 93 | b kvmppc_resume_\intno /* Get back original handler */ |
94 | 94 | ||
95 | /* Now we know we're handling a KVM guest */ | 95 | /* Now we know we're handling a KVM guest */ |
@@ -157,7 +157,7 @@ kvmppc_handler_skip_ins: | |||
157 | lwz r12, (SHADOW_VCPU_OFF + SVCPU_SCRATCH1)(r13) | 157 | lwz r12, (SHADOW_VCPU_OFF + SVCPU_SCRATCH1)(r13) |
158 | mtcr r12 | 158 | mtcr r12 |
159 | PPC_LL r12, (SHADOW_VCPU_OFF + SVCPU_SCRATCH0)(r13) | 159 | PPC_LL r12, (SHADOW_VCPU_OFF + SVCPU_SCRATCH0)(r13) |
160 | mfspr r13, SPRN_SPRG_SCRATCH0 | 160 | GET_SCRATCH0(r13) |
161 | 161 | ||
162 | /* And get back into the code */ | 162 | /* And get back into the code */ |
163 | RFI | 163 | RFI |