projects
/
wrapfs-3.14.y.git
/ commitdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
| commitdiff |
tree
raw
|
patch
| inline |
side by side
(parent:
7ae6f2d
)
KVM: x86: clflushopt should be treated as a no-op by emulation
author
David Edmondson
<david.edmondson@oracle.com>
Tue, 3 Nov 2020 12:04:00 +0000
(12:04 +0000)
committer
Greg Kroah-Hartman
<gregkh@linuxfoundation.org>
Sun, 22 Nov 2020 09:14:12 +0000
(10:14 +0100)
commit
51b958e5aeb1e18c00332e0b37c5d4e95a3eff84
upstream.
The instruction emulator ignores clflush instructions, yet fails to
support clflushopt. Treat both similarly.
Fixes: 13e457e0eebf ("KVM: x86: Emulator does not decode clflush well")
Signed-off-by: David Edmondson <david.edmondson@oracle.com>
Message-Id: <
20201103120400
.240882-1-david.edmondson@oracle.com>
Reviewed-by: Joao Martins <joao.m.martins@oracle.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
arch/x86/kvm/emulate.c
patch
|
blob
|
history
diff --git
a/arch/x86/kvm/emulate.c
b/arch/x86/kvm/emulate.c
index 484c32b7f79ff85ad1e13642d1c9c150f38e65f9..39265b55929d2c5b96c87c18a9501b470c588ff4 100644
(file)
--- a/
arch/x86/kvm/emulate.c
+++ b/
arch/x86/kvm/emulate.c
@@
-4050,6
+4050,12
@@
static int em_clflush(struct x86_emulate_ctxt *ctxt)
return X86EMUL_CONTINUE;
}
+static int em_clflushopt(struct x86_emulate_ctxt *ctxt)
+{
+ /* emulating clflushopt regardless of cpuid */
+ return X86EMUL_CONTINUE;
+}
+
static int em_movsxd(struct x86_emulate_ctxt *ctxt)
{
ctxt->dst.val = (s32) ctxt->src.val;
@@
-4592,7
+4598,7
@@
static const struct opcode group11[] = {
};
static const struct gprefix pfx_0f_ae_7 = {
- I(SrcMem | ByteOp, em_clflush),
N
, N, N,
+ I(SrcMem | ByteOp, em_clflush),
I(SrcMem | ByteOp, em_clflushopt)
, N, N,
};
static const struct group_dual group15 = { {