KVM: VMX: Truncate GPR value for DR and CR reads in !64-bit mode
authorSean Christopherson <seanjc@google.com>
Thu, 22 Apr 2021 02:21:23 +0000 (19:21 -0700)
committerPaolo Bonzini <pbonzini@redhat.com>
Mon, 26 Apr 2021 09:27:12 +0000 (05:27 -0400)
commitd8971344f5739a9cc53f91f1f593ddd82265b93b
tree4244acbe36a39336d3f40ba59bccbcf8dfc28bbb
parent0884335a2e653b8a045083aa1d57ce74269ac81d
KVM: VMX: Truncate GPR value for DR and CR reads in !64-bit mode

Drop bits 63:32 when storing a DR/CR to a GPR when the vCPU is not in
64-bit mode.  Per the SDM:

  The operand size for these instructions is always 32 bits in non-64-bit
  modes, regardless of the operand-size attribute.

CR8 technically isn't affected as CR8 isn't accessible outside of 64-bit
mode, but fix it up for consistency and to allow for future cleanup.

Fixes: 6aa8b732ca01 ("[PATCH] kvm: userspace interface")
Cc: stable@vger.kernel.org
Signed-off-by: Sean Christopherson <seanjc@google.com>
Message-Id: <20210422022128.3464144-5-seanjc@google.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
arch/x86/kvm/vmx/vmx.c