diff options
-rw-r--r-- | arch/x86/kvm/vmx.c | 47 |
1 files changed, 30 insertions, 17 deletions
diff --git a/arch/x86/kvm/vmx.c b/arch/x86/kvm/vmx.c index aba41ae2c81f..1caa1fc6d5ec 100644 --- a/arch/x86/kvm/vmx.c +++ b/arch/x86/kvm/vmx.c | |||
@@ -216,61 +216,69 @@ static inline int is_external_interrupt(u32 intr_info) | |||
216 | 216 | ||
217 | static inline int cpu_has_vmx_msr_bitmap(void) | 217 | static inline int cpu_has_vmx_msr_bitmap(void) |
218 | { | 218 | { |
219 | return (vmcs_config.cpu_based_exec_ctrl & CPU_BASED_USE_MSR_BITMAPS); | 219 | return vmcs_config.cpu_based_exec_ctrl & CPU_BASED_USE_MSR_BITMAPS; |
220 | } | 220 | } |
221 | 221 | ||
222 | static inline int cpu_has_vmx_tpr_shadow(void) | 222 | static inline int cpu_has_vmx_tpr_shadow(void) |
223 | { | 223 | { |
224 | return (vmcs_config.cpu_based_exec_ctrl & CPU_BASED_TPR_SHADOW); | 224 | return vmcs_config.cpu_based_exec_ctrl & CPU_BASED_TPR_SHADOW; |
225 | } | 225 | } |
226 | 226 | ||
227 | static inline int vm_need_tpr_shadow(struct kvm *kvm) | 227 | static inline int vm_need_tpr_shadow(struct kvm *kvm) |
228 | { | 228 | { |
229 | return ((cpu_has_vmx_tpr_shadow()) && (irqchip_in_kernel(kvm))); | 229 | return (cpu_has_vmx_tpr_shadow()) && (irqchip_in_kernel(kvm)); |
230 | } | 230 | } |
231 | 231 | ||
232 | static inline int cpu_has_secondary_exec_ctrls(void) | 232 | static inline int cpu_has_secondary_exec_ctrls(void) |
233 | { | 233 | { |
234 | return (vmcs_config.cpu_based_exec_ctrl & | 234 | return vmcs_config.cpu_based_exec_ctrl & |
235 | CPU_BASED_ACTIVATE_SECONDARY_CONTROLS); | 235 | CPU_BASED_ACTIVATE_SECONDARY_CONTROLS; |
236 | } | 236 | } |
237 | 237 | ||
238 | static inline bool cpu_has_vmx_virtualize_apic_accesses(void) | 238 | static inline bool cpu_has_vmx_virtualize_apic_accesses(void) |
239 | { | 239 | { |
240 | return flexpriority_enabled; | 240 | return vmcs_config.cpu_based_2nd_exec_ctrl & |
241 | SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES; | ||
242 | } | ||
243 | |||
244 | static inline bool cpu_has_vmx_flexpriority(void) | ||
245 | { | ||
246 | return cpu_has_vmx_tpr_shadow() && | ||
247 | cpu_has_vmx_virtualize_apic_accesses(); | ||
241 | } | 248 | } |
242 | 249 | ||
243 | static inline int cpu_has_vmx_invept_individual_addr(void) | 250 | static inline int cpu_has_vmx_invept_individual_addr(void) |
244 | { | 251 | { |
245 | return (!!(vmx_capability.ept & VMX_EPT_EXTENT_INDIVIDUAL_BIT)); | 252 | return !!(vmx_capability.ept & VMX_EPT_EXTENT_INDIVIDUAL_BIT); |
246 | } | 253 | } |
247 | 254 | ||
248 | static inline int cpu_has_vmx_invept_context(void) | 255 | static inline int cpu_has_vmx_invept_context(void) |
249 | { | 256 | { |
250 | return (!!(vmx_capability.ept & VMX_EPT_EXTENT_CONTEXT_BIT)); | 257 | return !!(vmx_capability.ept & VMX_EPT_EXTENT_CONTEXT_BIT); |
251 | } | 258 | } |
252 | 259 | ||
253 | static inline int cpu_has_vmx_invept_global(void) | 260 | static inline int cpu_has_vmx_invept_global(void) |
254 | { | 261 | { |
255 | return (!!(vmx_capability.ept & VMX_EPT_EXTENT_GLOBAL_BIT)); | 262 | return !!(vmx_capability.ept & VMX_EPT_EXTENT_GLOBAL_BIT); |
256 | } | 263 | } |
257 | 264 | ||
258 | static inline int cpu_has_vmx_ept(void) | 265 | static inline int cpu_has_vmx_ept(void) |
259 | { | 266 | { |
260 | return (vmcs_config.cpu_based_2nd_exec_ctrl & | 267 | return vmcs_config.cpu_based_2nd_exec_ctrl & |
261 | SECONDARY_EXEC_ENABLE_EPT); | 268 | SECONDARY_EXEC_ENABLE_EPT; |
262 | } | 269 | } |
263 | 270 | ||
264 | static inline int vm_need_virtualize_apic_accesses(struct kvm *kvm) | 271 | static inline int vm_need_virtualize_apic_accesses(struct kvm *kvm) |
265 | { | 272 | { |
266 | return ((cpu_has_vmx_virtualize_apic_accesses()) && | 273 | return flexpriority_enabled && |
267 | (irqchip_in_kernel(kvm))); | 274 | (cpu_has_vmx_virtualize_apic_accesses()) && |
275 | (irqchip_in_kernel(kvm)); | ||
268 | } | 276 | } |
269 | 277 | ||
270 | static inline int cpu_has_vmx_vpid(void) | 278 | static inline int cpu_has_vmx_vpid(void) |
271 | { | 279 | { |
272 | return (vmcs_config.cpu_based_2nd_exec_ctrl & | 280 | return vmcs_config.cpu_based_2nd_exec_ctrl & |
273 | SECONDARY_EXEC_ENABLE_VPID); | 281 | SECONDARY_EXEC_ENABLE_VPID; |
274 | } | 282 | } |
275 | 283 | ||
276 | static inline int cpu_has_virtual_nmis(void) | 284 | static inline int cpu_has_virtual_nmis(void) |
@@ -278,6 +286,11 @@ static inline int cpu_has_virtual_nmis(void) | |||
278 | return vmcs_config.pin_based_exec_ctrl & PIN_BASED_VIRTUAL_NMIS; | 286 | return vmcs_config.pin_based_exec_ctrl & PIN_BASED_VIRTUAL_NMIS; |
279 | } | 287 | } |
280 | 288 | ||
289 | static inline bool report_flexpriority(void) | ||
290 | { | ||
291 | return flexpriority_enabled; | ||
292 | } | ||
293 | |||
281 | static int __find_msr_index(struct vcpu_vmx *vmx, u32 msr) | 294 | static int __find_msr_index(struct vcpu_vmx *vmx, u32 msr) |
282 | { | 295 | { |
283 | int i; | 296 | int i; |
@@ -1201,7 +1214,7 @@ static __init int setup_vmcs_config(struct vmcs_config *vmcs_conf) | |||
1201 | if (!cpu_has_vmx_ept()) | 1214 | if (!cpu_has_vmx_ept()) |
1202 | enable_ept = 0; | 1215 | enable_ept = 0; |
1203 | 1216 | ||
1204 | if (!(vmcs_config.cpu_based_2nd_exec_ctrl & SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES)) | 1217 | if (!cpu_has_vmx_flexpriority()) |
1205 | flexpriority_enabled = 0; | 1218 | flexpriority_enabled = 0; |
1206 | 1219 | ||
1207 | min = 0; | 1220 | min = 0; |
@@ -3655,7 +3668,7 @@ static struct kvm_x86_ops vmx_x86_ops = { | |||
3655 | .check_processor_compatibility = vmx_check_processor_compat, | 3668 | .check_processor_compatibility = vmx_check_processor_compat, |
3656 | .hardware_enable = hardware_enable, | 3669 | .hardware_enable = hardware_enable, |
3657 | .hardware_disable = hardware_disable, | 3670 | .hardware_disable = hardware_disable, |
3658 | .cpu_has_accelerated_tpr = cpu_has_vmx_virtualize_apic_accesses, | 3671 | .cpu_has_accelerated_tpr = report_flexpriority, |
3659 | 3672 | ||
3660 | .vcpu_create = vmx_create_vcpu, | 3673 | .vcpu_create = vmx_create_vcpu, |
3661 | .vcpu_free = vmx_free_vcpu, | 3674 | .vcpu_free = vmx_free_vcpu, |