]> git.ipfire.org Git - thirdparty/libvirt.git/commitdiff
cpu_map: Add missing vmx features from MSR 0x480
authorTim Wiederhake <twiederh@redhat.com>
Thu, 9 Nov 2023 13:33:38 +0000 (14:33 +0100)
committerTim Wiederhake <twiederh@redhat.com>
Fri, 24 Nov 2023 09:46:40 +0000 (10:46 +0100)
Signed-off-by: Tim Wiederhake <twiederh@redhat.com>
Reviewed-by: Jiri Denemark <jdenemar@redhat.com>
16 files changed:
src/cpu_map/x86_features.xml
tests/cputestdata/x86_64-cpuid-Atom-P5362-enabled.xml
tests/cputestdata/x86_64-cpuid-Atom-P5362-json.xml
tests/cputestdata/x86_64-cpuid-Cooperlake-enabled.xml
tests/cputestdata/x86_64-cpuid-Cooperlake-json.xml
tests/cputestdata/x86_64-cpuid-Core-i7-8550U-enabled.xml
tests/cputestdata/x86_64-cpuid-Core-i7-8550U-json.xml
tests/cputestdata/x86_64-cpuid-Xeon-Platinum-9242-enabled.xml
tests/cputestdata/x86_64-cpuid-Xeon-Platinum-9242-json.xml
tests/cputestdata/x86_64-cpuid-baseline-Cooperlake+Cascadelake.xml
tests/domaincapsdata/qemu_4.2.0-q35.x86_64.xml
tests/domaincapsdata/qemu_4.2.0.x86_64.xml
tests/domaincapsdata/qemu_5.0.0-q35.x86_64.xml
tests/domaincapsdata/qemu_5.0.0.x86_64.xml
tests/qemuxml2argvdata/cpu-host-model-kvm.x86_64-4.2.0.args
tests/qemuxml2argvdata/cpu-host-model-kvm.x86_64-5.0.0.args

index 978b04e6150708bdfecafe58b18c83fe50b0e9c8..407cf65acc7c9867f33be1fca759ee172166c142 100644 (file)
   <feature name='split-lock-detect'>
     <msr index='0xcf' edx='0x00000000' eax='0x00000020'/>
   </feature>
+
+  <feature name='vmx-ins-outs'>
+    <msr index='0x480' edx='0x00400000' eax='0x00000000'/>
+  </feature>
+  <feature name='vmx-true-ctls'>
+    <msr index='0x480' edx='0x00800000' eax='0x00000000'/>
+  </feature>
+  <feature name='vmx-any-errcode'>
+    <msr index='0x480' edx='0x01000000' eax='0x00000000'/>
+  </feature>
 </cpus>
index 2214d448ef22209ba630cf87b697341f1913d259..d294f3bc85ae6a81ec0566be0be1b4b5c0b93666 100644 (file)
@@ -7,4 +7,5 @@
   <cpuid eax_in='0x80000001' ecx_in='0x00' eax='0x00000000' ebx='0x00000000' ecx='0x00000101' edx='0x28100800'/>
   <cpuid eax_in='0x80000008' ecx_in='0x00' eax='0x00000000' ebx='0x01009000' ecx='0x00000000' edx='0x00000000'/>
   <msr index='0x10a' edx='0x00000000' eax='0x0000006b'/>
+  <msr index='0x480' edx='0x00c00000' eax='0x00000000'/>
 </cpudata>
index bbe0919706be6be1faebbbf94304cdfd3c1e2638..717ef008d433b0decb455059fa31dedea4e15742 100644 (file)
@@ -18,6 +18,8 @@
   <feature policy='require' name='skip-l1dfl-vmentry'/>
   <feature policy='require' name='mds-no'/>
   <feature policy='require' name='pschange-mc-no'/>
+  <feature policy='require' name='vmx-ins-outs'/>
+  <feature policy='require' name='vmx-true-ctls'/>
   <feature policy='disable' name='mpx'/>
   <feature policy='disable' name='core-capability'/>
   <feature policy='disable' name='pdpe1gb'/>
index 1d91c3efa81a2d7c36cc81f97eec48c68db83d1d..adfb8828815d552c53e3e5474d150cdb497bb1ab 100644 (file)
@@ -8,4 +8,5 @@
   <cpuid eax_in='0x80000001' ecx_in='0x00' eax='0x00000000' ebx='0x00000000' ecx='0x00000121' edx='0x2c100800'/>
   <cpuid eax_in='0x80000008' ecx_in='0x00' eax='0x00000000' ebx='0x01009000' ecx='0x00000000' edx='0x00000000'/>
   <msr index='0x10a' edx='0x00000000' eax='0x000001eb'/>
