diff options
| author | 2021-11-02 17:15:31 +0800 | |
|---|---|---|
| committer | 2021-12-08 04:25:16 -0500 | |
| commit | d2f7d49826ae62b8b5c9829292e84861d2bda2b6 (patch) | |
| tree | c6e432705d61364c4b5d68924123978f63e81390 /tools/perf/scripts/python/net_dropmonitor.py | |
| parent | KVM: x86: Add an emulation type to handle completion of user exits (diff) | |
| download | linux-dev-d2f7d49826ae62b8b5c9829292e84861d2bda2b6.tar.xz linux-dev-d2f7d49826ae62b8b5c9829292e84861d2bda2b6.zip | |
KVM: x86: Use different callback if msr access comes from the emulator
If msr access triggers an exit to userspace, the
complete_userspace_io callback would skip instruction by vendor
callback for kvm_skip_emulated_instruction(). However, when msr
access comes from the emulator, e.g. if kvm.force_emulation_prefix
is enabled and the guest uses rdmsr/wrmsr with kvm prefix,
VM_EXIT_INSTRUCTION_LEN in vmcs is invalid and
kvm_emulate_instruction() should be used to skip instruction
instead.
As Sean noted, unlike the previous case, there's no #UD if
unrestricted guest is disabled and the guest accesses an MSR in
Big RM. So the correct way to fix this is to attach a different
callback when the msr access comes from the emulator.
Suggested-by: Sean Christopherson <seanjc@google.com>
Signed-off-by: Hou Wenlong <houwenlong93@linux.alibaba.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
Message-Id: <34208da8f51580a06e45afefac95afea0e3f96e3.1635842679.git.houwenlong93@linux.alibaba.com>
Diffstat (limited to 'tools/perf/scripts/python/net_dropmonitor.py')
0 files changed, 0 insertions, 0 deletions
