void vmx_vmcs_exit(struct vcpu *v);
void vmx_vmcs_reload(struct vcpu *v);
-#define CPU_BASED_VIRTUAL_INTR_PENDING 0x00000004
-#define CPU_BASED_USE_TSC_OFFSETING 0x00000008
-#define CPU_BASED_HLT_EXITING 0x00000080
-#define CPU_BASED_INVLPG_EXITING 0x00000200
-#define CPU_BASED_MWAIT_EXITING 0x00000400
-#define CPU_BASED_RDPMC_EXITING 0x00000800
-#define CPU_BASED_RDTSC_EXITING 0x00001000
-#define CPU_BASED_CR3_LOAD_EXITING 0x00008000
-#define CPU_BASED_CR3_STORE_EXITING 0x00010000
-#define CPU_BASED_CR8_LOAD_EXITING 0x00080000
-#define CPU_BASED_CR8_STORE_EXITING 0x00100000
-#define CPU_BASED_TPR_SHADOW 0x00200000
-#define CPU_BASED_VIRTUAL_NMI_PENDING 0x00400000
-#define CPU_BASED_MOV_DR_EXITING 0x00800000
-#define CPU_BASED_UNCOND_IO_EXITING 0x01000000
-#define CPU_BASED_ACTIVATE_IO_BITMAP 0x02000000
-#define CPU_BASED_MONITOR_TRAP_FLAG 0x08000000
-#define CPU_BASED_ACTIVATE_MSR_BITMAP 0x10000000
-#define CPU_BASED_MONITOR_EXITING 0x20000000
-#define CPU_BASED_PAUSE_EXITING 0x40000000
-#define CPU_BASED_ACTIVATE_SECONDARY_CONTROLS 0x80000000
+#define CPU_BASED_VIRTUAL_INTR_PENDING 0x00000004U
+#define CPU_BASED_USE_TSC_OFFSETING 0x00000008U
+#define CPU_BASED_HLT_EXITING 0x00000080U
+#define CPU_BASED_INVLPG_EXITING 0x00000200U
+#define CPU_BASED_MWAIT_EXITING 0x00000400U
+#define CPU_BASED_RDPMC_EXITING 0x00000800U
+#define CPU_BASED_RDTSC_EXITING 0x00001000U
+#define CPU_BASED_CR3_LOAD_EXITING 0x00008000U
+#define CPU_BASED_CR3_STORE_EXITING 0x00010000U
+#define CPU_BASED_CR8_LOAD_EXITING 0x00080000U
+#define CPU_BASED_CR8_STORE_EXITING 0x00100000U
+#define CPU_BASED_TPR_SHADOW 0x00200000U
+#define CPU_BASED_VIRTUAL_NMI_PENDING 0x00400000U
+#define CPU_BASED_MOV_DR_EXITING 0x00800000U
+#define CPU_BASED_UNCOND_IO_EXITING 0x01000000U
+#define CPU_BASED_ACTIVATE_IO_BITMAP 0x02000000U
+#define CPU_BASED_MONITOR_TRAP_FLAG 0x08000000U
+#define CPU_BASED_ACTIVATE_MSR_BITMAP 0x10000000U
+#define CPU_BASED_MONITOR_EXITING 0x20000000U
+#define CPU_BASED_PAUSE_EXITING 0x40000000U
+#define CPU_BASED_ACTIVATE_SECONDARY_CONTROLS 0x80000000U
extern u32 vmx_cpu_based_exec_control;
#define PIN_BASED_EXT_INTR_MASK 0x00000001
#define VM_ENTRY_LOAD_BNDCFGS 0x00010000
extern u32 vmx_vmentry_control;
-#define SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES 0x00000001
-#define SECONDARY_EXEC_ENABLE_EPT 0x00000002
-#define SECONDARY_EXEC_DESCRIPTOR_TABLE_EXITING 0x00000004
-#define SECONDARY_EXEC_ENABLE_RDTSCP 0x00000008
-#define SECONDARY_EXEC_VIRTUALIZE_X2APIC_MODE 0x00000010
-#define SECONDARY_EXEC_ENABLE_VPID 0x00000020
-#define SECONDARY_EXEC_WBINVD_EXITING 0x00000040
-#define SECONDARY_EXEC_UNRESTRICTED_GUEST 0x00000080
-#define SECONDARY_EXEC_APIC_REGISTER_VIRT 0x00000100
-#define SECONDARY_EXEC_VIRTUAL_INTR_DELIVERY 0x00000200
-#define SECONDARY_EXEC_PAUSE_LOOP_EXITING 0x00000400
-#define SECONDARY_EXEC_ENABLE_INVPCID 0x00001000
-#define SECONDARY_EXEC_ENABLE_VM_FUNCTIONS 0x00002000
-#define SECONDARY_EXEC_ENABLE_VMCS_SHADOWING 0x00004000
-#define SECONDARY_EXEC_ENABLE_PML 0x00020000
-#define SECONDARY_EXEC_ENABLE_VIRT_EXCEPTIONS 0x00040000
-#define SECONDARY_EXEC_XSAVES 0x00100000
-#define SECONDARY_EXEC_TSC_SCALING 0x02000000
-#define SECONDARY_EXEC_BUS_LOCK_DETECTION 0x40000000
-#define SECONDARY_EXEC_NOTIFY_VM_EXITING 0x80000000
+#define SECONDARY_EXEC_VIRTUALIZE_APIC_ACCESSES 0x00000001U
+#define SECONDARY_EXEC_ENABLE_EPT 0x00000002U
+#define SECONDARY_EXEC_DESCRIPTOR_TABLE_EXITING 0x00000004U
+#define SECONDARY_EXEC_ENABLE_RDTSCP 0x00000008U
+#define SECONDARY_EXEC_VIRTUALIZE_X2APIC_MODE 0x00000010U
+#define SECONDARY_EXEC_ENABLE_VPID 0x00000020U
+#define SECONDARY_EXEC_WBINVD_EXITING 0x00000040U
+#define SECONDARY_EXEC_UNRESTRICTED_GUEST 0x00000080U
+#define SECONDARY_EXEC_APIC_REGISTER_VIRT 0x00000100U
+#define SECONDARY_EXEC_VIRTUAL_INTR_DELIVERY 0x00000200U
+#define SECONDARY_EXEC_PAUSE_LOOP_EXITING 0x00000400U
+#define SECONDARY_EXEC_ENABLE_INVPCID 0x00001000U
+#define SECONDARY_EXEC_ENABLE_VM_FUNCTIONS 0x00002000U
+#define SECONDARY_EXEC_ENABLE_VMCS_SHADOWING 0x00004000U
+#define SECONDARY_EXEC_ENABLE_PML 0x00020000U
+#define SECONDARY_EXEC_ENABLE_VIRT_EXCEPTIONS 0x00040000U
+#define SECONDARY_EXEC_XSAVES 0x00100000U
+#define SECONDARY_EXEC_TSC_SCALING 0x02000000U
+#define SECONDARY_EXEC_BUS_LOCK_DETECTION 0x40000000U
+#define SECONDARY_EXEC_NOTIFY_VM_EXITING 0x80000000U
extern u32 vmx_secondary_exec_control;
#define VMX_EPT_EXEC_ONLY_SUPPORTED 0x00000001
#define cpu_has_vmx_notify_vm_exiting \
(vmx_secondary_exec_control & SECONDARY_EXEC_NOTIFY_VM_EXITING)
-#define VMCS_RID_TYPE_MASK 0x80000000
+#define VMCS_RID_TYPE_MASK 0x80000000U
/* GUEST_INTERRUPTIBILITY_INFO flags. */
#define VMX_INTR_SHADOW_STI 0x00000001
/*
* Exit Reasons
*/
-#define VMX_EXIT_REASONS_FAILED_VMENTRY 0x80000000
+#define VMX_EXIT_REASONS_FAILED_VMENTRY (1u << 31)
#define VMX_EXIT_REASONS_BUS_LOCK (1u << 26)
#define EXIT_REASON_EXCEPTION_NMI 0
* Note INTR_INFO_NMI_UNBLOCKED_BY_IRET is also used with Exit Qualification
* field for EPT violations, PML full and SPP-related event vmexits.
*/
-#define INTR_INFO_VECTOR_MASK 0xff /* 7:0 */
-#define INTR_INFO_INTR_TYPE_MASK 0x700 /* 10:8 */
-#define INTR_INFO_DELIVER_CODE_MASK 0x800 /* 11 */
-#define INTR_INFO_NMI_UNBLOCKED_BY_IRET 0x1000 /* 12 */
-#define INTR_INFO_VALID_MASK 0x80000000 /* 31 */
-#define INTR_INFO_RESVD_BITS_MASK 0x7ffff000
+#define INTR_INFO_VECTOR_MASK 0x000000ffU /* 7:0 */
+#define INTR_INFO_INTR_TYPE_MASK 0x00000700U /* 10:8 */
+#define INTR_INFO_DELIVER_CODE_MASK 0x00000800U /* 11 */
+#define INTR_INFO_NMI_UNBLOCKED_BY_IRET 0x00001000U /* 12 */
+#define INTR_INFO_VALID_MASK 0x80000000U /* 31 */
+#define INTR_INFO_RESVD_BITS_MASK 0x7ffff000U
/*
* Exit Qualifications for NOTIFY VM EXIT
static inline void vmx_pi_hooks_deassign(struct domain *d) {}
#endif
-#define APIC_INVALID_DEST 0xffffffff
+#define APIC_INVALID_DEST 0xffffffffU
/* EPT violation qualifications definitions */
typedef union ept_qual {