Commit a5ddea0e authored by Paul Mackerras's avatar Paul Mackerras

KVM: PPC: Book3S HV: Save and restore CR in __kvmppc_vcore_entry

The ABI specifies that CR fields CR2--CR4 are nonvolatile across function
calls.  Currently __kvmppc_vcore_entry doesn't save and restore the CR,
leading to CR2--CR4 getting corrupted with guest values, possibly leading
to incorrect behaviour in its caller.  This adds instructions to save
and restore CR at the points where we save and restore the nonvolatile
GPRs.
Signed-off-by: default avatarPaul Mackerras <paulus@samba.org>
Signed-off-by: default avatarAlexander Graf <agraf@suse.de>
Signed-off-by: default avatarPaul Mackerras <paulus@samba.org>
parent b4e51229
...@@ -46,8 +46,10 @@ _GLOBAL(__kvmppc_vcore_entry) ...@@ -46,8 +46,10 @@ _GLOBAL(__kvmppc_vcore_entry)
/* Save host state to the stack */ /* Save host state to the stack */
stdu r1, -SWITCH_FRAME_SIZE(r1) stdu r1, -SWITCH_FRAME_SIZE(r1)
/* Save non-volatile registers (r14 - r31) */ /* Save non-volatile registers (r14 - r31) and CR */
SAVE_NVGPRS(r1) SAVE_NVGPRS(r1)
mfcr r3
std r3, _CCR(r1)
/* Save host DSCR */ /* Save host DSCR */
BEGIN_FTR_SECTION BEGIN_FTR_SECTION
...@@ -157,8 +159,10 @@ kvmppc_handler_highmem: ...@@ -157,8 +159,10 @@ kvmppc_handler_highmem:
* R13 = PACA * R13 = PACA
*/ */
/* Restore non-volatile host registers (r14 - r31) */ /* Restore non-volatile host registers (r14 - r31) and CR */
REST_NVGPRS(r1) REST_NVGPRS(r1)
ld r4, _CCR(r1)
mtcr r4
addi r1, r1, SWITCH_FRAME_SIZE addi r1, r1, SWITCH_FRAME_SIZE
ld r0, PPC_LR_STKOFF(r1) ld r0, PPC_LR_STKOFF(r1)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment