cryptospore / rpms / qemu-kvm

Forked from rpms/qemu-kvm 2 years ago
Clone

Blame SOURCES/kvm-target-i386-define-a-new-MSR-based-feature-word-FEAT.patch

4ec855
From 127410386296459cf3eec4b12d7451afc50d2503 Mon Sep 17 00:00:00 2001
4ec855
From: Paolo Bonzini <pbonzini@redhat.com>
4ec855
Date: Fri, 22 Nov 2019 11:53:36 +0000
4ec855
Subject: [PATCH 03/16] target/i386: define a new MSR based feature word -
4ec855
 FEAT_CORE_CAPABILITY
4ec855
4ec855
RH-Author: Paolo Bonzini <pbonzini@redhat.com>
4ec855
Message-id: <20191122115348.25000-4-pbonzini@redhat.com>
4ec855
Patchwork-id: 92603
4ec855
O-Subject: [RHEL8.2/rhel qemu-kvm PATCH 03/15] target/i386: define a new MSR based feature word - FEAT_CORE_CAPABILITY
4ec855
Bugzilla: 1689270
4ec855
RH-Acked-by: Dr. David Alan Gilbert <dgilbert@redhat.com>
4ec855
RH-Acked-by: Eduardo Habkost <ehabkost@redhat.com>
4ec855
RH-Acked-by: Maxim Levitsky <mlevitsk@redhat.com>
4ec855
4ec855
From: Xiaoyao Li <xiaoyao.li@linux.intel.com>
4ec855
4ec855
MSR IA32_CORE_CAPABILITY is a feature-enumerating MSR, which only
4ec855
enumerates the feature split lock detection (via bit 5) by now.
4ec855
4ec855
The existence of MSR IA32_CORE_CAPABILITY is enumerated by CPUID.7_0:EDX[30].
4ec855
4ec855
The latest kernel patches about them can be found here:
4ec855
https://lkml.org/lkml/2019/4/24/1909
4ec855
4ec855
Signed-off-by: Xiaoyao Li <xiaoyao.li@linux.intel.com>
4ec855
Message-Id: <20190617153654.916-1-xiaoyao.li@linux.intel.com>
4ec855
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
4ec855
(cherry picked from commit 597360c0d8ebda9ca6f239db724a25bddec62b2f)
4ec855
4ec855
RHEL: context
4ec855
Signed-off-by: Danilo C. L. de Paula <ddepaula@redhat.com>
4ec855
---
4ec855
 target/i386/cpu.c | 22 +++++++++++++++++++++-
4ec855
 target/i386/cpu.h |  5 +++++
4ec855
 target/i386/kvm.c |  9 +++++++++
4ec855
 3 files changed, 35 insertions(+), 1 deletion(-)
4ec855
4ec855
diff --git a/target/i386/cpu.c b/target/i386/cpu.c
4ec855
index 8c1338f..52f1f33 100644
4ec855
--- a/target/i386/cpu.c
4ec855
+++ b/target/i386/cpu.c
4ec855
@@ -1045,7 +1045,7 @@ static FeatureWordInfo feature_word_info[FEATURE_WORDS] = {
4ec855
             NULL, NULL, NULL, NULL,
4ec855
             NULL, NULL, NULL, NULL,
4ec855
             NULL, NULL, "spec-ctrl", "stibp",
4ec855
-            NULL, "arch-capabilities", NULL, "ssbd",
4ec855
+            NULL, "arch-capabilities", "core-capability", "ssbd",
4ec855
         },
4ec855
         .cpuid = {
4ec855
             .eax = 7,
4ec855
@@ -1163,6 +1163,26 @@ static FeatureWordInfo feature_word_info[FEATURE_WORDS] = {
4ec855
             }
4ec855
         },
4ec855
     },
4ec855
+    [FEAT_CORE_CAPABILITY] = {
4ec855
+        .type = MSR_FEATURE_WORD,
4ec855
+        .feat_names = {
4ec855
+            NULL, NULL, NULL, NULL,
4ec855
+            NULL, "split-lock-detect", NULL, NULL,
4ec855
+            NULL, NULL, NULL, NULL,
4ec855
+            NULL, NULL, NULL, NULL,
4ec855
+            NULL, NULL, NULL, NULL,
4ec855
+            NULL, NULL, NULL, NULL,
4ec855
+            NULL, NULL, NULL, NULL,
4ec855
+            NULL, NULL, NULL, NULL,
4ec855
+        },
4ec855
+        .msr = {
4ec855
+            .index = MSR_IA32_CORE_CAPABILITY,
4ec855
+            .cpuid_dep = {
4ec855
+                FEAT_7_0_EDX,
4ec855
+                CPUID_7_0_EDX_CORE_CAPABILITY,
4ec855
+            },
4ec855
+        },
4ec855
+    },
4ec855
 };
4ec855
 
