| 12345678910111213141516171819202122232425262728293031323334 |
- From 0000000000000000000000000000000000000000 Mon Sep 17 00:00:00 2001
- From: Maxim Levitsky <[email protected]>
- Date: Wed, 3 Aug 2022 18:50:02 +0300
- Subject: [PATCH] KVM: x86: emulator: update the emulation mode after rsm
- This ensures that RIP will be correctly written back,
- because the RSM instruction can switch the CPU mode from
- 32 bit (or less) to 64 bit.
- This fixes a guest crash in case the #SMI is received
- while the guest runs a code from an address > 32 bit.
- Signed-off-by: Maxim Levitsky <[email protected]>
- Signed-off-by: Thomas Lamprecht <[email protected]>
- ---
- arch/x86/kvm/emulate.c | 5 +++++
- 1 file changed, 5 insertions(+)
- diff --git a/arch/x86/kvm/emulate.c b/arch/x86/kvm/emulate.c
- index 4a43261d25a2..4f7f5117ec7a 100644
- --- a/arch/x86/kvm/emulate.c
- +++ b/arch/x86/kvm/emulate.c
- @@ -2654,6 +2654,11 @@ static int em_rsm(struct x86_emulate_ctxt *ctxt)
- if (ret != X86EMUL_CONTINUE)
- goto emulate_shutdown;
-
- +
- + ret = emulator_recalc_and_set_mode(ctxt);
- + if (ret != X86EMUL_CONTINUE)
- + goto emulate_shutdown;
- +
- /*
- * Note, the ctxt->ops callbacks are responsible for handling side
- * effects when writing MSRs and CRs, e.g. MMU context resets, CPUID
|