+  <msr index='0x480' edx='0x00c00000' eax='0x00000000'/>
 </cpudata>
index c89e0e5350a763df7f020a81965a5a2d69ea0cd8..8dd5ebbc059383bb56e3020c14db94e0f736b0ae 100644 (file)
@@ -13,4 +13,6 @@
   <feature policy='require' name='amd-stibp'/>
   <feature policy='require' name='amd-ssbd'/>
   <feature policy='require' name='tsx-ctrl'/>
+  <feature policy='require' name='vmx-ins-outs'/>
+  <feature policy='require' name='vmx-true-ctls'/>
 </cpu>
index 57f8ebabba8eec5c39f9edc534214d9a6ce95178..9e0de97f636184b27be221bb0d9633eaeab2064e 100644 (file)
@@ -6,4 +6,5 @@
   <cpuid eax_in='0x0000000d' ecx_in='0x01' eax='0x0000000f' ebx='0x00000000' ecx='0x00000000' edx='0x00000000'/>
   <cpuid eax_in='0x80000001' ecx_in='0x00' eax='0x00000000' ebx='0x00000000' ecx='0x00000121' edx='0x2c100800'/>
   <msr index='0x10a' edx='0x00000000' eax='0x00000048'/>
+  <msr index='0x480' edx='0x00c00000' eax='0x00000000'/>
 </cpudata>
index 4774d39c7e8a85ebbd3efde0c13be1f916f514d8..4056f4bcac4fc7689385ba302b7b36d6c3091897 100644 (file)
@@ -15,6 +15,8 @@
   <feature policy='require' name='pdpe1gb'/>
   <feature policy='require' name='skip-l1dfl-vmentry'/>
   <feature policy='require' name='pschange-mc-no'/>
+  <feature policy='require' name='vmx-ins-outs'/>
+  <feature policy='require' name='vmx-true-ctls'/>
   <feature policy='disable' name='hle'/>
   <feature policy='disable' name='rtm'/>
 </cpu>
index cd082feffe57687e6e3730ffe2c22b25840c694d..4b1c06e18f2f0d8a681ebd87cee6487a66169706 100644 (file)
@@ -7,4 +7,5 @@
   <cpuid eax_in='0x80000001' ecx_in='0x00' eax='0x00000000' ebx='0x00000000' ecx='0x00000121' edx='0x2c100800'/>
   <cpuid eax_in='0x80000008' ecx_in='0x00' eax='0x00000000' ebx='0x01001000' ecx='0x00000000' edx='0x00000000'/>
   <msr index='0x10a' edx='0x00000000' eax='0x000000eb'/>
+  <msr index='0x480' edx='0x00c00000' eax='0x00000000'/>
 </cpudata>
index 10c256ee1e518b32b1dc0eed7101da3eabbd0943..1593e373028c25005bc7e790fc8cd5564809f324 100644 (file)
@@ -19,4 +19,6 @@
   <feature policy='require' name='mds-no'/>
   <feature policy='require' name='pschange-mc-no'/>
   <feature policy='require' name='tsx-ctrl'/>
+  <feature policy='require' name='vmx-ins-outs'/>
+  <feature policy='require' name='vmx-true-ctls'/>
 </cpu>
index ecac749b97229e05b668b6d788abaf895c0cf058..63fcf0cf43ee67d239d4b0afd2a926cfed24d8af 100644 (file)
@@ -19,4 +19,6 @@
   <feature policy='require' name='mds-no'/>
   <feature policy='require' name='pschange-mc-no'/>
   <feature policy='require' name='tsx-ctrl'/>
+  <feature policy='require' name='vmx-ins-outs'/>
+  <feature policy='require' name='vmx-true-ctls'/>
 </cpu>
index 3cbd234f9b7d2893d1e34360c96ec68828e324e1..03df6677e18382c911cf9f6ffcce9f74295bffda 100644 (file)
@@ -59,6 +59,8 @@
       <feature policy='require' name='invtsc'/>
       <feature policy='require' name='skip-l1dfl-vmentry'/>
       <feature policy='require' name='pschange-mc-no'/>
+      <feature policy='require' name='vmx-ins-outs'/>
+      <feature policy='require' name='vmx-true-ctls'/>
     </mode>
     <mode name='custom' supported='yes'>
       <model usable='yes' vendor='unknown'>qemu64</model>