4ec855
 typedef struct X86RegisterInfo32 {
4ec855
diff --git a/target/i386/cpu.h b/target/i386/cpu.h
4ec855
index 1ad54bd..f9b93be 100644
4ec855
--- a/target/i386/cpu.h
4ec855
+++ b/target/i386/cpu.h
4ec855
@@ -353,6 +353,7 @@ typedef enum X86Seg {
4ec855
 #define MSR_IA32_SPEC_CTRL              0x48
4ec855
 #define MSR_VIRT_SSBD                   0xc001011f
4ec855
 #define MSR_IA32_PRED_CMD               0x49
4ec855
+#define MSR_IA32_CORE_CAPABILITY        0xcf
4ec855
 #define MSR_IA32_ARCH_CAPABILITIES      0x10a
4ec855
 #define MSR_IA32_TSCDEADLINE            0x6e0
4ec855
 
4ec855
@@ -501,6 +502,7 @@ typedef enum FeatureWord {
4ec855
     FEAT_XSAVE_COMP_LO, /* CPUID[EAX=0xd,ECX=0].EAX */
4ec855
     FEAT_XSAVE_COMP_HI, /* CPUID[EAX=0xd,ECX=0].EDX */
4ec855
     FEAT_ARCH_CAPABILITIES,
4ec855
+    FEAT_CORE_CAPABILITY,
4ec855
     FEATURE_WORDS,
4ec855
 } FeatureWord;
4ec855
 
4ec855
@@ -690,6 +692,7 @@ typedef uint32_t FeatureWordArray[FEATURE_WORDS];
4ec855
 #define CPUID_7_0_EDX_AVX512_4FMAPS (1U << 3) /* AVX512 Multiply Accumulation Single Precision */
4ec855
 #define CPUID_7_0_EDX_SPEC_CTRL     (1U << 26) /* Speculation Control */
4ec855
 #define CPUID_7_0_EDX_ARCH_CAPABILITIES (1U << 29)  /*Arch Capabilities*/
4ec855
+#define CPUID_7_0_EDX_CORE_CAPABILITY   (1U << 30)  /*Core Capability*/
4ec855
 #define CPUID_7_0_EDX_SPEC_CTRL_SSBD  (1U << 31) /* Speculative Store Bypass Disable */
4ec855
 
4ec855
 #define KVM_HINTS_DEDICATED (1U << 0)
4ec855
@@ -744,6 +747,8 @@ typedef uint32_t FeatureWordArray[FEATURE_WORDS];
4ec855
 #define MSR_ARCH_CAP_SKIP_L1DFL_VMENTRY (1U << 3)
4ec855
 #define MSR_ARCH_CAP_SSB_NO     (1U << 4)
4ec855
 
4ec855
+#define MSR_CORE_CAP_SPLIT_LOCK_DETECT  (1U << 5)
4ec855
+
4ec855
 #ifndef HYPERV_SPINLOCK_NEVER_RETRY
4ec855
 #define HYPERV_SPINLOCK_NEVER_RETRY             0xFFFFFFFF
4ec855
 #endif
4ec855
diff --git a/target/i386/kvm.c b/target/i386/kvm.c
4ec855
index da5f07e..849a11a 100644
4ec855
--- a/target/i386/kvm.c
4ec855
+++ b/target/i386/kvm.c
4ec855
@@ -95,6 +95,7 @@ static bool has_msr_spec_ctrl;
4ec855
 static bool has_msr_virt_ssbd;
4ec855
 static bool has_msr_smi_count;
4ec855
 static bool has_msr_arch_capabs;
4ec855
+static bool has_msr_core_capabs;
4ec855
 
4ec855
 static uint32_t has_architectural_pmu_version;
4ec855
 static uint32_t num_architectural_pmu_gp_counters;
4ec855
@@ -1428,6 +1429,9 @@ static int kvm_get_supported_msrs(KVMState *s)
4ec855
                 case MSR_IA32_ARCH_CAPABILITIES:
4ec855
                     has_msr_arch_capabs = true;
4ec855
                     break;
4ec855
+                case MSR_IA32_CORE_CAPABILITY:
4ec855
+                    has_msr_core_capabs = true;
4ec855
+                    break;
4ec855
                 }
4ec855
             }
4ec855
         }
4ec855
@@ -1947,6 +1951,11 @@ static int kvm_put_msrs(X86CPU *cpu, int level)
4ec855
                           env->features[FEAT_ARCH_CAPABILITIES]);
4ec855
     }
4ec855
 
4ec855
+    if (has_msr_core_capabs) {
4ec855
+        kvm_msr_entry_add(cpu, MSR_IA32_CORE_CAPABILITY,
4ec855
+                          env->features[FEAT_CORE_CAPABILITY]);
4ec855
+    }
4ec855
+
4ec855
     /*
4ec855
      * The following MSRs have side effects on the guest or are too heavy
4ec855
      * for normal writeback. Limit them to reset or full state updates.
4ec855
-- 
4ec855
1.8.3.1
4ec855