| /** |
| * This file is part of the mingw-w64 runtime package. |
| * No warranty is given; refer to the file DISCLAIMER within this package. |
| */ |
| |
| #ifndef _WINHVAPIDEFS_H_ |
| #define _WINHVAPIDEFS_H_ |
| |
| typedef enum WHV_CAPABILITY_CODE { |
| WHvCapabilityCodeHypervisorPresent = 0x00000000, |
| WHvCapabilityCodeFeatures = 0x00000001, |
| WHvCapabilityCodeExtendedVmExits = 0x00000002, |
| WHvCapabilityCodeExceptionExitBitmap = 0x00000003, |
| WHvCapabilityCodeProcessorVendor = 0x00001000, |
| WHvCapabilityCodeProcessorFeatures = 0x00001001, |
| WHvCapabilityCodeProcessorClFlushSize = 0x00001002, |
| WHvCapabilityCodeProcessorXsaveFeatures = 0x00001003 |
| } WHV_CAPABILITY_CODE; |
| |
| typedef union WHV_CAPABILITY_FEATURES { |
| __C89_NAMELESS struct { |
| UINT64 PartialUnmap : 1; |
| UINT64 LocalApicEmulation : 1; |
| UINT64 Xsave : 1; |
| UINT64 DirtyPageTracking : 1; |
| UINT64 SpeculationControl : 1; |
| UINT64 Reserved : 59; |
| }; |
| UINT64 AsUINT64; |
| } WHV_CAPABILITY_FEATURES; |
| |
| C_ASSERT(sizeof(WHV_CAPABILITY_FEATURES) == sizeof(UINT64)); |
| |
| typedef union WHV_EXTENDED_VM_EXITS { |
| __C89_NAMELESS struct { |
| UINT64 X64CpuidExit : 1; |
| UINT64 X64MsrExit : 1; |
| UINT64 ExceptionExit : 1; |
| UINT64 Reserved : 61; |
| }; |
| UINT64 AsUINT64; |
| } WHV_EXTENDED_VM_EXITS; |
| |
| C_ASSERT(sizeof(WHV_EXTENDED_VM_EXITS) == sizeof(UINT64)); |
| |
| typedef enum WHV_PROCESSOR_VENDOR { |
| WHvProcessorVendorAmd = 0x0000, |
| WHvProcessorVendorIntel = 0x0001, |
| WHvProcessorVendorHygon = 0x0002 |
| } WHV_PROCESSOR_VENDOR; |
| |
| typedef union WHV_PROCESSOR_FEATURES { |
| __C89_NAMELESS struct { |
| UINT64 Sse3Support : 1; |
| UINT64 LahfSahfSupport : 1; |
| UINT64 Ssse3Support : 1; |
| UINT64 Sse4_1Support : 1; |
| UINT64 Sse4_2Support : 1; |
| UINT64 Sse4aSupport : 1; |
| UINT64 XopSupport : 1; |
| UINT64 PopCntSupport : 1; |
| UINT64 Cmpxchg16bSupport : 1; |
| UINT64 Altmovcr8Support : 1; |
| UINT64 LzcntSupport : 1; |
| UINT64 MisAlignSseSupport : 1; |
| UINT64 MmxExtSupport : 1; |
| UINT64 Amd3DNowSupport : 1; |
| UINT64 ExtendedAmd3DNowSupport : 1; |
| UINT64 Page1GbSupport : 1; |
| UINT64 AesSupport : 1; |
| UINT64 PclmulqdqSupport : 1; |
| UINT64 PcidSupport : 1; |
| UINT64 Fma4Support : 1; |
| UINT64 F16CSupport : 1; |
| UINT64 RdRandSupport : 1; |
| UINT64 RdWrFsGsSupport : 1; |
| UINT64 SmepSupport : 1; |
| UINT64 EnhancedFastStringSupport : 1; |
| UINT64 Bmi1Support : 1; |
| UINT64 Bmi2Support : 1; |
| UINT64 Reserved1 : 2; |
| UINT64 MovbeSupport : 1; |
| UINT64 Npiep1Support : 1; |
| UINT64 DepX87FPUSaveSupport : 1; |
| UINT64 RdSeedSupport : 1; |
| UINT64 AdxSupport : 1; |
| UINT64 IntelPrefetchSupport : 1; |
| UINT64 SmapSupport : 1; |
| UINT64 HleSupport : 1; |
| UINT64 RtmSupport : 1; |
| UINT64 RdtscpSupport : 1; |
| UINT64 ClflushoptSupport : 1; |
| UINT64 ClwbSupport : 1; |
| UINT64 ShaSupport : 1; |
| UINT64 X87PointersSavedSupport : 1; |
| UINT64 InvpcidSupport : 1; |
| UINT64 IbrsSupport : 1; |
| UINT64 StibpSupport : 1; |
| UINT64 IbpbSupport : 1; |
| UINT64 Reserved2 : 1; |
| UINT64 SsbdSupport : 1; |
| UINT64 FastShortRepMovSupport : 1; |
| UINT64 Reserved3 : 1; |
| UINT64 RdclNo : 1; |
| UINT64 IbrsAllSupport : 1; |
| UINT64 Reserved4 : 1; |
| UINT64 SsbNo : 1; |
| UINT64 RsbANo : 1; |
| UINT64 Reserved5 : 8; |
| }; |
| UINT64 AsUINT64; |
| } WHV_PROCESSOR_FEATURES; |
| |
| C_ASSERT(sizeof(WHV_PROCESSOR_FEATURES) == sizeof(UINT64)); |
| |
| typedef union _WHV_PROCESSOR_XSAVE_FEATURES { |
| __C89_NAMELESS struct { |
| UINT64 XsaveSupport : 1; |
| UINT64 XsaveoptSupport : 1; |
| UINT64 AvxSupport : 1; |
| UINT64 Avx2Support : 1; |
| UINT64 FmaSupport : 1; |
| UINT64 MpxSupport : 1; |
| UINT64 Avx512Support : 1; |
| UINT64 Avx512DQSupport : 1; |
| UINT64 Avx512CDSupport : 1; |
| UINT64 Avx512BWSupport : 1; |
| UINT64 Avx512VLSupport : 1; |
| UINT64 XsaveCompSupport : 1; |
| UINT64 XsaveSupervisorSupport : 1; |
| UINT64 Xcr1Support : 1; |
| UINT64 Avx512BitalgSupport : 1; |
| UINT64 Avx512IfmaSupport : 1; |
| UINT64 Avx512VBmiSupport : 1; |
| UINT64 Avx512VBmi2Support : 1; |
| UINT64 Avx512VnniSupport : 1; |
| UINT64 GfniSupport : 1; |
| UINT64 VaesSupport : 1; |
| UINT64 Avx512VPopcntdqSupport : 1; |
| UINT64 VpclmulqdqSupport : 1; |
| UINT64 Reserved : 41; |
| }; |
| UINT64 AsUINT64; |
| } WHV_PROCESSOR_XSAVE_FEATURES, *PWHV_PROCESSOR_XSAVE_FEATURES; |
| |
| C_ASSERT(sizeof(WHV_PROCESSOR_XSAVE_FEATURES) == sizeof(UINT64)); |
| |
| typedef union WHV_CAPABILITY { |
| WINBOOL HypervisorPresent; |
| WHV_CAPABILITY_FEATURES Features; |
| WHV_EXTENDED_VM_EXITS ExtendedVmExits; |
| WHV_PROCESSOR_VENDOR ProcessorVendor; |
| WHV_PROCESSOR_FEATURES ProcessorFeatures; |
| WHV_PROCESSOR_XSAVE_FEATURES ProcessorXsaveFeatures; |
| UINT8 ProcessorClFlushSize; |
| UINT64 ExceptionExitBitmap; |
| } WHV_CAPABILITY; |
| |
| typedef VOID* WHV_PARTITION_HANDLE; |
| |
| typedef enum WHV_PARTITION_PROPERTY_CODE { |
| WHvPartitionPropertyCodeExtendedVmExits = 0x00000001, |
| WHvPartitionPropertyCodeExceptionExitBitmap = 0x00000002, |
| WHvPartitionPropertyCodeSeparateSecurityDomain = 0x00000003, |
| WHvPartitionPropertyCodeProcessorFeatures = 0x00001001, |
| WHvPartitionPropertyCodeProcessorClFlushSize = 0x00001002, |
| WHvPartitionPropertyCodeCpuidExitList = 0x00001003, |
| WHvPartitionPropertyCodeCpuidResultList = 0x00001004, |
| WHvPartitionPropertyCodeLocalApicEmulationMode = 0x00001005, |
| WHvPartitionPropertyCodeProcessorXsaveFeatures = 0x00001006, |
| WHvPartitionPropertyCodeProcessorCount = 0x00001fff |
| } WHV_PARTITION_PROPERTY_CODE; |
| |
| typedef struct WHV_X64_CPUID_RESULT { |
| UINT32 Function; |
| UINT32 Reserved[3]; |
| UINT32 Eax; |
| UINT32 Ebx; |
| UINT32 Ecx; |
| UINT32 Edx; |
| } WHV_X64_CPUID_RESULT; |
| |
| typedef enum WHV_EXCEPTION_TYPE { |
| WHvX64ExceptionTypeDivideErrorFault = 0x0, |
| WHvX64ExceptionTypeDebugTrapOrFault = 0x1, |
| WHvX64ExceptionTypeBreakpointTrap = 0x3, |
| WHvX64ExceptionTypeOverflowTrap = 0x4, |
| WHvX64ExceptionTypeBoundRangeFault = 0x5, |
| WHvX64ExceptionTypeInvalidOpcodeFault = 0x6, |
| WHvX64ExceptionTypeDeviceNotAvailableFault = 0x7, |
| WHvX64ExceptionTypeDoubleFaultAbort = 0x8, |
| WHvX64ExceptionTypeInvalidTaskStateSegmentFault = 0x0A, |
| WHvX64ExceptionTypeSegmentNotPresentFault = 0x0B, |
| WHvX64ExceptionTypeStackFault = 0x0C, |
| WHvX64ExceptionTypeGeneralProtectionFault = 0x0D, |
| WHvX64ExceptionTypePageFault = 0x0E, |
| WHvX64ExceptionTypeFloatingPointErrorFault = 0x10, |
| WHvX64ExceptionTypeAlignmentCheckFault = 0x11, |
| WHvX64ExceptionTypeMachineCheckAbort = 0x12, |
| WHvX64ExceptionTypeSimdFloatingPointFault = 0x13 |
| } WHV_EXCEPTION_TYPE; |
| |
| typedef enum WHV_X64_LOCAL_APIC_EMULATION_MODE { |
| WHvX64LocalApicEmulationModeNone, |
| WHvX64LocalApicEmulationModeXApic |
| } WHV_X64_LOCAL_APIC_EMULATION_MODE; |
| |
| typedef union WHV_PARTITION_PROPERTY { |
| WHV_EXTENDED_VM_EXITS ExtendedVmExits; |
| WHV_PROCESSOR_FEATURES ProcessorFeatures; |
| WHV_PROCESSOR_XSAVE_FEATURES ProcessorXsaveFeatures; |
| UINT8 ProcessorClFlushSize; |
| UINT32 ProcessorCount; |
| UINT32 CpuidExitList[1]; |
| WHV_X64_CPUID_RESULT CpuidResultList[1]; |
| UINT64 ExceptionExitBitmap; |
| WHV_X64_LOCAL_APIC_EMULATION_MODE LocalApicEmulationMode; |
| WINBOOL SeparateSecurityDomain; |
| } WHV_PARTITION_PROPERTY; |
| |
| typedef UINT64 WHV_GUEST_PHYSICAL_ADDRESS; |
| typedef UINT64 WHV_GUEST_VIRTUAL_ADDRESS; |
| |
| typedef enum WHV_MAP_GPA_RANGE_FLAGS { |
| WHvMapGpaRangeFlagNone = 0x00000000, |
| WHvMapGpaRangeFlagRead = 0x00000001, |
| WHvMapGpaRangeFlagWrite = 0x00000002, |
| WHvMapGpaRangeFlagExecute = 0x00000004, |
| WHvMapGpaRangeFlagTrackDirtyPages = 0x00000008 |
| } WHV_MAP_GPA_RANGE_FLAGS; |
| |
| DEFINE_ENUM_FLAG_OPERATORS(WHV_MAP_GPA_RANGE_FLAGS); |
| |
| typedef enum WHV_TRANSLATE_GVA_FLAGS { |
| WHvTranslateGvaFlagNone = 0x00000000, |
| WHvTranslateGvaFlagValidateRead = 0x00000001, |
| WHvTranslateGvaFlagValidateWrite = 0x00000002, |
| WHvTranslateGvaFlagValidateExecute = 0x00000004, |
| WHvTranslateGvaFlagPrivilegeExempt = 0x00000008, |
| WHvTranslateGvaFlagSetPageTableBits = 0x00000010 |
| } WHV_TRANSLATE_GVA_FLAGS; |
| |
| DEFINE_ENUM_FLAG_OPERATORS(WHV_TRANSLATE_GVA_FLAGS); |
| |
| typedef enum WHV_TRANSLATE_GVA_RESULT_CODE { |
| WHvTranslateGvaResultSuccess = 0, |
| WHvTranslateGvaResultPageNotPresent = 1, |
| WHvTranslateGvaResultPrivilegeViolation = 2, |
| WHvTranslateGvaResultInvalidPageTableFlags = 3, |
| WHvTranslateGvaResultGpaUnmapped = 4, |
| WHvTranslateGvaResultGpaNoReadAccess = 5, |
| WHvTranslateGvaResultGpaNoWriteAccess = 6, |
| WHvTranslateGvaResultGpaIllegalOverlayAccess = 7, |
| WHvTranslateGvaResultIntercept = 8 |
| } WHV_TRANSLATE_GVA_RESULT_CODE; |
| |
| typedef struct WHV_TRANSLATE_GVA_RESULT { |
| WHV_TRANSLATE_GVA_RESULT_CODE ResultCode; |
| UINT32 Reserved; |
| } WHV_TRANSLATE_GVA_RESULT; |
| |
| typedef enum WHV_REGISTER_NAME { |
| WHvX64RegisterRax = 0x00000000, |
| WHvX64RegisterRcx = 0x00000001, |
| WHvX64RegisterRdx = 0x00000002, |
| WHvX64RegisterRbx = 0x00000003, |
| WHvX64RegisterRsp = 0x00000004, |
| WHvX64RegisterRbp = 0x00000005, |
| WHvX64RegisterRsi = 0x00000006, |
| WHvX64RegisterRdi = 0x00000007, |
| WHvX64RegisterR8 = 0x00000008, |
| WHvX64RegisterR9 = 0x00000009, |
| WHvX64RegisterR10 = 0x0000000A, |
| WHvX64RegisterR11 = 0x0000000B, |
| WHvX64RegisterR12 = 0x0000000C, |
| WHvX64RegisterR13 = 0x0000000D, |
| WHvX64RegisterR14 = 0x0000000E, |
| WHvX64RegisterR15 = 0x0000000F, |
| WHvX64RegisterRip = 0x00000010, |
| WHvX64RegisterRflags = 0x00000011, |
| WHvX64RegisterEs = 0x00000012, |
| WHvX64RegisterCs = 0x00000013, |
| WHvX64RegisterSs = 0x00000014, |
| WHvX64RegisterDs = 0x00000015, |
| WHvX64RegisterFs = 0x00000016, |
| WHvX64RegisterGs = 0x00000017, |
| WHvX64RegisterLdtr = 0x00000018, |
| WHvX64RegisterTr = 0x00000019, |
| WHvX64RegisterIdtr = 0x0000001A, |
| WHvX64RegisterGdtr = 0x0000001B, |
| WHvX64RegisterCr0 = 0x0000001C, |
| WHvX64RegisterCr2 = 0x0000001D, |
| WHvX64RegisterCr3 = 0x0000001E, |
| WHvX64RegisterCr4 = 0x0000001F, |
| WHvX64RegisterCr8 = 0x00000020, |
| WHvX64RegisterDr0 = 0x00000021, |
| WHvX64RegisterDr1 = 0x00000022, |
| WHvX64RegisterDr2 = 0x00000023, |
| WHvX64RegisterDr3 = 0x00000024, |
| WHvX64RegisterDr6 = 0x00000025, |
| WHvX64RegisterDr7 = 0x00000026, |
| WHvX64RegisterXCr0 = 0x00000027, |
| WHvX64RegisterXmm0 = 0x00001000, |
| WHvX64RegisterXmm1 = 0x00001001, |
| WHvX64RegisterXmm2 = 0x00001002, |
| WHvX64RegisterXmm3 = 0x00001003, |
| WHvX64RegisterXmm4 = 0x00001004, |
| WHvX64RegisterXmm5 = 0x00001005, |
| WHvX64RegisterXmm6 = 0x00001006, |
| WHvX64RegisterXmm7 = 0x00001007, |
| WHvX64RegisterXmm8 = 0x00001008, |
| WHvX64RegisterXmm9 = 0x00001009, |
| WHvX64RegisterXmm10 = 0x0000100A, |
| WHvX64RegisterXmm11 = 0x0000100B, |
| WHvX64RegisterXmm12 = 0x0000100C, |
| WHvX64RegisterXmm13 = 0x0000100D, |
| WHvX64RegisterXmm14 = 0x0000100E, |
| WHvX64RegisterXmm15 = 0x0000100F, |
| WHvX64RegisterFpMmx0 = 0x00001010, |
| WHvX64RegisterFpMmx1 = 0x00001011, |
| WHvX64RegisterFpMmx2 = 0x00001012, |
| WHvX64RegisterFpMmx3 = 0x00001013, |
| WHvX64RegisterFpMmx4 = 0x00001014, |
| WHvX64RegisterFpMmx5 = 0x00001015, |
| WHvX64RegisterFpMmx6 = 0x00001016, |
| WHvX64RegisterFpMmx7 = 0x00001017, |
| WHvX64RegisterFpControlStatus = 0x00001018, |
| WHvX64RegisterXmmControlStatus = 0x00001019, |
| WHvX64RegisterTsc = 0x00002000, |
| WHvX64RegisterEfer = 0x00002001, |
| WHvX64RegisterKernelGsBase = 0x00002002, |
| WHvX64RegisterApicBase = 0x00002003, |
| WHvX64RegisterPat = 0x00002004, |
| WHvX64RegisterSysenterCs = 0x00002005, |
| WHvX64RegisterSysenterEip = 0x00002006, |
| WHvX64RegisterSysenterEsp = 0x00002007, |
| WHvX64RegisterStar = 0x00002008, |
| WHvX64RegisterLstar = 0x00002009, |
| WHvX64RegisterCstar = 0x0000200A, |
| WHvX64RegisterSfmask = 0x0000200B, |
| WHvX64RegisterMsrMtrrCap = 0x0000200D, |
| WHvX64RegisterMsrMtrrDefType = 0x0000200E, |
| WHvX64RegisterMsrMtrrPhysBase0 = 0x00002010, |
| WHvX64RegisterMsrMtrrPhysBase1 = 0x00002011, |
| WHvX64RegisterMsrMtrrPhysBase2 = 0x00002012, |
| WHvX64RegisterMsrMtrrPhysBase3 = 0x00002013, |
| WHvX64RegisterMsrMtrrPhysBase4 = 0x00002014, |
| WHvX64RegisterMsrMtrrPhysBase5 = 0x00002015, |
| WHvX64RegisterMsrMtrrPhysBase6 = 0x00002016, |
| WHvX64RegisterMsrMtrrPhysBase7 = 0x00002017, |
| WHvX64RegisterMsrMtrrPhysBase8 = 0x00002018, |
| WHvX64RegisterMsrMtrrPhysBase9 = 0x00002019, |
| WHvX64RegisterMsrMtrrPhysBaseA = 0x0000201A, |
| WHvX64RegisterMsrMtrrPhysBaseB = 0x0000201B, |
| WHvX64RegisterMsrMtrrPhysBaseC = 0x0000201C, |
| WHvX64RegisterMsrMtrrPhysBaseD = 0x0000201D, |
| WHvX64RegisterMsrMtrrPhysBaseE = 0x0000201E, |
| WHvX64RegisterMsrMtrrPhysBaseF = 0x0000201F, |
| WHvX64RegisterMsrMtrrPhysMask0 = 0x00002040, |
| WHvX64RegisterMsrMtrrPhysMask1 = 0x00002041, |
| WHvX64RegisterMsrMtrrPhysMask2 = 0x00002042, |
| WHvX64RegisterMsrMtrrPhysMask3 = 0x00002043, |
| WHvX64RegisterMsrMtrrPhysMask4 = 0x00002044, |
| WHvX64RegisterMsrMtrrPhysMask5 = 0x00002045, |
| WHvX64RegisterMsrMtrrPhysMask6 = 0x00002046, |
| WHvX64RegisterMsrMtrrPhysMask7 = 0x00002047, |
| WHvX64RegisterMsrMtrrPhysMask8 = 0x00002048, |
| WHvX64RegisterMsrMtrrPhysMask9 = 0x00002049, |
| WHvX64RegisterMsrMtrrPhysMaskA = 0x0000204A, |
| WHvX64RegisterMsrMtrrPhysMaskB = 0x0000204B, |
| WHvX64RegisterMsrMtrrPhysMaskC = 0x0000204C, |
| WHvX64RegisterMsrMtrrPhysMaskD = 0x0000204D, |
| WHvX64RegisterMsrMtrrPhysMaskE = 0x0000204E, |
| WHvX64RegisterMsrMtrrPhysMaskF = 0x0000204F, |
| WHvX64RegisterMsrMtrrFix64k00000 = 0x00002070, |
| WHvX64RegisterMsrMtrrFix16k80000 = 0x00002071, |
| WHvX64RegisterMsrMtrrFix16kA0000 = 0x00002072, |
| WHvX64RegisterMsrMtrrFix4kC0000 = 0x00002073, |
| WHvX64RegisterMsrMtrrFix4kC8000 = 0x00002074, |
| WHvX64RegisterMsrMtrrFix4kD0000 = 0x00002075, |
| WHvX64RegisterMsrMtrrFix4kD8000 = 0x00002076, |
| WHvX64RegisterMsrMtrrFix4kE0000 = 0x00002077, |
| WHvX64RegisterMsrMtrrFix4kE8000 = 0x00002078, |
| WHvX64RegisterMsrMtrrFix4kF0000 = 0x00002079, |
| WHvX64RegisterMsrMtrrFix4kF8000 = 0x0000207A, |
| WHvX64RegisterTscAux = 0x0000207B, |
| WHvX64RegisterSpecCtrl = 0x00002084, |
| WHvX64RegisterPredCmd = 0x00002085, |
| WHvX64RegisterApicId = 0x00003002, |
| WHvX64RegisterApicVersion = 0x00003003, |
| WHvRegisterPendingInterruption = 0x80000000, |
| WHvRegisterInterruptState = 0x80000001, |
| WHvRegisterPendingEvent = 0x80000002, |
| WHvX64RegisterDeliverabilityNotifications = 0x80000004, |
| WHvRegisterInternalActivityState = 0x80000005 |
| } WHV_REGISTER_NAME; |
| |
| typedef union DECLSPEC_ALIGN(16) WHV_UINT128 { |
| __C89_NAMELESS struct { |
| UINT64 Low64; |
| UINT64 High64; |
| }; |
| UINT32 Dword[4]; |
| } WHV_UINT128; |
| |
| typedef union WHV_X64_FP_REGISTER { |
| __C89_NAMELESS struct { |
| UINT64 Mantissa; |
| UINT64 BiasedExponent:15; |
| UINT64 Sign:1; |
| UINT64 Reserved:48; |
| }; |
| WHV_UINT128 AsUINT128; |
| } WHV_X64_FP_REGISTER; |
| |
| typedef union WHV_X64_FP_CONTROL_STATUS_REGISTER { |
| __C89_NAMELESS struct { |
| UINT16 FpControl; |
| UINT16 FpStatus; |
| UINT8 FpTag; |
| UINT8 Reserved; |
| UINT16 LastFpOp; |
| __C89_NAMELESS union { |
| UINT64 LastFpRip; |
| __C89_NAMELESS struct { |
| UINT32 LastFpEip; |
| UINT16 LastFpCs; |
| UINT16 Reserved2; |
| }; |
| }; |
| }; |
| WHV_UINT128 AsUINT128; |
| } WHV_X64_FP_CONTROL_STATUS_REGISTER; |
| |
| typedef union WHV_X64_XMM_CONTROL_STATUS_REGISTER { |
| __C89_NAMELESS struct { |
| __C89_NAMELESS union { |
| UINT64 LastFpRdp; |
| __C89_NAMELESS struct { |
| UINT32 LastFpDp; |
| UINT16 LastFpDs; |
| UINT16 Reserved; |
| }; |
| }; |
| UINT32 XmmStatusControl; |
| UINT32 XmmStatusControlMask; |
| }; |
| WHV_UINT128 AsUINT128; |
| } WHV_X64_XMM_CONTROL_STATUS_REGISTER; |
| |
| typedef struct WHV_X64_SEGMENT_REGISTER { |
| UINT64 Base; |
| UINT32 Limit; |
| UINT16 Selector; |
| __C89_NAMELESS union { |
| __C89_NAMELESS struct { |
| UINT16 SegmentType:4; |
| UINT16 NonSystemSegment:1; |
| UINT16 DescriptorPrivilegeLevel:2; |
| UINT16 Present:1; |
| UINT16 Reserved:4; |
| UINT16 Available:1; |
| UINT16 Long:1; |
| UINT16 Default:1; |
| UINT16 Granularity:1; |
| }; |
| UINT16 Attributes; |
| }; |
| } WHV_X64_SEGMENT_REGISTER; |
| |
| typedef struct WHV_X64_TABLE_REGISTER { |
| UINT16 Pad[3]; |
| UINT16 Limit; |
| UINT64 Base; |
| } WHV_X64_TABLE_REGISTER; |
| |
| typedef union WHV_X64_INTERRUPT_STATE_REGISTER { |
| __C89_NAMELESS struct { |
| UINT64 InterruptShadow:1; |
| UINT64 NmiMasked:1; |
| UINT64 Reserved:62; |
| }; |
| UINT64 AsUINT64; |
| } WHV_X64_INTERRUPT_STATE_REGISTER; |
| |
| typedef union WHV_X64_PENDING_INTERRUPTION_REGISTER { |
| __C89_NAMELESS struct { |
| UINT32 InterruptionPending:1; |
| UINT32 InterruptionType:3; |
| UINT32 DeliverErrorCode:1; |
| UINT32 InstructionLength:4; |
| UINT32 NestedEvent:1; |
| UINT32 Reserved:6; |
| UINT32 InterruptionVector:16; |
| UINT32 ErrorCode; |
| }; |
| UINT64 AsUINT64; |
| } WHV_X64_PENDING_INTERRUPTION_REGISTER; |
| |
| C_ASSERT(sizeof(WHV_X64_PENDING_INTERRUPTION_REGISTER) == sizeof(UINT64)); |
| |
| typedef union WHV_X64_DELIVERABILITY_NOTIFICATIONS_REGISTER { |
| __C89_NAMELESS struct { |
| UINT64 NmiNotification:1; |
| UINT64 InterruptNotification:1; |
| UINT64 InterruptPriority:4; |
| UINT64 Reserved:58; |
| }; |
| UINT64 AsUINT64; |
| } WHV_X64_DELIVERABILITY_NOTIFICATIONS_REGISTER; |
| |
| C_ASSERT(sizeof(WHV_X64_DELIVERABILITY_NOTIFICATIONS_REGISTER) == sizeof(UINT64)); |
| |
| |
| typedef enum WHV_X64_PENDING_EVENT_TYPE { |
| WHvX64PendingEventException = 0, |
| WHvX64PendingEventExtInt = 5 |
| } WHV_X64_PENDING_EVENT_TYPE; |
| |
| typedef union WHV_X64_PENDING_EXCEPTION_EVENT { |
| __C89_NAMELESS struct { |
| UINT32 EventPending : 1; |
| UINT32 EventType : 3; |
| UINT32 Reserved0 : 4; |
| UINT32 DeliverErrorCode : 1; |
| UINT32 Reserved1 : 7; |
| UINT32 Vector : 16; |
| UINT32 ErrorCode; |
| UINT64 ExceptionParameter; |
| }; |
| WHV_UINT128 AsUINT128; |
| } WHV_X64_PENDING_EXCEPTION_EVENT; |
| |
| C_ASSERT(sizeof(WHV_X64_PENDING_EXCEPTION_EVENT) == sizeof(WHV_UINT128)); |
| |
| typedef union WHV_X64_PENDING_EXT_INT_EVENT { |
| __C89_NAMELESS struct { |
| UINT64 EventPending : 1; |
| UINT64 EventType : 3; |
| UINT64 Reserved0 : 4; |
| UINT64 Vector : 8; |
| UINT64 Reserved1 : 48; |
| UINT64 Reserved2; |
| }; |
| WHV_UINT128 AsUINT128; |
| } WHV_X64_PENDING_EXT_INT_EVENT; |
| |
| C_ASSERT(sizeof(WHV_X64_PENDING_EXT_INT_EVENT) == sizeof(WHV_UINT128)); |
| |
| typedef union WHV_REGISTER_VALUE { |
| WHV_UINT128 Reg128; |
| UINT64 Reg64; |
| UINT32 Reg32; |
| UINT16 Reg16; |
| UINT8 Reg8; |
| WHV_X64_FP_REGISTER Fp; |
| WHV_X64_FP_CONTROL_STATUS_REGISTER FpControlStatus; |
| WHV_X64_XMM_CONTROL_STATUS_REGISTER XmmControlStatus; |
| WHV_X64_SEGMENT_REGISTER Segment; |
| WHV_X64_TABLE_REGISTER Table; |
| WHV_X64_INTERRUPT_STATE_REGISTER InterruptState; |
| WHV_X64_PENDING_INTERRUPTION_REGISTER PendingInterruption; |
| WHV_X64_DELIVERABILITY_NOTIFICATIONS_REGISTER DeliverabilityNotifications; |
| WHV_X64_PENDING_EXCEPTION_EVENT ExceptionEvent; |
| WHV_X64_PENDING_EXT_INT_EVENT ExtIntEvent; |
| } WHV_REGISTER_VALUE; |
| |
| typedef enum WHV_RUN_VP_EXIT_REASON { |
| WHvRunVpExitReasonNone = 0x00000000, |
| WHvRunVpExitReasonMemoryAccess = 0x00000001, |
| WHvRunVpExitReasonX64IoPortAccess = 0x00000002, |
| WHvRunVpExitReasonUnrecoverableException = 0x00000004, |
| WHvRunVpExitReasonInvalidVpRegisterValue = 0x00000005, |
| WHvRunVpExitReasonUnsupportedFeature = 0x00000006, |
| WHvRunVpExitReasonX64InterruptWindow = 0x00000007, |
| WHvRunVpExitReasonX64Halt = 0x00000008, |
| WHvRunVpExitReasonX64ApicEoi = 0x00000009, |
| WHvRunVpExitReasonX64MsrAccess = 0x00001000, |
| WHvRunVpExitReasonX64Cpuid = 0x00001001, |
| WHvRunVpExitReasonException = 0x00001002, |
| WHvRunVpExitReasonCanceled = 0x00002001 |
| } WHV_RUN_VP_EXIT_REASON; |
| |
| typedef union WHV_X64_VP_EXECUTION_STATE { |
| __C89_NAMELESS struct { |
| UINT16 Cpl : 2; |
| UINT16 Cr0Pe : 1; |
| UINT16 Cr0Am : 1; |
| UINT16 EferLma : 1; |
| UINT16 DebugActive : 1; |
| UINT16 InterruptionPending : 1; |
| UINT16 Reserved0 : 5; |
| UINT16 InterruptShadow : 1; |
| UINT16 Reserved1 : 3; |
| }; |
| UINT16 AsUINT16; |
| } WHV_X64_VP_EXECUTION_STATE; |
| |
| C_ASSERT(sizeof(WHV_X64_VP_EXECUTION_STATE) == sizeof(UINT16)); |
| |
| typedef struct WHV_VP_EXIT_CONTEXT { |
| WHV_X64_VP_EXECUTION_STATE ExecutionState; |
| UINT8 InstructionLength : 4; |
| UINT8 Cr8 : 4; |
| UINT8 Reserved; |
| UINT32 Reserved2; |
| WHV_X64_SEGMENT_REGISTER Cs; |
| UINT64 Rip; |
| UINT64 Rflags; |
| } WHV_VP_EXIT_CONTEXT; |
| |
| typedef enum WHV_MEMORY_ACCESS_TYPE { |
| WHvMemoryAccessRead = 0, |
| WHvMemoryAccessWrite = 1, |
| WHvMemoryAccessExecute = 2 |
| } WHV_MEMORY_ACCESS_TYPE; |
| |
| typedef union WHV_MEMORY_ACCESS_INFO { |
| __C89_NAMELESS struct { |
| UINT32 AccessType : 2; |
| UINT32 GpaUnmapped : 1; |
| UINT32 GvaValid : 1; |
| UINT32 Reserved : 28; |
| }; |
| UINT32 AsUINT32; |
| } WHV_MEMORY_ACCESS_INFO; |
| |
| typedef struct WHV_MEMORY_ACCESS_CONTEXT { |
| UINT8 InstructionByteCount; |
| UINT8 Reserved[3]; |
| UINT8 InstructionBytes[16]; |
| WHV_MEMORY_ACCESS_INFO AccessInfo; |
| WHV_GUEST_PHYSICAL_ADDRESS Gpa; |
| WHV_GUEST_VIRTUAL_ADDRESS Gva; |
| } WHV_MEMORY_ACCESS_CONTEXT; |
| |
| typedef union WHV_X64_IO_PORT_ACCESS_INFO { |
| __C89_NAMELESS struct { |
| UINT32 IsWrite : 1; |
| UINT32 AccessSize: 3; |
| UINT32 StringOp : 1; |
| UINT32 RepPrefix : 1; |
| UINT32 Reserved : 26; |
| }; |
| UINT32 AsUINT32; |
| } WHV_X64_IO_PORT_ACCESS_INFO; |
| |
| C_ASSERT(sizeof(WHV_X64_IO_PORT_ACCESS_INFO) == sizeof(UINT32)); |
| |
| typedef struct WHV_X64_IO_PORT_ACCESS_CONTEXT { |
| UINT8 InstructionByteCount; |
| UINT8 Reserved[3]; |
| UINT8 InstructionBytes[16]; |
| WHV_X64_IO_PORT_ACCESS_INFO AccessInfo; |
| UINT16 PortNumber; |
| UINT16 Reserved2[3]; |
| UINT64 Rax; |
| UINT64 Rcx; |
| UINT64 Rsi; |
| UINT64 Rdi; |
| WHV_X64_SEGMENT_REGISTER Ds; |
| WHV_X64_SEGMENT_REGISTER Es; |
| } WHV_X64_IO_PORT_ACCESS_CONTEXT; |
| |
| typedef union WHV_X64_MSR_ACCESS_INFO { |
| __C89_NAMELESS struct { |
| UINT32 IsWrite : 1; |
| UINT32 Reserved : 31; |
| }; |
| UINT32 AsUINT32; |
| } WHV_X64_MSR_ACCESS_INFO; |
| |
| C_ASSERT(sizeof(WHV_X64_MSR_ACCESS_INFO) == sizeof(UINT32)); |
| |
| typedef struct WHV_X64_MSR_ACCESS_CONTEXT { |
| WHV_X64_MSR_ACCESS_INFO AccessInfo; |
| UINT32 MsrNumber; |
| UINT64 Rax; |
| UINT64 Rdx; |
| } WHV_X64_MSR_ACCESS_CONTEXT; |
| |
| typedef struct WHV_X64_CPUID_ACCESS_CONTEXT { |
| UINT64 Rax; |
| UINT64 Rcx; |
| UINT64 Rdx; |
| UINT64 Rbx; |
| UINT64 DefaultResultRax; |
| UINT64 DefaultResultRcx; |
| UINT64 DefaultResultRdx; |
| UINT64 DefaultResultRbx; |
| } WHV_X64_CPUID_ACCESS_CONTEXT; |
| |
| typedef union WHV_VP_EXCEPTION_INFO { |
| __C89_NAMELESS struct { |
| UINT32 ErrorCodeValid : 1; |
| UINT32 SoftwareException : 1; |
| UINT32 Reserved : 30; |
| }; |
| UINT32 AsUINT32; |
| } WHV_VP_EXCEPTION_INFO; |
| |
| C_ASSERT(sizeof(WHV_VP_EXCEPTION_INFO) == sizeof(UINT32)); |
| |
| typedef struct WHV_VP_EXCEPTION_CONTEXT { |
| UINT8 InstructionByteCount; |
| UINT8 Reserved[3]; |
| UINT8 InstructionBytes[16]; |
| WHV_VP_EXCEPTION_INFO ExceptionInfo; |
| UINT8 ExceptionType; |
| UINT8 Reserved2[3]; |
| UINT32 ErrorCode; |
| UINT64 ExceptionParameter; |
| } WHV_VP_EXCEPTION_CONTEXT; |
| |
| typedef enum WHV_X64_UNSUPPORTED_FEATURE_CODE { |
| WHvUnsupportedFeatureIntercept = 1, |
| WHvUnsupportedFeatureTaskSwitchTss = 2 |
| } WHV_X64_UNSUPPORTED_FEATURE_CODE; |
| |
| typedef struct WHV_X64_UNSUPPORTED_FEATURE_CONTEXT { |
| WHV_X64_UNSUPPORTED_FEATURE_CODE FeatureCode; |
| UINT32 Reserved; |
| UINT64 FeatureParameter; |
| } WHV_X64_UNSUPPORTED_FEATURE_CONTEXT; |
| |
| typedef enum WHV_RUN_VP_CANCEL_REASON { |
| WhvRunVpCancelReasonUser = 0 |
| } WHV_RUN_VP_CANCEL_REASON; |
| |
| typedef struct WHV_RUN_VP_CANCELED_CONTEXT { |
| WHV_RUN_VP_CANCEL_REASON CancelReason; |
| } WHV_RUN_VP_CANCELED_CONTEXT; |
| |
| typedef enum WHV_X64_PENDING_INTERRUPTION_TYPE { |
| WHvX64PendingInterrupt = 0, |
| WHvX64PendingNmi = 2, |
| WHvX64PendingException = 3 |
| } WHV_X64_PENDING_INTERRUPTION_TYPE, *PWHV_X64_PENDING_INTERRUPTION_TYPE; |
| |
| typedef struct WHV_X64_INTERRUPTION_DELIVERABLE_CONTEXT { |
| WHV_X64_PENDING_INTERRUPTION_TYPE DeliverableType; |
| } WHV_X64_INTERRUPTION_DELIVERABLE_CONTEXT, *PWHV_X64_INTERRUPTION_DELIVERABLE_CONTEXT; |
| |
| typedef struct WHV_X64_APIC_EOI_CONTEXT { |
| UINT32 InterruptVector; |
| } WHV_X64_APIC_EOI_CONTEXT; |
| |
| typedef struct WHV_RUN_VP_EXIT_CONTEXT { |
| WHV_RUN_VP_EXIT_REASON ExitReason; |
| UINT32 Reserved; |
| WHV_VP_EXIT_CONTEXT VpContext; |
| __C89_NAMELESS union { |
| WHV_MEMORY_ACCESS_CONTEXT MemoryAccess; |
| WHV_X64_IO_PORT_ACCESS_CONTEXT IoPortAccess; |
| WHV_X64_MSR_ACCESS_CONTEXT MsrAccess; |
| WHV_X64_CPUID_ACCESS_CONTEXT CpuidAccess; |
| WHV_VP_EXCEPTION_CONTEXT VpException; |
| WHV_X64_INTERRUPTION_DELIVERABLE_CONTEXT InterruptWindow; |
| WHV_X64_UNSUPPORTED_FEATURE_CONTEXT UnsupportedFeature; |
| WHV_RUN_VP_CANCELED_CONTEXT CancelReason; |
| WHV_X64_APIC_EOI_CONTEXT ApicEoi; |
| }; |
| } WHV_RUN_VP_EXIT_CONTEXT; |
| |
| typedef enum WHV_INTERRUPT_TYPE { |
| WHvX64InterruptTypeFixed = 0, |
| WHvX64InterruptTypeLowestPriority = 1, |
| WHvX64InterruptTypeNmi = 4, |
| WHvX64InterruptTypeInit = 5, |
| WHvX64InterruptTypeSipi = 6, |
| WHvX64InterruptTypeLocalInt1 = 9 |
| } WHV_INTERRUPT_TYPE; |
| |
| typedef enum WHV_INTERRUPT_DESTINATION_MODE { |
| WHvX64InterruptDestinationModePhysical, |
| WHvX64InterruptDestinationModeLogical |
| } WHV_INTERRUPT_DESTINATION_MODE; |
| |
| typedef enum WHV_INTERRUPT_TRIGGER_MODE { |
| WHvX64InterruptTriggerModeEdge, |
| WHvX64InterruptTriggerModeLevel |
| } WHV_INTERRUPT_TRIGGER_MODE; |
| |
| typedef struct WHV_INTERRUPT_CONTROL { |
| UINT64 Type : 8; |
| UINT64 DestinationMode : 4; |
| UINT64 TriggerMode : 4; |
| UINT64 Reserved : 48; |
| UINT32 Destination; |
| UINT32 Vector; |
| } WHV_INTERRUPT_CONTROL; |
| |
| typedef enum WHV_PARTITION_COUNTER_SET { |
| WHvPartitionCounterSetMemory |
| } WHV_PARTITION_COUNTER_SET; |
| |
| typedef struct WHV_PARTITION_MEMORY_COUNTERS { |
| UINT64 Mapped4KPageCount; |
| UINT64 Mapped2MPageCount; |
| UINT64 Mapped1GPageCount; |
| } WHV_PARTITION_MEMORY_COUNTERS; |
| |
| typedef enum WHV_PROCESSOR_COUNTER_SET { |
| WHvProcessorCounterSetRuntime, |
| WHvProcessorCounterSetIntercepts, |
| WHvProcessorCounterSetEvents, |
| WHvProcessorCounterSetApic |
| } WHV_PROCESSOR_COUNTER_SET; |
| |
| typedef struct WHV_PROCESSOR_RUNTIME_COUNTERS { |
| UINT64 TotalRuntime100ns; |
| UINT64 HypervisorRuntime100ns; |
| } WHV_PROCESSOR_RUNTIME_COUNTERS; |
| |
| typedef struct WHV_PROCESSOR_INTERCEPT_COUNTER { |
| UINT64 Count; |
| UINT64 Time100ns; |
| } WHV_PROCESSOR_INTERCEPT_COUNTER; |
| |
| typedef struct WHV_PROCESSOR_INTERCEPT_COUNTERS { |
| WHV_PROCESSOR_INTERCEPT_COUNTER PageInvalidations; |
| WHV_PROCESSOR_INTERCEPT_COUNTER ControlRegisterAccesses; |
| WHV_PROCESSOR_INTERCEPT_COUNTER IoInstructions; |
| WHV_PROCESSOR_INTERCEPT_COUNTER HaltInstructions; |
| WHV_PROCESSOR_INTERCEPT_COUNTER CpuidInstructions; |
| WHV_PROCESSOR_INTERCEPT_COUNTER MsrAccesses; |
| WHV_PROCESSOR_INTERCEPT_COUNTER OtherIntercepts; |
| WHV_PROCESSOR_INTERCEPT_COUNTER PendingInterrupts; |
| WHV_PROCESSOR_INTERCEPT_COUNTER EmulatedInstructions; |
| WHV_PROCESSOR_INTERCEPT_COUNTER DebugRegisterAccesses; |
| WHV_PROCESSOR_INTERCEPT_COUNTER PageFaultIntercepts; |
| } WHV_PROCESSOR_ACTIVITY_COUNTERS; |
| |
| typedef struct WHV_PROCESSOR_EVENT_COUNTERS { |
| UINT64 PageFaultCount; |
| UINT64 ExceptionCount; |
| UINT64 InterruptCount; |
| } WHV_PROCESSOR_GUEST_EVENT_COUNTERS; |
| |
| typedef struct WHV_PROCESSOR_APIC_COUNTERS { |
| UINT64 MmioAccessCount; |
| UINT64 EoiAccessCount; |
| UINT64 TprAccessCount; |
| UINT64 SentIpiCount; |
| UINT64 SelfIpiCount; |
| } WHV_PROCESSOR_APIC_COUNTERS; |
| |
| #endif |