mirror of
https://github.com/torvalds/linux.git
synced 2024-11-17 01:22:07 +00:00
KVM: nVMX: Trap unconditionally if msr bitmap access fails
This avoids basing decisions on uninitialized variables, potentially leaking kernel data to the L1 guest. Reviewed-by: Gleb Natapov <gleb@redhat.com> Signed-off-by: Jan Kiszka <jan.kiszka@siemens.com> Signed-off-by: Marcelo Tosatti <mtosatti@redhat.com>
This commit is contained in:
parent
908a7bdd6a
commit
bd31a7f557
@ -5985,7 +5985,8 @@ static bool nested_vmx_exit_handled_msr(struct kvm_vcpu *vcpu,
|
||||
/* Then read the msr_index'th bit from this bitmap: */
|
||||
if (msr_index < 1024*8) {
|
||||
unsigned char b;
|
||||
kvm_read_guest(vcpu->kvm, bitmap + msr_index/8, &b, 1);
|
||||
if (kvm_read_guest(vcpu->kvm, bitmap + msr_index/8, &b, 1))
|
||||
return 1;
|
||||
return 1 & (b >> (msr_index & 7));
|
||||
} else
|
||||
return 1; /* let L1 handle the wrong parameter */
|
||||
|
Loading…
Reference in New Issue
Block a user