KVM: x86: Advertise PREFETCHIT0/1 CPUID to user space
authorJiaxi Chen <jiaxi.chen@linux.intel.com>
Fri, 25 Nov 2022 12:58:45 +0000 (20:58 +0800)
committerPaolo Bonzini <pbonzini@redhat.com>
Mon, 28 Nov 2022 18:33:30 +0000 (13:33 -0500)
commit29c46979b25d5ca867e9859bfdd088d028739cdf
tree5058c82c12f5eb7c248b7e656948e539a20abcf2
parent9977f0877de7f8fc51391e2d52bc993efbd58b90
KVM: x86: Advertise PREFETCHIT0/1 CPUID to user space

Latest Intel platform Granite Rapids has introduced a new instruction -
PREFETCHIT0/1, which moves code to memory (cache) closer to the
processor depending on specific hints.

The bit definition:
CPUID.(EAX=7,ECX=1):EDX[bit 14]

PREFETCHIT0/1 is on a KVM-only subleaf. Plus an x86_FEATURE definition
for this feature bit to direct it to the KVM entry.

Advertise PREFETCHIT0/1 to KVM userspace. This is safe because there are
no new VMX controls or additional host enabling required for guests to
use this feature.

Signed-off-by: Jiaxi Chen <jiaxi.chen@linux.intel.com>
Message-Id: <20221125125845.1182922-9-jiaxi.chen@linux.intel.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
arch/x86/kvm/cpuid.c
arch/x86/kvm/reverse_cpuid.h