Commit 4a8fd4a7 authored by Sean Christopherson's avatar Sean Christopherson

KVM: nVMX: Reword comments about generating nested CR0/4 read shadows

Reword the comments that (attempt to) document nVMX's overrides of the
CR0/4 read shadows for L2 after calling vmx_set_cr0/4().  The important
behavior that needs to be documented is that KVM needs to override the
shadows to account for L1's masks even though the shadows are set by the
common helpers (and that setting the shadows first would result in the
correct shadows being clobbered).
Signed-off-by: default avatarSean Christopherson <seanjc@google.com>
Reviewed-by: default avatarJim Mattson <jmattson@google.com>
Link: https://lore.kernel.org/r/20220831000721.4066617-1-seanjc@google.com
parent 1f158147
...@@ -2588,12 +2588,9 @@ static int prepare_vmcs02(struct kvm_vcpu *vcpu, struct vmcs12 *vmcs12, ...@@ -2588,12 +2588,9 @@ static int prepare_vmcs02(struct kvm_vcpu *vcpu, struct vmcs12 *vmcs12,
nested_ept_init_mmu_context(vcpu); nested_ept_init_mmu_context(vcpu);
/* /*
* This sets GUEST_CR0 to vmcs12->guest_cr0, possibly modifying those * Override the CR0/CR4 read shadows after setting the effective guest
* bits which we consider mandatory enabled. * CR0/CR4. The common helpers also set the shadows, but they don't
* The CR0_READ_SHADOW is what L2 should have expected to read given * account for vmcs12's cr0/4_guest_host_mask.
* the specifications by L1; It's not enough to take
* vmcs12->cr0_read_shadow because on our cr0_guest_host_mask we
* have more bits than L1 expected.
*/ */
vmx_set_cr0(vcpu, vmcs12->guest_cr0); vmx_set_cr0(vcpu, vmcs12->guest_cr0);
vmcs_writel(CR0_READ_SHADOW, nested_read_cr0(vmcs12)); vmcs_writel(CR0_READ_SHADOW, nested_read_cr0(vmcs12));
......
...@@ -79,9 +79,10 @@ static inline bool nested_ept_ad_enabled(struct kvm_vcpu *vcpu) ...@@ -79,9 +79,10 @@ static inline bool nested_ept_ad_enabled(struct kvm_vcpu *vcpu)
} }
/* /*
* Return the cr0 value that a nested guest would read. This is a combination * Return the cr0/4 value that a nested guest would read. This is a combination
* of the real cr0 used to run the guest (guest_cr0), and the bits shadowed by * of L1's "real" cr0 used to run the guest (guest_cr0), and the bits shadowed
* its hypervisor (cr0_read_shadow). * by the L1 hypervisor (cr0_read_shadow). KVM must emulate CPU behavior as
* the value+mask loaded into vmcs02 may not match the vmcs12 fields.
*/ */
static inline unsigned long nested_read_cr0(struct vmcs12 *fields) static inline unsigned long nested_read_cr0(struct vmcs12 *fields)
{ {
......
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