index 274c1ea8d8a249c423115a1405dae03109fa8ab7..a4230b2465dbeb12c252e9d4c185009d3b13ff04 100644 (file)
@@ -58,6 +58,8 @@
       <feature policy='require' name='invtsc'/>
       <feature policy='require' name='skip-l1dfl-vmentry'/>
       <feature policy='require' name='pschange-mc-no'/>
+      <feature policy='require' name='vmx-ins-outs'/>
+      <feature policy='require' name='vmx-true-ctls'/>
     </mode>
     <mode name='custom' supported='yes'>
       <model usable='yes' vendor='unknown'>qemu64</model>
index f17a77534421734cf08a0ae60a31d2f1ea4659ec..ce1a0a9cfe3f9141ada6edde9ae67eba101ff6c2 100644 (file)
@@ -59,6 +59,8 @@
       <feature policy='require' name='invtsc'/>
       <feature policy='require' name='skip-l1dfl-vmentry'/>
       <feature policy='require' name='pschange-mc-no'/>
+      <feature policy='require' name='vmx-ins-outs'/>
+      <feature policy='require' name='vmx-true-ctls'/>
     </mode>
     <mode name='custom' supported='yes'>
       <model usable='yes' vendor='unknown'>qemu64</model>
index a2e5dc2be428ec10ab1c3a4eb86e987359263457..0f21fb43c93aa09d098265a4749e1e75ffd64d2a 100644 (file)
@@ -58,6 +58,8 @@
       <feature policy='require' name='invtsc'/>
       <feature policy='require' name='skip-l1dfl-vmentry'/>
       <feature policy='require' name='pschange-mc-no'/>
+      <feature policy='require' name='vmx-ins-outs'/>
+      <feature policy='require' name='vmx-true-ctls'/>
     </mode>
     <mode name='custom' supported='yes'>
       <model usable='yes' vendor='unknown'>qemu64</model>
index 945163795d00e33a4aef31a218287069356e278f..8caaa1872d249919437afc48e5104dca03b911af 100644 (file)
@@ -12,7 +12,7 @@ XDG_CONFIG_HOME=/var/lib/libvirt/qemu/domain--1-QEMUGuest1/.config \
 -object secret,id=masterKey0,format=raw,file=/var/lib/libvirt/qemu/domain--1-QEMUGuest1/master-key.aes \
 -machine pc-q35-4.2,usb=off,dump-guest-core=off \
 -accel kvm \
--cpu Skylake-Client-IBRS,ss=on,vmx=on,hypervisor=on,tsc-adjust=on,clflushopt=on,umip=on,md-clear=on,stibp=on,arch-capabilities=on,ssbd=on,xsaves=on,pdpe1gb=on,skip-l1dfl-vmentry=on,pschange-mc-no=on \
+-cpu Skylake-Client-IBRS,ss=on,vmx=on,hypervisor=on,tsc-adjust=on,clflushopt=on,umip=on,md-clear=on,stibp=on,arch-capabilities=on,ssbd=on,xsaves=on,pdpe1gb=on,skip-l1dfl-vmentry=on,pschange-mc-no=on,vmx-ins-outs=on,vmx-true-ctls=on \
 -m size=219136k \
 -overcommit mem-lock=off \
 -smp 1,sockets=1,cores=1,threads=1 \
index 95c88f1ace051f8b26083e7046f7b5a63c80d459..930336672cb63535990624f373631750bab418bf 100644 (file)
@@ -12,7 +12,7 @@ XDG_CONFIG_HOME=/var/lib/libvirt/qemu/domain--1-QEMUGuest1/.config \
 -object secret,id=masterKey0,format=raw,file=/var/lib/libvirt/qemu/domain--1-QEMUGuest1/master-key.aes \
 -machine pc-q35-5.0,usb=off,dump-guest-core=off \
 -accel kvm \
--cpu Skylake-Client-IBRS,ss=on,vmx=on,hypervisor=on,tsc-adjust=on,clflushopt=on,umip=on,md-clear=on,stibp=on,arch-capabilities=on,ssbd=on,xsaves=on,pdpe1gb=on,skip-l1dfl-vmentry=on,pschange-mc-no=on \
+-cpu Skylake-Client-IBRS,ss=on,vmx=on,hypervisor=on,tsc-adjust=on,clflushopt=on,umip=on,md-clear=on,stibp=on,arch-capabilities=on,ssbd=on,xsaves=on,pdpe1gb=on,skip-l1dfl-vmentry=on,pschange-mc-no=on,vmx-ins-outs=on,vmx-true-ctls=on \
 -m size=219136k \
 -overcommit mem-lock=off \
 -smp 1,sockets=1,cores=1,threads=1 \