blob: b547b7a5679cce4f3e5463fd27b84ec4f7a7d621 [file] [log] [blame]
/**
* 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_
#if defined(__x86_64__) || defined(__aarch64__)
#if defined(__x86_64__)
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,
WHvX64RegisterVirtualCr0 = 0x00000028,
WHvX64RegisterVirtualCr3 = 0x00000029,
WHvX64RegisterVirtualCr4 = 0x0000002A,
WHvX64RegisterVirtualCr8 = 0x0000002B,
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,
WHvX64RegisterInitialApicId = 0x0000200C,
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,
WHvX64RegisterBndcfgs = 0x0000207C,
WHvX64RegisterMCount = 0x0000207E,
WHvX64RegisterACount = 0x0000207F,
WHvX64RegisterSpecCtrl = 0x00002084,
WHvX64RegisterPredCmd = 0x00002085,
WHvX64RegisterTscVirtualOffset = 0x00002087,
WHvX64RegisterTsxCtrl = 0x00002088,
WHvX64RegisterXss = 0x0000208B,
WHvX64RegisterUCet = 0x0000208C,
WHvX64RegisterSCet = 0x0000208D,
WHvX64RegisterSsp = 0x0000208E,
WHvX64RegisterPl0Ssp = 0x0000208F,
WHvX64RegisterPl1Ssp = 0x00002090,
WHvX64RegisterPl2Ssp = 0x00002091,
WHvX64RegisterPl3Ssp = 0x00002092,
WHvX64RegisterInterruptSspTableAddr = 0x00002093,
WHvX64RegisterTscDeadline = 0x00002095,
WHvX64RegisterTscAdjust = 0x00002096,
WHvX64RegisterUmwaitControl = 0x00002098,
WHvX64RegisterXfd = 0x00002099,
WHvX64RegisterXfdErr = 0x0000209A,
WHvX64RegisterMsrIa32MiscEnable = 0x000020A0,
WHvX64RegisterIa32FeatureControl = 0x000020A1,
WHvX64RegisterIa32VmxBasic = 0x000020A2,
WHvX64RegisterIa32VmxPinbasedCtls = 0x000020A3,
WHvX64RegisterIa32VmxProcbasedCtls = 0x000020A4,
WHvX64RegisterIa32VmxExitCtls = 0x000020A5,
WHvX64RegisterIa32VmxEntryCtls = 0x000020A6,
WHvX64RegisterIa32VmxMisc = 0x000020A7,
WHvX64RegisterIa32VmxCr0Fixed0 = 0x000020A8,
WHvX64RegisterIa32VmxCr0Fixed1 = 0x000020A9,
WHvX64RegisterIa32VmxCr4Fixed0 = 0x000020AA,
WHvX64RegisterIa32VmxCr4Fixed1 = 0x000020AB,
WHvX64RegisterIa32VmxVmcsEnum = 0x000020AC,
WHvX64RegisterIa32VmxProcbasedCtls2 = 0x000020AD,
WHvX64RegisterIa32VmxEptVpidCap = 0x000020AE,
WHvX64RegisterIa32VmxTruePinbasedCtls = 0x000020AF,
WHvX64RegisterIa32VmxTrueProcbasedCtls = 0x000020B0,
WHvX64RegisterIa32VmxTrueExitCtls = 0x000020B1,
WHvX64RegisterIa32VmxTrueEntryCtls = 0x000020B2,
WHvX64RegisterAmdVmHsavePa = 0x000020B3,
WHvX64RegisterAmdVmCr = 0x000020B4,
WHvX64RegisterApicId = 0x00003002,
WHvX64RegisterApicVersion = 0x00003003,
WHvX64RegisterApicTpr = 0x00003008,
WHvX64RegisterApicPpr = 0x0000300A,
WHvX64RegisterApicEoi = 0x0000300B,
WHvX64RegisterApicLdr = 0x0000300D,
WHvX64RegisterApicSpurious = 0x0000300F,
WHvX64RegisterApicIsr0 = 0x00003010,
WHvX64RegisterApicIsr1 = 0x00003011,
WHvX64RegisterApicIsr2 = 0x00003012,
WHvX64RegisterApicIsr3 = 0x00003013,
WHvX64RegisterApicIsr4 = 0x00003014,
WHvX64RegisterApicIsr5 = 0x00003015,
WHvX64RegisterApicIsr6 = 0x00003016,
WHvX64RegisterApicIsr7 = 0x00003017,
WHvX64RegisterApicTmr0 = 0x00003018,
WHvX64RegisterApicTmr1 = 0x00003019,
WHvX64RegisterApicTmr2 = 0x0000301A,
WHvX64RegisterApicTmr3 = 0x0000301B,
WHvX64RegisterApicTmr4 = 0x0000301C,
WHvX64RegisterApicTmr5 = 0x0000301D,
WHvX64RegisterApicTmr6 = 0x0000301E,
WHvX64RegisterApicTmr7 = 0x0000301F,
WHvX64RegisterApicIrr0 = 0x00003020,
WHvX64RegisterApicIrr1 = 0x00003021,
WHvX64RegisterApicIrr2 = 0x00003022,
WHvX64RegisterApicIrr3 = 0x00003023,
WHvX64RegisterApicIrr4 = 0x00003024,
WHvX64RegisterApicIrr5 = 0x00003025,
WHvX64RegisterApicIrr6 = 0x00003026,
WHvX64RegisterApicIrr7 = 0x00003027,
WHvX64RegisterApicEse = 0x00003028,
WHvX64RegisterApicIcr = 0x00003030,
WHvX64RegisterApicLvtTimer = 0x00003032,
WHvX64RegisterApicLvtThermal = 0x00003033,
WHvX64RegisterApicLvtPerfmon = 0x00003034,
WHvX64RegisterApicLvtLint0 = 0x00003035,
WHvX64RegisterApicLvtLint1 = 0x00003036,
WHvX64RegisterApicLvtError = 0x00003037,
WHvX64RegisterApicInitCount = 0x00003038,
WHvX64RegisterApicCurrentCount = 0x00003039,
WHvX64RegisterApicDivide = 0x0000303E,
WHvX64RegisterApicSelfIpi = 0x0000303F,
WHvRegisterSint0 = 0x00004000,
WHvRegisterSint1 = 0x00004001,
WHvRegisterSint2 = 0x00004002,
WHvRegisterSint3 = 0x00004003,
WHvRegisterSint4 = 0x00004004,
WHvRegisterSint5 = 0x00004005,
WHvRegisterSint6 = 0x00004006,
WHvRegisterSint7 = 0x00004007,
WHvRegisterSint8 = 0x00004008,
WHvRegisterSint9 = 0x00004009,
WHvRegisterSint10 = 0x0000400A,
WHvRegisterSint11 = 0x0000400B,
WHvRegisterSint12 = 0x0000400C,
WHvRegisterSint13 = 0x0000400D,
WHvRegisterSint14 = 0x0000400E,
WHvRegisterSint15 = 0x0000400F,
WHvRegisterScontrol = 0x00004010,
WHvRegisterSversion = 0x00004011,
WHvRegisterSiefp = 0x00004012,
WHvRegisterSimp = 0x00004013,
WHvRegisterEom = 0x00004014,
WHvRegisterVpRuntime = 0x00005000,
WHvX64RegisterHypercall = 0x00005001,
WHvRegisterGuestOsId = 0x00005002,
WHvRegisterVpAssistPage = 0x00005013,
WHvRegisterReferenceTsc = 0x00005017,
WHvRegisterReferenceTscSequence = 0x0000501A,
WHvX64RegisterNestedGuestState = 0x00005050,
WHvX64RegisterNestedCurrentVmGpa = 0x00005051,
WHvX64RegisterNestedVmxInvEpt = 0x00005052,
WHvX64RegisterNestedVmxInvVpid = 0x00005053,
WHvRegisterPendingInterruption = 0x80000000,
WHvRegisterInterruptState = 0x80000001,
WHvRegisterPendingEvent = 0x80000002,
WHvRegisterPendingEvent1 = 0x80000003,
WHvX64RegisterDeliverabilityNotifications = 0x80000004,
WHvRegisterDeliverabilityNotifications = 0x80000004,
WHvRegisterInternalActivityState = 0x80000005,
WHvX64RegisterPendingDebugException = 0x80000006,
WHvRegisterPendingEvent2 = 0x80000007,
WHvRegisterPendingEvent3 = 0x80000008
} WHV_REGISTER_NAME;
#elif defined (__aarch64__)
typedef enum WHV_REGISTER_NAME {
WHvArm64RegisterX0 = 0x00020000,
WHvArm64RegisterX1 = 0x00020001,
WHvArm64RegisterX2 = 0x00020002,
WHvArm64RegisterX3 = 0x00020003,
WHvArm64RegisterX4 = 0x00020004,
WHvArm64RegisterX5 = 0x00020005,
WHvArm64RegisterX6 = 0x00020006,
WHvArm64RegisterX7 = 0x00020007,
WHvArm64RegisterX8 = 0x00020008,
WHvArm64RegisterX9 = 0x00020009,
WHvArm64RegisterX10 = 0x0002000A,
WHvArm64RegisterX11 = 0x0002000B,
WHvArm64RegisterX12 = 0x0002000C,
WHvArm64RegisterX13 = 0x0002000D,
WHvArm64RegisterX14 = 0x0002000E,
WHvArm64RegisterX15 = 0x0002000F,
WHvArm64RegisterX16 = 0x00020010,
WHvArm64RegisterX17 = 0x00020011,
WHvArm64RegisterX18 = 0x00020012,
WHvArm64RegisterX19 = 0x00020013,
WHvArm64RegisterX20 = 0x00020014,
WHvArm64RegisterX21 = 0x00020015,
WHvArm64RegisterX22 = 0x00020016,
WHvArm64RegisterX23 = 0x00020017,
WHvArm64RegisterX24 = 0x00020018,
WHvArm64RegisterX25 = 0x00020019,
WHvArm64RegisterX26 = 0x0002001A,
WHvArm64RegisterX27 = 0x0002001B,
WHvArm64RegisterX28 = 0x0002001C,
WHvArm64RegisterFp = 0x0002001D,
WHvArm64RegisterLr = 0x0002001E,
WHvArm64RegisterPc = 0x00020022,
WHvArm64RegisterQ0 = 0x00030000,
WHvArm64RegisterQ1 = 0x00030001,
WHvArm64RegisterQ2 = 0x00030002,
WHvArm64RegisterQ3 = 0x00030003,
WHvArm64RegisterQ4 = 0x00030004,
WHvArm64RegisterQ5 = 0x00030005,
WHvArm64RegisterQ6 = 0x00030006,
WHvArm64RegisterQ7 = 0x00030007,
WHvArm64RegisterQ8 = 0x00030008,
WHvArm64RegisterQ9 = 0x00030009,
WHvArm64RegisterQ10 = 0x0003000A,
WHvArm64RegisterQ11 = 0x0003000B,
WHvArm64RegisterQ12 = 0x0003000C,
WHvArm64RegisterQ13 = 0x0003000D,
WHvArm64RegisterQ14 = 0x0003000E,
WHvArm64RegisterQ15 = 0x0003000F,
WHvArm64RegisterQ16 = 0x00030010,
WHvArm64RegisterQ17 = 0x00030011,
WHvArm64RegisterQ18 = 0x00030012,
WHvArm64RegisterQ19 = 0x00030013,
WHvArm64RegisterQ20 = 0x00030014,
WHvArm64RegisterQ21 = 0x00030015,
WHvArm64RegisterQ22 = 0x00030016,
WHvArm64RegisterQ23 = 0x00030017,
WHvArm64RegisterQ24 = 0x00030018,
WHvArm64RegisterQ25 = 0x00030019,
WHvArm64RegisterQ26 = 0x0003001A,
WHvArm64RegisterQ27 = 0x0003001B,
WHvArm64RegisterQ28 = 0x0003001C,
WHvArm64RegisterQ29 = 0x0003001D,
WHvArm64RegisterQ30 = 0x0003001E,
WHvArm64RegisterQ31 = 0x0003001F,
WHvArm64RegisterPstate = 0x00020023,
WHvArm64RegisterElrEl1 = 0x00040015,
WHvArm64RegisterFpcr = 0x00040012,
WHvArm64RegisterFpsr = 0x00040013,
WHvArm64RegisterSp = 0x0002001F,
WHvArm64RegisterSpEl0 = 0x00020020,
WHvArm64RegisterSpEl1 = 0x00020021,
WHvArm64RegisterSpsrEl1 = 0x00040014,
WHvArm64RegisterIdMidrEl1 = 0x00022000,
WHvArm64RegisterIdRes01El1 = 0x00022001,
WHvArm64RegisterIdRes02El1 = 0x00022002,
WHvArm64RegisterIdRes03El1 = 0x00022003,
WHvArm64RegisterIdRes04El1 = 0x00022004,
WHvArm64RegisterIdMpidrEl1 = 0x00022005,
WHvArm64RegisterIdRevidrEl1 = 0x00022006,
WHvArm64RegisterIdRes07El1 = 0x00022007,
WHvArm64RegisterIdPfr0El1 = 0x00022008,
WHvArm64RegisterIdPfr1El1 = 0x00022009,
WHvArm64RegisterIdDfr0El1 = 0x0002200A,
WHvArm64RegisterIdRes13El1 = 0x0002200B,
WHvArm64RegisterIdMmfr0El1 = 0x0002200C,
WHvArm64RegisterIdMmfr1El1 = 0x0002200D,
WHvArm64RegisterIdMmfr2El1 = 0x0002200E,
WHvArm64RegisterIdMmfr3El1 = 0x0002200F,
WHvArm64RegisterIdIsar0El1 = 0x00022010,
WHvArm64RegisterIdIsar1El1 = 0x00022011,
WHvArm64RegisterIdIsar2El1 = 0x00022012,
WHvArm64RegisterIdIsar3El1 = 0x00022013,
WHvArm64RegisterIdIsar4El1 = 0x00022014,
WHvArm64RegisterIdIsar5El1 = 0x00022015,
WHvArm64RegisterIdRes26El1 = 0x00022016,
WHvArm64RegisterIdRes27El1 = 0x00022017,
WHvArm64RegisterIdMvfr0El1 = 0x00022018,
WHvArm64RegisterIdMvfr1El1 = 0x00022019,
WHvArm64RegisterIdMvfr2El1 = 0x0002201A,
WHvArm64RegisterIdRes33El1 = 0x0002201B,
WHvArm64RegisterIdPfr2El1 = 0x0002201C,
WHvArm64RegisterIdRes35El1 = 0x0002201D,
WHvArm64RegisterIdRes36El1 = 0x0002201E,
WHvArm64RegisterIdRes37El1 = 0x0002201F,
WHvArm64RegisterIdAa64Pfr0El1 = 0x00022020,
WHvArm64RegisterIdAa64Pfr1El1 = 0x00022021,
WHvArm64RegisterIdAa64Pfr2El1 = 0x00022022,
WHvArm64RegisterIdRes43El1 = 0x00022023,
WHvArm64RegisterIdAa64Zfr0El1 = 0x00022024,
WHvArm64RegisterIdAa64Smfr0El1 = 0x00022025,
WHvArm64RegisterIdRes46El1 = 0x00022026,
WHvArm64RegisterIdRes47El1 = 0x00022027,
WHvArm64RegisterIdAa64Dfr0El1 = 0x00022028,
WHvArm64RegisterIdAa64Dfr1El1 = 0x00022029,
WHvArm64RegisterIdRes52El1 = 0x0002202A,
WHvArm64RegisterIdRes53El1 = 0x0002202B,
WHvArm64RegisterIdRes54El1 = 0x0002202C,
WHvArm64RegisterIdRes55El1 = 0x0002202D,
WHvArm64RegisterIdRes56El1 = 0x0002202E,
WHvArm64RegisterIdRes57El1 = 0x0002202F,
WHvArm64RegisterIdAa64Isar0El1 = 0x00022030,
WHvArm64RegisterIdAa64Isar1El1 = 0x00022031,
WHvArm64RegisterIdAa64Isar2El1 = 0x00022032,
WHvArm64RegisterIdRes63El1 = 0x00022033,
WHvArm64RegisterIdRes64El1 = 0x00022034,
WHvArm64RegisterIdRes65El1 = 0x00022035,
WHvArm64RegisterIdRes66El1 = 0x00022036,
WHvArm64RegisterIdRes67El1 = 0x00022037,
WHvArm64RegisterIdAa64Mmfr0El1 = 0x00022038,
WHvArm64RegisterIdAa64Mmfr1El1 = 0x00022039,
WHvArm64RegisterIdAa64Mmfr2El1 = 0x0002203A,
WHvArm64RegisterIdAa64Mmfr3El1 = 0x0002203B,
WHvArm64RegisterIdAa64Mmfr4El1 = 0x0002203C,
WHvArm64RegisterIdRes75El1 = 0x0002203D,
WHvArm64RegisterIdRes76El1 = 0x0002203E,
WHvArm64RegisterIdRes77El1 = 0x0002203F,
WHvArm64RegisterIdRes80El1 = 0x00022040,
WHvArm64RegisterIdRes81El1 = 0x00022041,
WHvArm64RegisterIdRes82El1 = 0x00022042,
WHvArm64RegisterIdRes83El1 = 0x00022043,
WHvArm64RegisterIdRes84El1 = 0x00022044,
WHvArm64RegisterIdRes85El1 = 0x00022045,
WHvArm64RegisterIdRes86El1 = 0x00022046,
WHvArm64RegisterIdRes87El1 = 0x00022047,
WHvArm64RegisterIdRes90El1 = 0x00022048,
WHvArm64RegisterIdRes91El1 = 0x00022049,
WHvArm64RegisterIdRes92El1 = 0x0002204A,
WHvArm64RegisterIdRes93El1 = 0x0002204B,
WHvArm64RegisterIdRes94El1 = 0x0002204C,
WHvArm64RegisterIdRes95El1 = 0x0002204D,
WHvArm64RegisterIdRes96El1 = 0x0002204E,
WHvArm64RegisterIdRes97El1 = 0x0002204F,
WHvArm64RegisterIdRes100El1 = 0x00022050,
WHvArm64RegisterIdRes101El1 = 0x00022051,
WHvArm64RegisterIdRes102El1 = 0x00022052,
WHvArm64RegisterIdRes103El1 = 0x00022053,
WHvArm64RegisterIdRes104El1 = 0x00022054,
WHvArm64RegisterIdRes105El1 = 0x00022055,
WHvArm64RegisterIdRes106El1 = 0x00022056,
WHvArm64RegisterIdRes107El1 = 0x00022057,
WHvArm64RegisterIdRes110El1 = 0x00022058,
WHvArm64RegisterIdRes111El1 = 0x00022059,
WHvArm64RegisterIdRes112El1 = 0x0002205A,
WHvArm64RegisterIdRes113El1 = 0x0002205B,
WHvArm64RegisterIdRes114El1 = 0x0002205C,
WHvArm64RegisterIdRes115El1 = 0x0002205D,
WHvArm64RegisterIdRes116El1 = 0x0002205E,
WHvArm64RegisterIdRes117El1 = 0x0002205F,
WHvArm64RegisterIdRes120El1 = 0x00022060,
WHvArm64RegisterIdRes121El1 = 0x00022061,
WHvArm64RegisterIdRes122El1 = 0x00022062,
WHvArm64RegisterIdRes123El1 = 0x00022063,
WHvArm64RegisterIdRes124El1 = 0x00022064,
WHvArm64RegisterIdRes125El1 = 0x00022065,
WHvArm64RegisterIdRes126El1 = 0x00022066,
WHvArm64RegisterIdRes127El1 = 0x00022067,
WHvArm64RegisterIdRes130El1 = 0x00022068,
WHvArm64RegisterIdRes131El1 = 0x00022069,
WHvArm64RegisterIdRes132El1 = 0x0002206A,
WHvArm64RegisterIdRes133El1 = 0x0002206B,
WHvArm64RegisterIdRes134El1 = 0x0002206C,
WHvArm64RegisterIdRes135El1 = 0x0002206D,
WHvArm64RegisterIdRes136El1 = 0x0002206E,
WHvArm64RegisterIdRes137El1 = 0x0002206F,
WHvArm64RegisterIdRes140El1 = 0x00022070,
WHvArm64RegisterIdRes141El1 = 0x00022071,
WHvArm64RegisterIdRes142El1 = 0x00022072,
WHvArm64RegisterIdRes143El1 = 0x00022073,
WHvArm64RegisterIdRes144El1 = 0x00022074,
WHvArm64RegisterIdRes145El1 = 0x00022075,
WHvArm64RegisterIdRes146El1 = 0x00022076,
WHvArm64RegisterIdRes147El1 = 0x00022077,
WHvArm64RegisterIdRes150El1 = 0x00022078,
WHvArm64RegisterIdRes151El1 = 0x00022079,
WHvArm64RegisterIdRes152El1 = 0x0002207A,
WHvArm64RegisterIdRes153El1 = 0x0002207B,
WHvArm64RegisterIdRes154El1 = 0x0002207C,
WHvArm64RegisterIdRes155El1 = 0x0002207D,
WHvArm64RegisterIdRes156El1 = 0x0002207E,
WHvArm64RegisterIdRes157El1 = 0x0002207F,
WHvArm64RegisterActlrEl1 = 0x00040003,
WHvArm64RegisterApdAKeyHiEl1 = 0x00040026,
WHvArm64RegisterApdAKeyLoEl1 = 0x00040027,
WHvArm64RegisterApdBKeyHiEl1 = 0x00040028,
WHvArm64RegisterApdBKeyLoEl1 = 0x00040029,
WHvArm64RegisterApgAKeyHiEl1 = 0x0004002A,
WHvArm64RegisterApgAKeyLoEl1 = 0x0004002B,
WHvArm64RegisterApiAKeyHiEl1 = 0x0004002C,
WHvArm64RegisterApiAKeyLoEl1 = 0x0004002D,
WHvArm64RegisterApiBKeyHiEl1 = 0x0004002E,
WHvArm64RegisterApiBKeyLoEl1 = 0x0004002F,
WHvArm64RegisterContextidrEl1 = 0x0004000D,
WHvArm64RegisterCpacrEl1 = 0x00040004,
WHvArm64RegisterCsselrEl1 = 0x00040035,
WHvArm64RegisterEsrEl1 = 0x00040008,
WHvArm64RegisterFarEl1 = 0x00040009,
WHvArm64RegisterMairEl1 = 0x0004000B,
WHvArm64RegisterMidrEl1 = 0x00040051,
WHvArm64RegisterMpidrEl1 = 0x00040001,
WHvArm64RegisterParEl1 = 0x0004000A,
WHvArm64RegisterSctlrEl1 = 0x00040002,
WHvArm64RegisterTcrEl1 = 0x00040007,
WHvArm64RegisterTpidrEl0 = 0x00040011,
WHvArm64RegisterTpidrEl1 = 0x0004000E,
WHvArm64RegisterTpidrroEl0 = 0x00040010,
WHvArm64RegisterTtbr0El1 = 0x00040005,
WHvArm64RegisterTtbr1El1 = 0x00040006,
WHvArm64RegisterVbarEl1 = 0x0004000C,
WHvArm64RegisterZcrEl1 = 0x00040071,
WHvArm64RegisterDbgbcr0El1 = 0x00050000,
WHvArm64RegisterDbgbcr1El1 = 0x00050001,
WHvArm64RegisterDbgbcr2El1 = 0x00050002,
WHvArm64RegisterDbgbcr3El1 = 0x00050003,
WHvArm64RegisterDbgbcr4El1 = 0x00050004,
WHvArm64RegisterDbgbcr5El1 = 0x00050005,
WHvArm64RegisterDbgbcr6El1 = 0x00050006,
WHvArm64RegisterDbgbcr7El1 = 0x00050007,
WHvArm64RegisterDbgbcr8El1 = 0x00050008,
WHvArm64RegisterDbgbcr9El1 = 0x00050009,
WHvArm64RegisterDbgbcr10El1 = 0x0005000A,
WHvArm64RegisterDbgbcr11El1 = 0x0005000B,
WHvArm64RegisterDbgbcr12El1 = 0x0005000C,
WHvArm64RegisterDbgbcr13El1 = 0x0005000D,
WHvArm64RegisterDbgbcr14El1 = 0x0005000E,
WHvArm64RegisterDbgbcr15El1 = 0x0005000F,
WHvArm64RegisterDbgbvr0El1 = 0x00050020,
WHvArm64RegisterDbgbvr1El1 = 0x00050021,
WHvArm64RegisterDbgbvr2El1 = 0x00050022,
WHvArm64RegisterDbgbvr3El1 = 0x00050023,
WHvArm64RegisterDbgbvr4El1 = 0x00050024,
WHvArm64RegisterDbgbvr5El1 = 0x00050025,
WHvArm64RegisterDbgbvr6El1 = 0x00050026,
WHvArm64RegisterDbgbvr7El1 = 0x00050027,
WHvArm64RegisterDbgbvr8El1 = 0x00050028,
WHvArm64RegisterDbgbvr9El1 = 0x00050029,
WHvArm64RegisterDbgbvr10El1 = 0x0005002A,
WHvArm64RegisterDbgbvr11El1 = 0x0005002B,
WHvArm64RegisterDbgbvr12El1 = 0x0005002C,
WHvArm64RegisterDbgbvr13El1 = 0x0005002D,
WHvArm64RegisterDbgbvr14El1 = 0x0005002E,
WHvArm64RegisterDbgbvr15El1 = 0x0005002F,
WHvArm64RegisterDbgprcrEl1 = 0x00050045,
WHvArm64RegisterDbgwcr0El1 = 0x00050010,
WHvArm64RegisterDbgwcr1El1 = 0x00050011,
WHvArm64RegisterDbgwcr2El1 = 0x00050012,
WHvArm64RegisterDbgwcr3El1 = 0x00050013,
WHvArm64RegisterDbgwcr4El1 = 0x00050014,
WHvArm64RegisterDbgwcr5El1 = 0x00050015,
WHvArm64RegisterDbgwcr6El1 = 0x00050016,
WHvArm64RegisterDbgwcr7El1 = 0x00050017,
WHvArm64RegisterDbgwcr8El1 = 0x00050018,
WHvArm64RegisterDbgwcr9El1 = 0x00050019,
WHvArm64RegisterDbgwcr10El1 = 0x0005001A,
WHvArm64RegisterDbgwcr11El1 = 0x0005001B,
WHvArm64RegisterDbgwcr12El1 = 0x0005001C,
WHvArm64RegisterDbgwcr13El1 = 0x0005001D,
WHvArm64RegisterDbgwcr14El1 = 0x0005001E,
WHvArm64RegisterDbgwcr15El1 = 0x0005001F,
WHvArm64RegisterDbgwvr0El1 = 0x00050030,
WHvArm64RegisterDbgwvr1El1 = 0x00050031,
WHvArm64RegisterDbgwvr2El1 = 0x00050032,
WHvArm64RegisterDbgwvr3El1 = 0x00050033,
WHvArm64RegisterDbgwvr4El1 = 0x00050034,
WHvArm64RegisterDbgwvr5El1 = 0x00050035,
WHvArm64RegisterDbgwvr6El1 = 0x00050036,
WHvArm64RegisterDbgwvr7El1 = 0x00050037,
WHvArm64RegisterDbgwvr8El1 = 0x00050038,
WHvArm64RegisterDbgwvr9El1 = 0x00050039,
WHvArm64RegisterDbgwvr10El1 = 0x0005003A,
WHvArm64RegisterDbgwvr11El1 = 0x0005003B,
WHvArm64RegisterDbgwvr12El1 = 0x0005003C,
WHvArm64RegisterDbgwvr13El1 = 0x0005003D,
WHvArm64RegisterDbgwvr14El1 = 0x0005003E,
WHvArm64RegisterDbgwvr15El1 = 0x0005003F,
WHvArm64RegisterMdrarEl1 = 0x0005004C,
WHvArm64RegisterMdscrEl1 = 0x0005004D,
WHvArm64RegisterOsdlrEl1 = 0x0005004E,
WHvArm64RegisterOslarEl1 = 0x00050052,
WHvArm64RegisterOslsrEl1 = 0x00050053,
WHvArm64RegisterPmccfiltrEl0 = 0x00052000,
WHvArm64RegisterPmccntrEl0 = 0x00052001,
WHvArm64RegisterPmceid0El0 = 0x00052002,
WHvArm64RegisterPmceid1El0 = 0x00052003,
WHvArm64RegisterPmcntenclrEl0 = 0x00052004,
WHvArm64RegisterPmcntensetEl0 = 0x00052005,
WHvArm64RegisterPmcrEl0 = 0x00052006,
WHvArm64RegisterPmevcntr0El0 = 0x00052007,
WHvArm64RegisterPmevcntr1El0 = 0x00052008,
WHvArm64RegisterPmevcntr2El0 = 0x00052009,
WHvArm64RegisterPmevcntr3El0 = 0x0005200A,
WHvArm64RegisterPmevcntr4El0 = 0x0005200B,
WHvArm64RegisterPmevcntr5El0 = 0x0005200C,
WHvArm64RegisterPmevcntr6El0 = 0x0005200D,
WHvArm64RegisterPmevcntr7El0 = 0x0005200E,
WHvArm64RegisterPmevcntr8El0 = 0x0005200F,
WHvArm64RegisterPmevcntr9El0 = 0x00052010,
WHvArm64RegisterPmevcntr10El0 = 0x00052011,
WHvArm64RegisterPmevcntr11El0 = 0x00052012,
WHvArm64RegisterPmevcntr12El0 = 0x00052013,
WHvArm64RegisterPmevcntr13El0 = 0x00052014,
WHvArm64RegisterPmevcntr14El0 = 0x00052015,
WHvArm64RegisterPmevcntr15El0 = 0x00052016,
WHvArm64RegisterPmevcntr16El0 = 0x00052017,
WHvArm64RegisterPmevcntr17El0 = 0x00052018,
WHvArm64RegisterPmevcntr18El0 = 0x00052019,
WHvArm64RegisterPmevcntr19El0 = 0x0005201A,
WHvArm64RegisterPmevcntr20El0 = 0x0005201B,
WHvArm64RegisterPmevcntr21El0 = 0x0005201C,
WHvArm64RegisterPmevcntr22El0 = 0x0005201D,
WHvArm64RegisterPmevcntr23El0 = 0x0005201E,
WHvArm64RegisterPmevcntr24El0 = 0x0005201F,
WHvArm64RegisterPmevcntr25El0 = 0x00052020,
WHvArm64RegisterPmevcntr26El0 = 0x00052021,
WHvArm64RegisterPmevcntr27El0 = 0x00052022,
WHvArm64RegisterPmevcntr28El0 = 0x00052023,
WHvArm64RegisterPmevcntr29El0 = 0x00052024,
WHvArm64RegisterPmevcntr30El0 = 0x00052025,
WHvArm64RegisterPmevtyper0El0 = 0x00052026,
WHvArm64RegisterPmevtyper1El0 = 0x00052027,
WHvArm64RegisterPmevtyper2El0 = 0x00052028,
WHvArm64RegisterPmevtyper3El0 = 0x00052029,
WHvArm64RegisterPmevtyper4El0 = 0x0005202A,
WHvArm64RegisterPmevtyper5El0 = 0x0005202B,
WHvArm64RegisterPmevtyper6El0 = 0x0005202C,
WHvArm64RegisterPmevtyper7El0 = 0x0005202D,
WHvArm64RegisterPmevtyper8El0 = 0x0005202E,
WHvArm64RegisterPmevtyper9El0 = 0x0005202F,
WHvArm64RegisterPmevtyper10El0 = 0x00052030,
WHvArm64RegisterPmevtyper11El0 = 0x00052031,
WHvArm64RegisterPmevtyper12El0 = 0x00052032,
WHvArm64RegisterPmevtyper13El0 = 0x00052033,
WHvArm64RegisterPmevtyper14El0 = 0x00052034,
WHvArm64RegisterPmevtyper15El0 = 0x00052035,
WHvArm64RegisterPmevtyper16El0 = 0x00052036,
WHvArm64RegisterPmevtyper17El0 = 0x00052037,
WHvArm64RegisterPmevtyper18El0 = 0x00052038,
WHvArm64RegisterPmevtyper19El0 = 0x00052039,
WHvArm64RegisterPmevtyper20El0 = 0x0005203A,
WHvArm64RegisterPmevtyper21El0 = 0x0005203B,
WHvArm64RegisterPmevtyper22El0 = 0x0005203C,
WHvArm64RegisterPmevtyper23El0 = 0x0005203D,
WHvArm64RegisterPmevtyper24El0 = 0x0005203E,
WHvArm64RegisterPmevtyper25El0 = 0x0005203F,
WHvArm64RegisterPmevtyper26El0 = 0x00052040,
WHvArm64RegisterPmevtyper27El0 = 0x00052041,
WHvArm64RegisterPmevtyper28El0 = 0x00052042,
WHvArm64RegisterPmevtyper29El0 = 0x00052043,
WHvArm64RegisterPmevtyper30El0 = 0x00052044,
WHvArm64RegisterPmintenclrEl1 = 0x00052045,
WHvArm64RegisterPmintensetEl1 = 0x00052046,
WHvArm64RegisterPmovsclrEl0 = 0x00052048,
WHvArm64RegisterPmovssetEl0 = 0x00052049,
WHvArm64RegisterPmselrEl0 = 0x0005204A,
WHvArm64RegisterPmuserenrEl0 = 0x0005204C,
WHvArm64RegisterCntkctlEl1 = 0x00058008,
WHvArm64RegisterCntvCtlEl0 = 0x0005800E,
WHvArm64RegisterCntvCvalEl0 = 0x0005800F,
WHvArm64RegisterCntvctEl0 = 0x00058011,
WHvArm64RegisterGicrBaseGpa = 0x00063000,
WHvRegisterSint0 = 0x000A0000,
WHvRegisterSint1 = 0x000A0001,
WHvRegisterSint2 = 0x000A0002,
WHvRegisterSint3 = 0x000A0003,
WHvRegisterSint4 = 0x000A0004,
WHvRegisterSint5 = 0x000A0005,
WHvRegisterSint6 = 0x000A0006,
WHvRegisterSint7 = 0x000A0007,
WHvRegisterSint8 = 0x000A0008,
WHvRegisterSint9 = 0x000A0009,
WHvRegisterSint10 = 0x000A000A,
WHvRegisterSint11 = 0x000A000B,
WHvRegisterSint12 = 0x000A000C,
WHvRegisterSint13 = 0x000A000D,
WHvRegisterSint14 = 0x000A000E,
WHvRegisterSint15 = 0x000A000F,
WHvRegisterScontrol = 0x000A0010,
WHvRegisterSversion = 0x000A0011,
WHvRegisterSifp = 0x000A0012,
WHvRegisterSipp = 0x000A0013,
WHvRegisterEom = 0x000A0014,
WHvRegisterHypervisorVersion = 0x00000100,
WHvRegisterPrivilegesAndFeaturesInfo = 0x00000200,
WHvRegisterFeaturesInfo = 0x00000201,
WHvRegisterImplementationLimitsInfo = 0x00000202,
WHvRegisterHardwareFeaturesInfo = 0x00000203,
WHvRegisterCpuManagementFeaturesInfo = 0x00000204,
WHvRegisterPasidFeaturesInfo = 0x00000205,
WHvRegisterGuestCrashP0 = 0x00000210,
WHvRegisterGuestCrashP1 = 0x00000211,
WHvRegisterGuestCrashP2 = 0x00000212,
WHvRegisterGuestCrashP3 = 0x00000213,
WHvRegisterGuestCrashP4 = 0x00000214,
WHvRegisterGuestCrashCtl = 0x00000215,
WHvRegisterVpRuntime = 0x00090000,
WHvRegisterGuestOsId = 0x00090002,
WHvRegisterVpAssistPage = 0x00090013,
WHvArm64RegisterPartitionInfoPage = 0x00090015,
WHvRegisterReferenceTsc = 0x00090017,
WHvRegisterReferenceTscSequence = 0x0009001A,
WHvRegisterPendingEvent0 = 0x00010004,
WHvRegisterPendingEvent1 = 0x00010005,
WHvRegisterDeliverabilityNotifications = 0x00010006,
WHvRegisterInternalActivityState = 0x00000004,
WHvRegisterPendingEvent2 = 0x00010008,
WHvRegisterPendingEvent3 = 0x00010009
} WHV_REGISTER_NAME;
#define WHvRegisterSiefp WHvRegisterSifp
#define WHvRegisterSimp WHvRegisterSipp
#define WHvRegisterPendingEvent WHvRegisterPendingEvent0
#endif /* __x86_64__ || __aarch64__ */
typedef UINT64 WHV_GUEST_PHYSICAL_ADDRESS;
typedef UINT64 WHV_GUEST_VIRTUAL_ADDRESS;
typedef union DECLSPEC_ALIGN(16) WHV_UINT128 {
__C89_NAMELESS struct {
UINT64 Low64;
UINT64 High64;
};
UINT32 Dword[4];
} WHV_UINT128;
C_ASSERT(sizeof(WHV_UINT128) == 16);
#if defined(__x86_64__)
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;
C_ASSERT(sizeof(WHV_X64_FP_REGISTER) == 16);
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;
C_ASSERT(sizeof(WHV_X64_FP_CONTROL_STATUS_REGISTER) == 16);
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;
C_ASSERT(sizeof(WHV_X64_XMM_CONTROL_STATUS_REGISTER) == 16);
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;
C_ASSERT(sizeof(WHV_X64_SEGMENT_REGISTER) == 16);
typedef struct WHV_X64_TABLE_REGISTER {
UINT16 Pad[3];
UINT16 Limit;
UINT64 Base;
} WHV_X64_TABLE_REGISTER;
C_ASSERT(sizeof(WHV_X64_TABLE_REGISTER) == 16);
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;
C_ASSERT(sizeof(WHV_X64_INTERRUPT_STATE_REGISTER) == 8);
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 enum WHV_X64_PENDING_EVENT_TYPE {
WHvX64PendingEventException = 0,
WHvX64PendingEventExtInt = 5,
WHvX64PendingEventSvmNestedExit = 7,
WHvX64PendingEventVmxNestedExit = 8
} 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_X64_PENDING_SVM_NESTED_EXIT_EVENT0 {
__C89_NAMELESS struct {
UINT64 EventPending : 1;
UINT64 EventType : 4;
UINT64 Reserved0 : 3;
UINT64 InstructionBytesValid : 1;
UINT64 Reserved1 : 55;
UINT64 ExitCode;
};
WHV_UINT128 AsUINT128;
} WHV_X64_PENDING_SVM_NESTED_EXIT_EVENT0;
typedef union WHV_X64_PENDING_SVM_NESTED_EXIT_EVENT1 {
__C89_NAMELESS struct {
UINT64 ExitInfo1;
UINT64 ExitInfo2;
};
WHV_UINT128 AsUINT128;
} WHV_X64_PENDING_SVM_NESTED_EXIT_EVENT1;
typedef union WHV_X64_PENDING_SVM_NESTED_EXIT_EVENT2 {
__C89_NAMELESS struct {
UINT64 NextRip;
UINT8 InstructionBytesFetchedCount;
UINT8 InstructionBytes[7];
};
WHV_UINT128 AsUINT128;
} WHV_X64_PENDING_SVM_NESTED_EXIT_EVENT2;
typedef union WHV_X64_PENDING_SVM_NESTED_EXIT_EVENT3 {
__C89_NAMELESS struct {
UINT8 InstructionBytes[8];
UINT64 Reserved2;
};
WHV_UINT128 AsUINT128;
} WHV_X64_PENDING_SVM_NESTED_EXIT_EVENT3;
C_ASSERT(sizeof(WHV_X64_PENDING_SVM_NESTED_EXIT_EVENT0) == 16);
C_ASSERT(sizeof(WHV_X64_PENDING_SVM_NESTED_EXIT_EVENT1) == 16);
C_ASSERT(sizeof(WHV_X64_PENDING_SVM_NESTED_EXIT_EVENT2) == 16);
C_ASSERT(sizeof(WHV_X64_PENDING_SVM_NESTED_EXIT_EVENT3) == 16);
typedef union WHV_X64_PENDING_VMX_NESTED_EXIT_EVENT0 {
__C89_NAMELESS struct {
UINT32 EventPending : 1;
UINT32 EventType : 4;
UINT32 Reserved0 : 27;
UINT32 ExitReason;
UINT64 ExitQualification;
};
WHV_UINT128 AsUINT128;
} WHV_X64_PENDING_VMX_NESTED_EXIT_EVENT0;
typedef union WHV_X64_PENDING_VMX_NESTED_EXIT_EVENT1 {
__C89_NAMELESS struct {
UINT32 InstructionLength;
UINT32 InstructionInfo;
UINT32 ExitInterruptionInfo;
UINT32 ExitExceptionErrorCode;
};
WHV_UINT128 AsUINT128;
} WHV_X64_PENDING_VMX_NESTED_EXIT_EVENT1;
typedef union WHV_X64_PENDING_VMX_NESTED_EXIT_EVENT2 {
__C89_NAMELESS struct {
UINT64 GuestLinearAddress;
UINT64 GuestPhysicalAddress;
};
WHV_UINT128 AsUINT128;
} WHV_X64_PENDING_VMX_NESTED_EXIT_EVENT2;
C_ASSERT(sizeof(WHV_X64_PENDING_VMX_NESTED_EXIT_EVENT0) == 16);
C_ASSERT(sizeof(WHV_X64_PENDING_VMX_NESTED_EXIT_EVENT1) == 16);
C_ASSERT(sizeof(WHV_X64_PENDING_VMX_NESTED_EXIT_EVENT2) == 16);
typedef union WHV_X64_NESTED_INVEPT_REGISTER {
__C89_NAMELESS struct {
UINT8 Type;
UINT8 Reserved[7];
UINT64 Eptp;
};
WHV_UINT128 AsUINT128;
} WHV_X64_NESTED_INVEPT_REGISTER;
C_ASSERT(sizeof(WHV_X64_NESTED_INVEPT_REGISTER) == 16);
typedef union WHV_X64_NESTED_INVVPID_REGISTER {
__C89_NAMELESS struct {
UINT8 Type;
UINT8 Reserved[3];
UINT32 Vpid;
UINT64 LinearAddress;
};
WHV_UINT128 AsUINT128;
} WHV_X64_NESTED_INVVPID_REGISTER;
C_ASSERT(sizeof(WHV_X64_NESTED_INVVPID_REGISTER) == 16);
typedef union WHV_X64_NESTED_GUEST_STATE {
__C89_NAMELESS struct {
UINT64 NestedVirtActive : 1;
UINT64 NestedGuestMode : 1;
UINT64 VmEntryPending : 1;
UINT64 Reserved0 : 61;
UINT64 Reserved1;
};
WHV_UINT128 AsUINT128;
} WHV_X64_NESTED_GUEST_STATE;
C_ASSERT(sizeof(WHV_X64_NESTED_GUEST_STATE) == 16);
#endif /* defined(__x86_64__) */
typedef union WHV_DELIVERABILITY_NOTIFICATIONS_REGISTER {
__C89_NAMELESS struct {
#if defined(__x86_64__)
UINT64 NmiNotification:1;
UINT64 InterruptNotification:1;
UINT64 InterruptPriority:4;
UINT64 Reserved:42;
#elif defined(__aarch64__)
UINT64 Reserved:48;
#endif
UINT64 Sint:16;
};
UINT64 AsUINT64;
} WHV_DELIVERABILITY_NOTIFICATIONS_REGISTER, WHV_X64_DELIVERABILITY_NOTIFICATIONS_REGISTER;
C_ASSERT(sizeof(WHV_DELIVERABILITY_NOTIFICATIONS_REGISTER) == 8);
typedef union WHV_INTERNAL_ACTIVITY_REGISTER {
__C89_NAMELESS struct {
UINT64 StartupSuspend : 1;
UINT64 HaltSuspend : 1;
UINT64 IdleSuspend : 1;
UINT64 Reserved :61;
};
UINT64 AsUINT64;
} WHV_INTERNAL_ACTIVITY_REGISTER;
C_ASSERT(sizeof(WHV_INTERNAL_ACTIVITY_REGISTER) == 8);
#if defined(__x86_64__)
typedef union WHV_X64_PENDING_DEBUG_EXCEPTION {
UINT64 AsUINT64;
__C89_NAMELESS struct {
UINT64 Breakpoint0 : 1;
UINT64 Breakpoint1 : 1;
UINT64 Breakpoint2 : 1;
UINT64 Breakpoint3 : 1;
UINT64 SingleStep : 1;
UINT64 Reserved0 : 59;
};
} WHV_X64_PENDING_DEBUG_EXCEPTION;
C_ASSERT(sizeof(WHV_X64_PENDING_DEBUG_EXCEPTION) == 8);
#elif defined(__aarch64__)
typedef enum WHV_ARM64_PENDING_EVENT_TYPE {
WHvArm64PendingEventException = 0,
WHvArm64PendingEventSyntheticException = 1
} WHV_ARM64_PENDING_EVENT_TYPE;
#define WHV_ARM64_PENDING_EVENT_HEADER \
UINT8 EventPending : 1; \
UINT8 EventType : 3; \
UINT8 Reserved : 4
typedef union WHV_ARM64_PENDING_EXCEPTION_EVENT {
UINT64 AsUINT64[3];
__C89_NAMELESS struct {
WHV_ARM64_PENDING_EVENT_HEADER;
UINT8 Reserved1;
UINT16 Reserved2;
UINT32 Reserved3;
UINT64 EsrElx;
UINT64 FarElx;
};
} WHV_ARM64_PENDING_EXCEPTION_EVENT;
typedef enum WHV_ARM64_SYNTHETIC_EXCEPTION_TYPE {
WHvArm64SyntheticExceptionTypeSmc = 0x0,
WHvArm64SyntheticExceptionTypeSecure = 0x1,
WHvArm64SyntheticExceptionTypeCrashdump = 0x2,
WHvArm64SyntheticExceptionTypeVirtualizationFault = 0x3,
WHvArm64SyntheticExceptionTypeMax = 0x3F + 1
} WHV_ARM64_SYNTHETIC_EXCEPTION_TYPE;
typedef union WHV_ARM64_PENDING_SYNTHETIC_EXCEPTION_EVENT {
UINT64 AsUINT64[2];
__C89_NAMELESS struct {
WHV_ARM64_PENDING_EVENT_HEADER;
UINT8 Reserved1;
UINT16 Reserved2;
UINT32 ExceptionType;
UINT64 Context;
};
} WHV_ARM64_PENDING_SYNTHETIC_EXCEPTION_EVENT;
typedef union WHV_ARM64_PENDING_EVENT {
__C89_NAMELESS struct {
WHV_UINT128 Reg0;
WHV_UINT128 Reg1;
};
__C89_NAMELESS struct {
WHV_ARM64_PENDING_EVENT_HEADER;
UINT8 EventData[15];
};
WHV_ARM64_PENDING_EXCEPTION_EVENT Exception;
WHV_ARM64_PENDING_SYNTHETIC_EXCEPTION_EVENT SyntheticException;
} WHV_ARM64_PENDING_EVENT;
#endif /* defined(__x86_64__) || defined(__aarch64__) */
typedef union WHV_REGISTER_VALUE {
WHV_UINT128 Reg128;
UINT64 Reg64;
UINT32 Reg32;
UINT16 Reg16;
UINT8 Reg8;
WHV_INTERNAL_ACTIVITY_REGISTER InternalActivity;
WHV_DELIVERABILITY_NOTIFICATIONS_REGISTER DeliverabilityNotifications;
#if defined(__x86_64__)
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_PENDING_EXCEPTION_EVENT ExceptionEvent;
WHV_X64_PENDING_EXT_INT_EVENT ExtIntEvent;
WHV_X64_PENDING_DEBUG_EXCEPTION PendingDebugException;
WHV_X64_NESTED_GUEST_STATE NestedState;
WHV_X64_NESTED_INVEPT_REGISTER InvEpt;
WHV_X64_NESTED_INVVPID_REGISTER InvVpid;
WHV_X64_PENDING_SVM_NESTED_EXIT_EVENT0 SvmNestedExit0;
WHV_X64_PENDING_SVM_NESTED_EXIT_EVENT1 SvmNestedExit1;
WHV_X64_PENDING_SVM_NESTED_EXIT_EVENT2 SvmNestedExit2;
WHV_X64_PENDING_SVM_NESTED_EXIT_EVENT3 SvmNestedExit3;
WHV_X64_PENDING_VMX_NESTED_EXIT_EVENT0 VmxNestedExit0;
WHV_X64_PENDING_VMX_NESTED_EXIT_EVENT1 VmxNestedExit1;
WHV_X64_PENDING_VMX_NESTED_EXIT_EVENT2 VmxNestedExit2;
#endif
} WHV_REGISTER_VALUE;
C_ASSERT(sizeof(WHV_REGISTER_VALUE) == 16);
typedef enum WHV_CAPABILITY_CODE {
WHvCapabilityCodeHypervisorPresent = 0x00000000
,WHvCapabilityCodeFeatures = 0x00000001
,WHvCapabilityCodeExtendedVmExits = 0x00000002
#if defined(__x86_64__)
,WHvCapabilityCodeExceptionExitBitmap = 0x00000003
,WHvCapabilityCodeX64MsrExitBitmap = 0x00000004
#endif
,WHvCapabilityCodeGpaRangePopulateFlags = 0x00000005
,WHvCapabilityCodeSchedulerFeatures = 0x00000006
,WHvCapabilityCodeProcessorVendor = 0x00001000
,WHvCapabilityCodeProcessorFeatures = 0x00001001
,WHvCapabilityCodeProcessorClFlushSize = 0x00001002
#if defined(__x86_64__)
,WHvCapabilityCodeProcessorXsaveFeatures = 0x00001003
#endif
,WHvCapabilityCodeProcessorClockFrequency = 0x00001004
#if defined(__x86_64__)
,WHvCapabilityCodeInterruptClockFrequency = 0x00001005
#endif
,WHvCapabilityCodeProcessorFeaturesBanks = 0x00001006
,WHvCapabilityCodeProcessorFrequencyCap = 0x00001007
,WHvCapabilityCodeSyntheticProcessorFeaturesBanks = 0x00001008
#if defined(__x86_64__)
,WHvCapabilityCodeProcessorPerfmonFeatures = 0x00001009
#endif
,WHvCapabilityCodePhysicalAddressWidth = 0x0000100A
#if defined(__x86_64__)
,WHvCapabilityCodeVmxBasic = 0x00002000
,WHvCapabilityCodeVmxPinbasedCtls = 0x00002001
,WHvCapabilityCodeVmxProcbasedCtls = 0x00002002
,WHvCapabilityCodeVmxExitCtls = 0x00002003
,WHvCapabilityCodeVmxEntryCtls = 0x00002004
,WHvCapabilityCodeVmxMisc = 0x00002005
,WHvCapabilityCodeVmxCr0Fixed0 = 0x00002006
,WHvCapabilityCodeVmxCr0Fixed1 = 0x00002007
,WHvCapabilityCodeVmxCr4Fixed0 = 0x00002008
,WHvCapabilityCodeVmxCr4Fixed1 = 0x00002009
,WHvCapabilityCodeVmxVmcsEnum = 0x0000200A
,WHvCapabilityCodeVmxProcbasedCtls2 = 0x0000200B
,WHvCapabilityCodeVmxEptVpidCap = 0x0000200C
,WHvCapabilityCodeVmxTruePinbasedCtls = 0x0000200D
,WHvCapabilityCodeVmxTrueProcbasedCtls = 0x0000200E
,WHvCapabilityCodeVmxTrueExitCtls = 0x0000200F
,WHvCapabilityCodeVmxTrueEntryCtls = 0x00002010
#elif defined (__aarch64__)
,WHvCapabilityCodeGicLpiIntIdBits = 0x00002011
,WHvCapabilityCodeMaxSveVectorLength = 0x00002012
#endif
} WHV_CAPABILITY_CODE;
typedef union WHV_CAPABILITY_FEATURES {
__C89_NAMELESS struct {
UINT64 PartialUnmap : 1;
#if defined(__x86_64__)
UINT64 LocalApicEmulation : 1;
UINT64 Xsave : 1;
#else
UINT64 ReservedArm0 : 2;
#endif
UINT64 DirtyPageTracking : 1;
UINT64 SpeculationControl : 1;
#if defined(__x86_64__)
UINT64 ApicRemoteRead : 1;
#else
UINT64 ReservedArm1 : 1;
#endif
UINT64 IdleSuspend : 1;
UINT64 VirtualPciDeviceSupport : 1;
UINT64 IommuSupport : 1;
UINT64 VpHotAddRemove : 1;
UINT64 DeviceAccessTracking : 1;
#if defined(__x86_64__)
UINT64 ReservedX640 : 1;
#else
UINT64 Arm64Support : 1;
#endif
UINT64 Reserved : 52;
};
UINT64 AsUINT64;
} WHV_CAPABILITY_FEATURES;
C_ASSERT(sizeof(WHV_CAPABILITY_FEATURES) == sizeof(UINT64));
typedef union WHV_EXTENDED_VM_EXITS {
__C89_NAMELESS struct {
#if defined(__x86_64__)
UINT64 X64CpuidExit : 1;
UINT64 X64MsrExit : 1;
UINT64 ExceptionExit : 1;
UINT64 X64RdtscExit : 1;
UINT64 X64ApicSmiExitTrap : 1;
#else
UINT64 ReservedArm0 : 5;
#endif
UINT64 HypercallExit : 1;
#if defined(__x86_64__)
UINT64 X64ApicInitSipiExitTrap : 1;
UINT64 X64ApicWriteLint0ExitTrap : 1;
UINT64 X64ApicWriteLint1ExitTrap : 1;
UINT64 X64ApicWriteSvrExitTrap : 1;
#else
UINT64 ReservedArm1 : 4;
#endif
UINT64 UnknownSynicConnection : 1;
UINT64 RetargetUnknownVpciDevice : 1;
#if defined(__x86_64__)
UINT64 X64ApicWriteLdrExitTrap : 1;
UINT64 X64ApicWriteDfrExitTrap : 1;
#else
UINT64 ReservedArm2 : 2;
#endif
UINT64 GpaAccessFaultExit : 1;
UINT64 Reserved : 49;
};
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,
WHvProcessorVendorArm = 0x0010
} WHV_PROCESSOR_VENDOR;
#if defined(__x86_64__)
typedef union WHV_X64_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 UnrestrictedGuestSupport : 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 : 1;
UINT64 RdPidSupport : 1;
UINT64 UmipSupport : 1;
UINT64 MdsNoSupport : 1;
UINT64 MdClearSupport : 1;
UINT64 TaaNoSupport : 1;
UINT64 TsxCtrlSupport : 1;
UINT64 Reserved6 : 1;
};
UINT64 AsUINT64;
} WHV_X64_PROCESSOR_FEATURES, WHV_PROCESSOR_FEATURES;
C_ASSERT(sizeof(WHV_X64_PROCESSOR_FEATURES) == sizeof(UINT64));
typedef union WHV_X64_PROCESSOR_FEATURES1 {
__C89_NAMELESS struct {
UINT64 ACountMCountSupport : 1;
UINT64 TscInvariantSupport : 1;
UINT64 ClZeroSupport : 1;
UINT64 RdpruSupport : 1;
UINT64 La57Support : 1;
UINT64 MbecSupport : 1;
UINT64 NestedVirtSupport : 1;
UINT64 PsfdSupport: 1;
UINT64 CetSsSupport : 1;
UINT64 CetIbtSupport : 1;
UINT64 VmxExceptionInjectSupport : 1;
UINT64 Reserved2 : 1;
UINT64 UmwaitTpauseSupport : 1;
UINT64 MovdiriSupport : 1;
UINT64 Movdir64bSupport : 1;
UINT64 CldemoteSupport : 1;
UINT64 SerializeSupport : 1;
UINT64 TscDeadlineTmrSupport : 1;
UINT64 TscAdjustSupport : 1;
UINT64 FZLRepMovsb : 1;
UINT64 FSRepStosb : 1;
UINT64 FSRepCmpsb : 1;
UINT64 TsxLdTrkSupport : 1;
UINT64 VmxInsOutsExitInfoSupport : 1;
UINT64 Reserved3 : 1;
UINT64 SbdrSsdpNoSupport : 1;
UINT64 FbsdpNoSupport : 1;
UINT64 PsdpNoSupport : 1;
UINT64 FbClearSupport : 1;
UINT64 BtcNoSupport : 1;
UINT64 IbpbRsbFlushSupport : 1;
UINT64 StibpAlwaysOnSupport : 1;
UINT64 PerfGlobalCtrlSupport : 1;
UINT64 NptExecuteOnlySupport : 1;
UINT64 NptADFlagsSupport : 1;
UINT64 Npt1GbPageSupport : 1;
UINT64 Reserved4 : 1;
UINT64 Reserved5 : 1;
UINT64 Reserved6 : 1;
UINT64 Reserved7 : 1;
UINT64 CmpccxaddSupport : 1;
UINT64 Reserved8 : 1;
UINT64 Reserved9 : 1;
UINT64 Reserved10 : 1;
UINT64 Reserved11 : 1;
UINT64 PrefetchISupport : 1;
UINT64 Sha512Support : 1;
UINT64 Reserved12 : 1;
UINT64 Reserved13 : 1;
UINT64 Reserved14 : 1;
UINT64 SM3Support : 1;
UINT64 SM4Support : 1;
UINT64 Reserved15 : 1;
UINT64 Reserved16 : 1;
UINT64 SbpbSupported : 1;
UINT64 IbpbBrTypeSupported : 1;
UINT64 SrsoNoSupported : 1;
UINT64 SrsoUserKernelNoSupported : 1;
UINT64 Reserved17 : 1;
UINT64 Reserved18 : 1;
UINT64 Reserved19 : 1;
UINT64 Reserved20 : 3;
};
UINT64 AsUINT64;
} WHV_X64_PROCESSOR_FEATURES1, WHV_PROCESSOR_FEATURES1;
C_ASSERT(sizeof(WHV_X64_PROCESSOR_FEATURES1) == sizeof(UINT64));
#elif defined(__aarch64__)
typedef union WHV_ARM64_PROCESSOR_FEATURES {
__C89_NAMELESS struct {
UINT64 Asid16 : 1;
UINT64 TGran16 : 1;
UINT64 TGran64 : 1;
UINT64 Haf : 1;
UINT64 Hdbs : 1;
UINT64 Pan : 1;
UINT64 AtS1E1 : 1;
UINT64 Uao : 1;
UINT64 El0Aarch32 : 1;
UINT64 Fp : 1;
UINT64 FpHp : 1;
UINT64 AdvSimd : 1;
UINT64 AdvSimdHp : 1;
UINT64 GicV3V4 : 1;
UINT64 GicV41 : 1;
UINT64 Ras : 1;
UINT64 PmuV3 : 1;
UINT64 PmuV3ArmV81 : 1;
UINT64 PmuV3ArmV84 : 1;
UINT64 PmuV3ArmV85 : 1;
UINT64 Aes : 1;
UINT64 PolyMul : 1;
UINT64 Sha1 : 1;
UINT64 Sha256 : 1;
UINT64 Sha512 : 1;
UINT64 Crc32 : 1;
UINT64 Atomic : 1;
UINT64 Rdm : 1;
UINT64 Sha3 : 1;
UINT64 Sm3 : 1;
UINT64 Sm4 : 1;
UINT64 Dp : 1;
UINT64 Fhm : 1;
UINT64 DcCvap : 1;
UINT64 DcCvadp : 1;
UINT64 ApaBase : 1;
UINT64 ApaEp : 1;
UINT64 ApaEp2 : 1;
UINT64 ApaEp2Fp : 1;
UINT64 ApaEp2Fpc : 1;
UINT64 Jscvt : 1;
UINT64 Fcma : 1;
UINT64 RcpcV83 : 1;
UINT64 RcpcV84 : 1;
UINT64 Gpa : 1;
UINT64 L1ipPipt : 1;
UINT64 DzPermitted : 1;
UINT64 Ssbs : 1;
UINT64 SsbsRw : 1;
UINT64 Reserved49 : 1;
UINT64 Reserved50 : 1;
UINT64 Reserved51 : 1;
UINT64 Reserved52 : 1;
UINT64 Csv2 : 1;
UINT64 Csv3 : 1;
UINT64 Sb : 1;
UINT64 Idc : 1;
UINT64 Dic : 1;
UINT64 TlbiOs : 1;
UINT64 TlbiOsRange : 1;
UINT64 FlagsM : 1;
UINT64 FlagsM2 : 1;
UINT64 Bf16 : 1;
UINT64 Ebf16 : 1;
};
UINT64 AsUINT64;
} WHV_ARM64_PROCESSOR_FEATURES, WHV_PROCESSOR_FEATURES;
typedef union WHV_ARM64_PROCESSOR_FEATURES1 {
__C89_NAMELESS struct {
UINT64 SveBf16 : 1;
UINT64 SveEbf16 : 1;
UINT64 I8mm : 1;
UINT64 SveI8mm : 1;
UINT64 Frintts : 1;
UINT64 Specres : 1;
UINT64 Reserved6 : 1;
UINT64 Rpres : 1;
UINT64 Exs : 1;
UINT64 SpecSei : 1;
UINT64 Ets : 1;
UINT64 Afp : 1;
UINT64 Iesb : 1;
UINT64 Rng : 1;
UINT64 Lse2 : 1;
UINT64 Idst : 1;
UINT64 Reserved16 : 1;
UINT64 Reserved17 : 1;
UINT64 Reserved18 : 1;
UINT64 Reserved19 : 1;
UINT64 Reserved20 : 1;
UINT64 Reserved21 : 1;
UINT64 Ccidx : 1;
UINT64 Reserved23 : 1;
UINT64 Reserved24 : 1;
UINT64 Reserved25 : 1;
UINT64 Reserved26 : 1;
UINT64 Reserved27 : 1;
UINT64 Reserved28 : 1;
UINT64 Reserved29 : 1;
UINT64 Reserved30 : 1;
UINT64 Reserved31 : 1;
UINT64 Reserved32 : 1;
UINT64 Reserved33 : 1;
UINT64 Reserved34 : 1;
UINT64 TtCnp : 1;
UINT64 Hpds : 1;
UINT64 Sve : 1;
UINT64 SveV2 : 1;
UINT64 SveV2P1 : 1;
UINT64 SpecFpacc : 1;
UINT64 SveAes : 1;
UINT64 SveBitPerm : 1;
UINT64 SveSha3 : 1;
UINT64 SveSm4 : 1;
UINT64 E0PD : 1;
UINT64 Reserved : 8;
};
UINT64 AsUINT64;
} WHV_ARM64_PROCESSOR_FEATURES1, WHV_PROCESSOR_FEATURES1;
#endif /* __x86_64__ || __aarch64__ */
#define WHV_PROCESSOR_FEATURES_BANKS_COUNT 2
typedef struct WHV_PROCESSOR_FEATURES_BANKS {
UINT32 BanksCount;
UINT32 Reserved0;
__C89_NAMELESS union {
__C89_NAMELESS struct {
WHV_PROCESSOR_FEATURES Bank0;
WHV_PROCESSOR_FEATURES1 Bank1;
};
UINT64 AsUINT64[WHV_PROCESSOR_FEATURES_BANKS_COUNT];
};
} WHV_PROCESSOR_FEATURES_BANKS;
C_ASSERT(sizeof(WHV_PROCESSOR_FEATURES_BANKS) == sizeof(UINT64) * (WHV_PROCESSOR_FEATURES_BANKS_COUNT + 1));
typedef union WHV_SYNTHETIC_PROCESSOR_FEATURES {
__C89_NAMELESS struct {
UINT64 HypervisorPresent : 1;
UINT64 Hv1 : 1;
UINT64 AccessVpRunTimeReg : 1;
UINT64 AccessPartitionReferenceCounter : 1;
UINT64 AccessSynicRegs : 1;
UINT64 AccessSyntheticTimerRegs : 1;
UINT64 AccessIntrCtrlRegs : 1;
UINT64 AccessHypercallRegs : 1;
UINT64 AccessVpIndex : 1;
UINT64 AccessPartitionReferenceTsc : 1;
#ifdef __x86_64__
UINT64 AccessGuestIdleReg : 1;
UINT64 AccessFrequencyRegs : 1;
#else
UINT64 ReservedZ10 : 1;
UINT64 ReservedZ11 : 1;
#endif
UINT64 ReservedZ12 : 1;
UINT64 ReservedZ13 : 1;
UINT64 ReservedZ14 : 1;
#ifdef __x86_64__
UINT64 EnableExtendedGvaRangesForFlushVirtualAddressList : 1;
#else
UINT64 ReservedZ15 : 1;
#endif
UINT64 ReservedZ16 : 1;
UINT64 ReservedZ17 : 1;
UINT64 FastHypercallOutput : 1;
UINT64 ReservedZ19 : 1;
UINT64 ReservedZ20 : 1;
UINT64 ReservedZ21 : 1;
UINT64 DirectSyntheticTimers : 1;
UINT64 ReservedZ23 : 1;
UINT64 ExtendedProcessorMasks : 1;
UINT64 TbFlushHypercalls : 1;
UINT64 SyntheticClusterIpi : 1;
UINT64 NotifyLongSpinWait : 1;
UINT64 QueryNumaDistance : 1;
UINT64 SignalEvents : 1;
UINT64 RetargetDeviceInterrupt : 1;
#ifdef __x86_64__
UINT64 RestoreTime : 1;
UINT64 EnlightenedVmcs : 1;
UINT64 NestedDebugCtl : 1;
UINT64 SyntheticTimeUnhaltedTimer : 1;
UINT64 IdleSpecCtrl : 1;
#else
UINT64 ReservedZ31 : 1;
UINT64 ReservedZ32 : 1;
UINT64 ReservedZ33 : 1;
UINT64 ReservedZ34 : 1;
UINT64 ReservedZ35 : 1;
#endif
UINT64 ReservedZ36 : 1;
UINT64 WakeVps : 1;
UINT64 AccessVpRegs : 1;
#ifdef __aarch64__
UINT64 SyncContext : 1;
#else
UINT64 ReservedZ39 : 1;
#endif
UINT64 ReservedZ40 : 1;
UINT64 ReservedZ41 : 1;
UINT64 ReservedZ42 : 1;
UINT64 ReservedZ43 : 1;
UINT64 ReservedZ44 : 1;
UINT64 Reserved : 19;
};
UINT64 AsUINT64;
} WHV_SYNTHETIC_PROCESSOR_FEATURES;
C_ASSERT(sizeof(WHV_SYNTHETIC_PROCESSOR_FEATURES) == 8);
#define WHV_SYNTHETIC_PROCESSOR_FEATURES_BANKS_COUNT 1
typedef struct WHV_SYNTHETIC_PROCESSOR_FEATURES_BANKS {
UINT32 BanksCount;
UINT32 Reserved0;
__C89_NAMELESS union {
__C89_NAMELESS struct {
WHV_SYNTHETIC_PROCESSOR_FEATURES Bank0;
};
UINT64 AsUINT64[WHV_SYNTHETIC_PROCESSOR_FEATURES_BANKS_COUNT];
};
} WHV_SYNTHETIC_PROCESSOR_FEATURES_BANKS;
C_ASSERT(sizeof(WHV_SYNTHETIC_PROCESSOR_FEATURES_BANKS) == 16);
typedef UINT8 WHV_VTL;
#define WHV_VTL_ALL 0xF
typedef union WHV_INPUT_VTL {
UINT8 AsUINT8;
__C89_NAMELESS struct {
UINT8 TargetVtl : 4;
UINT8 UseTargetVtl : 1;
UINT8 Reserved : 3;
};
} WHV_INPUT_VTL;
typedef union WHV_ENABLE_PARTITION_VTL_FLAGS {
UINT8 AsUINT8;
__C89_NAMELESS struct {
UINT8 EnableMbec : 1;
UINT8 EnableSupervisorShadowStack : 1;
UINT8 EnableHardwareHvpt : 1;
UINT8 Reserved : 5;
};
} WHV_ENABLE_PARTITION_VTL_FLAGS;
typedef union WHV_DISABLE_PARTITION_VTL_FLAGS {
UINT8 AsUINT8;
__C89_NAMELESS struct {
UINT8 ScrubOnly : 1;
UINT8 Reserved : 7;
};
} WHV_DISABLE_PARTITION_VTL_FLAGS;
typedef struct WHV_INITIAL_VP_CONTEXT {
#if defined(__aarch64__)
UINT64 Pc;
UINT64 Sp_ELh;
UINT64 SCTLR_EL1;
UINT64 MAIR_EL1;
UINT64 TCR_EL1;
UINT64 VBAR_EL1;
UINT64 TTBR0_EL1;
UINT64 TTBR1_EL1;
UINT64 X18;
#else
UINT64 Rip;
UINT64 Rsp;
UINT64 Rflags;
WHV_X64_SEGMENT_REGISTER Cs;
WHV_X64_SEGMENT_REGISTER Ds;
WHV_X64_SEGMENT_REGISTER Es;
WHV_X64_SEGMENT_REGISTER Fs;
WHV_X64_SEGMENT_REGISTER Gs;
WHV_X64_SEGMENT_REGISTER Ss;
WHV_X64_SEGMENT_REGISTER Tr;
WHV_X64_SEGMENT_REGISTER Ldtr;
WHV_X64_TABLE_REGISTER Idtr;
WHV_X64_TABLE_REGISTER Gdtr;
UINT64 Efer;
UINT64 Cr0;
UINT64 Cr3;
UINT64 Cr4;
UINT64 MsrCrPat;
#endif
} WHV_INITIAL_VP_CONTEXT;
typedef union WHV_DISABLE_VP_VTL_FLAGS {
UINT8 AsUINT8;
__C89_NAMELESS struct {
UINT8 ScrubOnly : 1;
UINT8 Reserved : 7;
};
} WHV_DISABLE_VP_VTL_FLAGS;
typedef VOID* WHV_PARTITION_HANDLE;
typedef enum WHV_PARTITION_PROPERTY_CODE {
WHvPartitionPropertyCodeExtendedVmExits = 0x00000001,
#if defined(__x86_64__)
WHvPartitionPropertyCodeExceptionExitBitmap = 0x00000002,
#endif
WHvPartitionPropertyCodeSeparateSecurityDomain = 0x00000003,
WHvPartitionPropertyCodeNestedVirtualization = 0x00000004,
#if defined(__x86_64__)
WHvPartitionPropertyCodeX64MsrExitBitmap = 0x00000005,
#endif
WHvPartitionPropertyCodePrimaryNumaNode = 0x00000006,
WHvPartitionPropertyCodeCpuReserve = 0x00000007,
WHvPartitionPropertyCodeCpuCap = 0x00000008,
WHvPartitionPropertyCodeCpuWeight = 0x00000009,
WHvPartitionPropertyCodeCpuGroupId = 0x0000000A,
WHvPartitionPropertyCodeProcessorFrequencyCap = 0x0000000B,
WHvPartitionPropertyCodeAllowDeviceAssignment = 0x0000000C,
WHvPartitionPropertyCodeDisableSmt = 0x0000000D,
WHvPartitionPropertyCodeProcessorFeatures = 0x00001001,
WHvPartitionPropertyCodeProcessorClFlushSize = 0x00001002,
#if defined(__x86_64__)
WHvPartitionPropertyCodeCpuidExitList = 0x00001003,
WHvPartitionPropertyCodeCpuidResultList = 0x00001004,
WHvPartitionPropertyCodeLocalApicEmulationMode = 0x00001005,
WHvPartitionPropertyCodeProcessorXsaveFeatures = 0x00001006,
#endif
WHvPartitionPropertyCodeProcessorClockFrequency = 0x00001007,
#if defined(__x86_64__)
WHvPartitionPropertyCodeInterruptClockFrequency = 0x00001008,
WHvPartitionPropertyCodeApicRemoteReadSupport = 0x00001009,
#endif
WHvPartitionPropertyCodeProcessorFeaturesBanks = 0x0000100A,
WHvPartitionPropertyCodeReferenceTime = 0x0000100B,
WHvPartitionPropertyCodeSyntheticProcessorFeaturesBanks = 0x0000100C,
#if defined(__x86_64__)
WHvPartitionPropertyCodeCpuidResultList2 = 0x0000100D,
WHvPartitionPropertyCodeProcessorPerfmonFeatures = 0x0000100E,
WHvPartitionPropertyCodeMsrActionList = 0x0000100F,
WHvPartitionPropertyCodeUnimplementedMsrAction = 0x00001010,
#endif
WHvPartitionPropertyCodePhysicalAddressWidth = 0x00001011,
#if defined(__aarch64__)
WHvPartitionPropertyCodeArm64IcParameters = 0x00001012,
#endif
WHvPartitionPropertyCodeProcessorCount = 0x00001fff
} WHV_PARTITION_PROPERTY_CODE;
#if defined(__x86_64__)
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 Avx512Bf16Support : 1;
UINT64 Avx512Vp2IntersectSupport : 1;
UINT64 Avx512Fp16Support : 1;
UINT64 XfdSupport : 1;
UINT64 AmxTileSupport : 1;
UINT64 AmxBf16Support : 1;
UINT64 AmxInt8Support : 1;
UINT64 AvxVnniSupport : 1;
UINT64 AvxIfmaSupport : 1;
UINT64 AvxNeConvertSupport : 1;
UINT64 AvxVnniInt8Support : 1;
UINT64 AvxVnniInt16Support : 1;
UINT64 Avx10_1_256Support : 1;
UINT64 Avx10_1_512Support : 1;
UINT64 AmxFp16Support : 1;
UINT64 Reserved : 26;
};
UINT64 AsUINT64;
} WHV_PROCESSOR_XSAVE_FEATURES, *PWHV_PROCESSOR_XSAVE_FEATURES;
C_ASSERT(sizeof(WHV_PROCESSOR_XSAVE_FEATURES) == sizeof(UINT64));
typedef union WHV_PROCESSOR_PERFMON_FEATURES {
__C89_NAMELESS struct {
UINT64 PmuSupport : 1;
UINT64 LbrSupport : 1;
UINT64 Reserved : 62;
};
UINT64 AsUINT64;
} WHV_PROCESSOR_PERFMON_FEATURES, *PWHV_PROCESSOR_PERFMON_FEATURES;
C_ASSERT(sizeof(WHV_PROCESSOR_PERFMON_FEATURES) == 8);
typedef union WHV_X64_MSR_EXIT_BITMAP {
UINT64 AsUINT64;
__C89_NAMELESS struct {
UINT64 UnhandledMsrs : 1;
UINT64 TscMsrWrite : 1;
UINT64 TscMsrRead : 1;
UINT64 ApicBaseMsrWrite : 1;
UINT64 MiscEnableMsrRead : 1;
UINT64 McUpdatePatchLevelMsrRead : 1;
UINT64 Reserved : 58;
};
} WHV_X64_MSR_EXIT_BITMAP;
C_ASSERT(sizeof(WHV_X64_MSR_EXIT_BITMAP) == sizeof(UINT64));
#endif /* defined(__x86_64__) */
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
#if defined(__x86_64__)
,WHvTranslateGvaFlagPrivilegeExempt = 0x00000008
#endif
,WHvTranslateGvaFlagSetPageTableBits = 0x00000010
#if defined(__x86_64__)
,WHvTranslateGvaFlagEnforceSmap = 0x00000100
,WHvTranslateGvaFlagOverrideSmap = 0x00000200
#endif
} WHV_TRANSLATE_GVA_FLAGS;
DEFINE_ENUM_FLAG_OPERATORS(WHV_TRANSLATE_GVA_FLAGS);
typedef union WHV_TRANSLATE_GVA_2_FLAGS {
__C89_NAMELESS struct {
UINT64 ValidateRead : 1;
UINT64 ValidateWrite : 1;
UINT64 ValidateExecute : 1;
#if defined(__x86_64__)
UINT64 PrivilegeExempt : 1;
#else
UINT64 Reserved0 : 1;
#endif
UINT64 SetPageTableBits : 1;
UINT64 Reserved1 : 3;
#if defined(__x86_64__)
UINT64 EnforceSmap : 1;
UINT64 OverrideSmap : 1;
#else
UINT64 Reserved2 : 1;
UINT64 Reserved3 : 1;
#endif
UINT64 Reserved4 : 46;
UINT64 InputVtl : 8;
};
UINT64 AsUINT64;
} WHV_TRANSLATE_GVA_2_FLAGS;
C_ASSERT(sizeof(WHV_TRANSLATE_GVA_2_FLAGS) == 8);
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;
C_ASSERT(sizeof(WHV_TRANSLATE_GVA_RESULT) == 8);
#define WHV_READ_WRITE_GPA_RANGE_MAX_SIZE 16
typedef struct WHV_MEMORY_RANGE_ENTRY {
UINT64 GuestAddress;
UINT64 SizeInBytes;
} WHV_MEMORY_RANGE_ENTRY;
C_ASSERT(sizeof(WHV_MEMORY_RANGE_ENTRY) == 16);
typedef union WHV_ADVISE_GPA_RANGE_POPULATE_FLAGS {
UINT32 AsUINT32;
__C89_NAMELESS struct {
UINT32 Prefetch:1;
UINT32 AvoidHardFaults:1;
UINT32 Reserved:30;
};
} WHV_ADVISE_GPA_RANGE_POPULATE_FLAGS;
C_ASSERT(sizeof(WHV_ADVISE_GPA_RANGE_POPULATE_FLAGS) == 4);
typedef enum WHV_MEMORY_ACCESS_TYPE {
WHvMemoryAccessRead = 0,
WHvMemoryAccessWrite = 1,
WHvMemoryAccessExecute = 2
} WHV_MEMORY_ACCESS_TYPE;
typedef struct WHV_ADVISE_GPA_RANGE_POPULATE {
WHV_ADVISE_GPA_RANGE_POPULATE_FLAGS Flags;
WHV_MEMORY_ACCESS_TYPE AccessType;
} WHV_ADVISE_GPA_RANGE_POPULATE;
C_ASSERT(sizeof(WHV_ADVISE_GPA_RANGE_POPULATE) == 8);
typedef union WHV_ADVISE_GPA_RANGE {
WHV_ADVISE_GPA_RANGE_POPULATE Populate;
} WHV_ADVISE_GPA_RANGE;
C_ASSERT(sizeof(WHV_ADVISE_GPA_RANGE) == 8);
typedef enum WHV_CACHE_TYPE {
WHvCacheTypeUncached = 0,
WHvCacheTypeWriteCombining = 1,
WHvCacheTypeWriteThrough = 4,
#ifdef __x86_64__
WHvCacheTypeWriteProtected = 5,
#endif
WHvCacheTypeWriteBack = 6
} WHV_CACHE_TYPE;
typedef union WHV_ACCESS_GPA_CONTROLS {
UINT64 AsUINT64;
__C89_NAMELESS struct {
WHV_CACHE_TYPE CacheType;
WHV_INPUT_VTL InputVtl;
UINT8 Reserved;
UINT16 Reserved1;
};
} WHV_ACCESS_GPA_CONTROLS;
C_ASSERT(sizeof(WHV_ACCESS_GPA_CONTROLS) == 8);
typedef struct WHV_CAPABILITY_PROCESSOR_FREQUENCY_CAP {
UINT32 IsSupported:1;
UINT32 Reserved:31;
UINT32 HighestFrequencyMhz;
UINT32 NominalFrequencyMhz;
UINT32 LowestFrequencyMhz;
UINT32 FrequencyStepMhz;
} WHV_CAPABILITY_PROCESSOR_FREQUENCY_CAP;
C_ASSERT(sizeof(WHV_CAPABILITY_PROCESSOR_FREQUENCY_CAP) == 20);
typedef union WHV_SCHEDULER_FEATURES {
__C89_NAMELESS struct {
UINT64 CpuReserve: 1;
UINT64 CpuCap: 1;
UINT64 CpuWeight: 1;
UINT64 CpuGroupId: 1;
UINT64 DisableSmt: 1;
UINT64 Reserved: 59;
};
UINT64 AsUINT64;
} WHV_SCHEDULER_FEATURES;
C_ASSERT(sizeof(WHV_SCHEDULER_FEATURES) == 8);
typedef union WHV_CAPABILITY {
WINBOOL HypervisorPresent;
WHV_CAPABILITY_FEATURES Features;
WHV_EXTENDED_VM_EXITS ExtendedVmExits;
WHV_PROCESSOR_VENDOR ProcessorVendor;
WHV_PROCESSOR_FEATURES ProcessorFeatures;
WHV_SYNTHETIC_PROCESSOR_FEATURES_BANKS SyntheticProcessorFeaturesBanks;
UINT8 ProcessorClFlushSize;
UINT64 ProcessorClockFrequency;
WHV_PROCESSOR_FEATURES_BANKS ProcessorFeaturesBanks;
WHV_ADVISE_GPA_RANGE_POPULATE_FLAGS GpaRangePopulateFlags;
WHV_CAPABILITY_PROCESSOR_FREQUENCY_CAP ProcessorFrequencyCap;
WHV_SCHEDULER_FEATURES SchedulerFeatures;
UINT32 PhysicalAddressWidth;
UINT64 NestedFeatureRegister;
#if defined(__x86_64__)
WHV_PROCESSOR_XSAVE_FEATURES ProcessorXsaveFeatures;
UINT64 InterruptClockFrequency;
WHV_PROCESSOR_PERFMON_FEATURES ProcessorPerfmonFeatures;
WHV_X64_MSR_EXIT_BITMAP X64MsrExitBitmap;
UINT64 ExceptionExitBitmap;
#elif defined (__aarch64__)
UINT32 GicLpiIntIdBits;
UINT32 MaxSveVectorLength;
#endif
} WHV_CAPABILITY;
#if defined(__x86_64__)
typedef struct WHV_X64_CPUID_RESULT {
UINT32 Function;
UINT32 Reserved[3];
UINT32 Eax;
UINT32 Ebx;
UINT32 Ecx;
UINT32 Edx;
} WHV_X64_CPUID_RESULT;
C_ASSERT(sizeof(WHV_X64_CPUID_RESULT) == 32);
typedef enum WHV_X64_CPUID_RESULT2_FLAGS {
WHvX64CpuidResult2FlagSubleafSpecific = 0x00000001,
WHvX64CpuidResult2FlagVpSpecific = 0x00000002
} WHV_X64_CPUID_RESULT2_FLAGS;
DEFINE_ENUM_FLAG_OPERATORS(WHV_X64_CPUID_RESULT2_FLAGS);
typedef struct WHV_CPUID_OUTPUT {
UINT32 Eax;
UINT32 Ebx;
UINT32 Ecx;
UINT32 Edx;
} WHV_CPUID_OUTPUT;
C_ASSERT(sizeof(WHV_CPUID_OUTPUT) == 16);
typedef struct WHV_X64_CPUID_RESULT2 {
UINT32 Function;
UINT32 Index;
UINT32 VpIndex;
WHV_X64_CPUID_RESULT2_FLAGS Flags;
WHV_CPUID_OUTPUT Output;
WHV_CPUID_OUTPUT Mask;
} WHV_X64_CPUID_RESULT2;
C_ASSERT(sizeof(WHV_X64_CPUID_RESULT2) == 48);
typedef struct WHV_MSR_ACTION_ENTRY {
UINT32 Index;
UINT8 ReadAction;
UINT8 WriteAction;
UINT16 Reserved;
} WHV_MSR_ACTION_ENTRY;
C_ASSERT(sizeof(WHV_MSR_ACTION_ENTRY) == 8);
typedef enum WHV_MSR_ACTION {
WHvMsrActionArchitectureDefault = 0,
WHvMsrActionIgnoreWriteReadZero = 1,
WHvMsrActionExit = 2
} WHV_MSR_ACTION;
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,
WHvX64ExceptionTypeControlProtectionFault = 0x15
} WHV_EXCEPTION_TYPE;
typedef enum WHV_X64_LOCAL_APIC_EMULATION_MODE {
WHvX64LocalApicEmulationModeNone,
WHvX64LocalApicEmulationModeXApic,
WHvX64LocalApicEmulationModeX2Apic
} WHV_X64_LOCAL_APIC_EMULATION_MODE;
#elif defined(__aarch64__)
typedef enum WHV_ARM64_IC_EMULATION_MODE {
WHvArm64IcEmulationModeNone = 0,
WHvArm64IcEmulationModeGicV3
} WHV_ARM64_IC_EMULATION_MODE;
typedef UINT32 WHV_ARM64_INTERRUPT_VECTOR;
typedef struct WHV_ARM64_IC_GIC_V3_PARAMETERS {
WHV_GUEST_PHYSICAL_ADDRESS GicdBaseAddress;
WHV_GUEST_PHYSICAL_ADDRESS GitsTranslaterBaseAddress;
UINT32 Reserved;
UINT32 GicLpiIntIdBits;
WHV_ARM64_INTERRUPT_VECTOR GicPpiOverflowInterruptFromCntv;
WHV_ARM64_INTERRUPT_VECTOR GicPpiPerformanceMonitorsInterrupt;
UINT32 Reserved1[6];
} WHV_ARM64_IC_GIC_V3_PARAMETERS;
C_ASSERT(sizeof(WHV_ARM64_IC_GIC_V3_PARAMETERS) == 56);
typedef struct WHV_ARM64_IC_PARAMETERS {
WHV_ARM64_IC_EMULATION_MODE EmulationMode;
UINT32 Reserved;
__C89_NAMELESS union {
WHV_ARM64_IC_GIC_V3_PARAMETERS GicV3Parameters;
};
} WHV_ARM64_IC_PARAMETERS;
C_ASSERT(sizeof(WHV_ARM64_IC_PARAMETERS) == 64);
#endif /* defined(__x86_64__) || defined(__aarch64__) */
typedef union WHV_PARTITION_PROPERTY {
WHV_EXTENDED_VM_EXITS ExtendedVmExits;
WHV_PROCESSOR_FEATURES ProcessorFeatures;
WHV_SYNTHETIC_PROCESSOR_FEATURES_BANKS SyntheticProcessorFeaturesBanks;
UINT8 ProcessorClFlushSize;
UINT32 ProcessorCount;
WINBOOL SeparateSecurityDomain;
WINBOOL NestedVirtualization;
UINT64 ProcessorClockFrequency;
WHV_PROCESSOR_FEATURES_BANKS ProcessorFeaturesBanks;
UINT64 ReferenceTime;
USHORT PrimaryNumaNode;
UINT32 CpuReserve;
UINT32 CpuCap;
UINT32 CpuWeight;
UINT64 CpuGroupId;
UINT32 ProcessorFrequencyCap;
WINBOOL AllowDeviceAssignment;
WINBOOL DisableSmt;
UINT32 PhysicalAddressWidth;
#if defined(__x86_64__)
WHV_PROCESSOR_XSAVE_FEATURES ProcessorXsaveFeatures;
UINT32 CpuidExitList[1];
UINT64 ExceptionExitBitmap;
WINBOOL ApicRemoteRead;
WHV_X64_MSR_EXIT_BITMAP X64MsrExitBitmap;
WHV_PROCESSOR_PERFMON_FEATURES ProcessorPerfmonFeatures;
UINT64 InterruptClockFrequency;
WHV_X64_CPUID_RESULT CpuidResultList[1];
WHV_X64_CPUID_RESULT2 CpuidResultList2[1];
WHV_MSR_ACTION_ENTRY MsrActionList[1];
WHV_MSR_ACTION UnimplementedMsrAction;
WHV_X64_LOCAL_APIC_EMULATION_MODE LocalApicEmulationMode;
#elif defined(__aarch64__)
WHV_ARM64_IC_PARAMETERS Arm64IcParameters;
#endif
} WHV_PARTITION_PROPERTY;
#if defined(__x86_64__)
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,
WHvRunVpExitReasonSynicSintDeliverable = 0x0000000A,
WHvRunVpExitReasonX64MsrAccess = 0x00001000,
WHvRunVpExitReasonX64Cpuid = 0x00001001,
WHvRunVpExitReasonException = 0x00001002,
WHvRunVpExitReasonX64Rdtsc = 0x00001003,
WHvRunVpExitReasonX64ApicSmiTrap = 0x00001004,
WHvRunVpExitReasonHypercall = 0x00001005,
WHvRunVpExitReasonX64ApicInitSipiTrap = 0x00001006,
WHvRunVpExitReasonX64ApicWriteTrap = 0x00001007,
WHvRunVpExitReasonCanceled = 0x00002001
} WHV_RUN_VP_EXIT_REASON;
#elif defined(__aarch64__)
typedef enum WHV_RUN_VP_EXIT_REASON {
WHvRunVpExitReasonNone = 0x00000000,
WHvRunVpExitReasonUnmappedGpa = 0x80000000,
WHvRunVpExitReasonGpaIntercept = 0x80000001,
WHvRunVpExitReasonUnrecoverableException = 0x80000021,
WHvRunVpExitReasonInvalidVpRegisterValue = 0x80000020,
WHvRunVpExitReasonUnsupportedFeature = 0x80000022,
WHvRunVpExitReasonSynicSintDeliverable = 0x80000062,
WHvMessageTypeRegisterIntercept = 0x80010006,
WHvRunVpExitReasonArm64Reset = 0x8001000c,
WHvRunVpExitReasonHypercall = 0x80000050,
WHvRunVpExitReasonCanceled = 0xFFFFFFFF
} WHV_RUN_VP_EXIT_REASON;
#endif /* defined(__x86_64__) || defined(__aarch64__) */
#if defined(__x86_64__)
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_X64_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_X64_VP_EXIT_CONTEXT, WHV_VP_EXIT_CONTEXT;
C_ASSERT(sizeof(WHV_X64_VP_EXIT_CONTEXT) == 40);
typedef struct WHV_SYNIC_SINT_DELIVERABLE_CONTEXT {
UINT16 DeliverableSints;
UINT16 Reserved1;
UINT32 Reserved2;
} WHV_SYNIC_SINT_DELIVERABLE_CONTEXT;
C_ASSERT(sizeof(WHV_SYNIC_SINT_DELIVERABLE_CONTEXT) == 8);
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;
C_ASSERT(sizeof(WHV_MEMORY_ACCESS_INFO) == 4);
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;
C_ASSERT(sizeof(WHV_MEMORY_ACCESS_CONTEXT) == 40);
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) == 4);
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;
C_ASSERT(sizeof(WHV_X64_IO_PORT_ACCESS_CONTEXT) == 96);
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;
C_ASSERT(sizeof(WHV_X64_MSR_ACCESS_CONTEXT) == 24);
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;
C_ASSERT(sizeof(WHV_X64_CPUID_ACCESS_CONTEXT) == 64);
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) == 4);
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;
C_ASSERT(sizeof(WHV_VP_EXCEPTION_CONTEXT) == 40);
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;
C_ASSERT(sizeof(WHV_X64_UNSUPPORTED_FEATURE_CONTEXT) == 16);
#elif defined(__aarch64__)
typedef union WHV_VP_EXECUTION_STATE {
UINT16 AsUINT16;
__C89_NAMELESS struct {
UINT16 Cpl : 2;
UINT16 DebugActive : 1;
UINT16 InterruptionPending : 1;
UINT16 Vtl : 4;
UINT16 VirtualizationFaultActive : 1;
UINT16 Reserved : 7;
};
} WHV_VP_EXECUTION_STATE;
C_ASSERT(sizeof(WHV_VP_EXECUTION_STATE) == 2);
typedef struct WHV_INTERCEPT_MESSAGE_HEADER {
UINT32 VpIndex;
UINT8 InstructionLength;
UINT8 InterceptAccessType;
WHV_VP_EXECUTION_STATE ExecutionState;
UINT64 Pc;
UINT64 Cpsr;
} WHV_INTERCEPT_MESSAGE_HEADER;
C_ASSERT(sizeof(WHV_INTERCEPT_MESSAGE_HEADER) == 24);
typedef union WHV_MEMORY_ACCESS_INFO {
UINT8 AsUINT8;
__C89_NAMELESS struct {
UINT8 GvaValid : 1;
UINT8 GvaGpaValid : 1;
UINT8 HypercallOutputPending : 1;
UINT8 Reserved : 5;
};
} WHV_MEMORY_ACCESS_INFO;
typedef struct WHV_MEMORY_ACCESS_CONTEXT {
WHV_INTERCEPT_MESSAGE_HEADER Header;
UINT32 Reserved0;
UINT8 InstructionByteCount;
WHV_MEMORY_ACCESS_INFO AccessInfo;
UINT16 Reserved1;
UINT8 InstructionBytes[4];
UINT32 Reserved2;
UINT64 Gva;
UINT64 Gpa;
UINT64 Syndrome;
} WHV_MEMORY_ACCESS_CONTEXT;
C_ASSERT(sizeof(WHV_MEMORY_ACCESS_CONTEXT) == 64);
typedef struct WHV_UNRECOVERABLE_EXCEPTION_CONTEXT {
WHV_INTERCEPT_MESSAGE_HEADER Header;
} WHV_UNRECOVERABLE_EXCEPTION_CONTEXT;
C_ASSERT(sizeof(WHV_UNRECOVERABLE_EXCEPTION_CONTEXT) == 24);
typedef struct WHV_INVALID_VP_REGISTER_CONTEXT {
UINT32 VpIndex;
UINT32 Reserved;
} WHV_INVALID_VP_REGISTER_CONTEXT;
C_ASSERT(sizeof(WHV_INVALID_VP_REGISTER_CONTEXT) == 8);
typedef struct WHV_SYNIC_SINT_DELIVERABLE_CONTEXT {
WHV_INTERCEPT_MESSAGE_HEADER Header;
UINT16 DeliverableSints;
UINT16 Reserved1;
UINT32 Reserved2;
} WHV_SYNIC_SINT_DELIVERABLE_CONTEXT;
C_ASSERT(sizeof(WHV_SYNIC_SINT_DELIVERABLE_CONTEXT) == 32);
typedef union WHV_REGISTER_ACCESS_INFO {
WHV_REGISTER_VALUE SourceValue;
WHV_REGISTER_NAME DestinationRegister;
} WHV_REGISTER_ACCESS_INFO;
typedef struct WHV_REGISTER_CONTEXT {
WHV_INTERCEPT_MESSAGE_HEADER Header;
__C89_NAMELESS struct {
UINT8 IsMemoryOp:1;
UINT8 Reserved:7;
};
UINT8 Reserved8;
UINT16 Reserved16;
WHV_REGISTER_NAME RegisterName;
WHV_REGISTER_ACCESS_INFO AccessInfo;
} WHV_REGISTER_CONTEXT;
C_ASSERT(sizeof(WHV_REGISTER_CONTEXT) == 48);
typedef enum WHV_ARM64_RESET_TYPE {
WHvArm64ResetTypePowerOff = 0,
WHvArm64ResetTypeReboot
} WHV_ARM64_RESET_TYPE;
typedef struct WHV_ARM64_RESET_CONTEXT {
WHV_INTERCEPT_MESSAGE_HEADER Header;
WHV_ARM64_RESET_TYPE ResetType;
UINT32 Reserved;
} WHV_ARM64_RESET_CONTEXT;
C_ASSERT(sizeof(WHV_ARM64_RESET_CONTEXT) == 32);
#endif /* defined(__x86_64__) || defined(__aarch64__) */
typedef enum WHV_RUN_VP_CANCEL_REASON {
WHvRunVpCancelReasonUser = 0
} WHV_RUN_VP_CANCEL_REASON;
#define WhvRunVpCancelReasonUser WHvRunVpCancelReasonUser
typedef struct WHV_RUN_VP_CANCELED_CONTEXT {
WHV_RUN_VP_CANCEL_REASON CancelReason;
} WHV_RUN_VP_CANCELED_CONTEXT;
C_ASSERT(sizeof(WHV_RUN_VP_CANCELED_CONTEXT) == 4);
#if defined(__x86_64__)
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;
C_ASSERT(sizeof(WHV_X64_INTERRUPTION_DELIVERABLE_CONTEXT) == 4);
typedef struct WHV_X64_APIC_EOI_CONTEXT {
UINT32 InterruptVector;
} WHV_X64_APIC_EOI_CONTEXT;
C_ASSERT(sizeof(WHV_X64_APIC_EOI_CONTEXT) == 4);
typedef union WHV_X64_RDTSC_INFO {
__C89_NAMELESS struct {
UINT64 IsRdtscp : 1;
UINT64 Reserved : 63;
};
UINT64 AsUINT64;
} WHV_X64_RDTSC_INFO;
C_ASSERT(sizeof(WHV_X64_RDTSC_INFO) == 8);
typedef struct WHV_X64_RDTSC_CONTEXT {
UINT64 TscAux;
UINT64 VirtualOffset;
UINT64 Tsc;
UINT64 ReferenceTime;
WHV_X64_RDTSC_INFO RdtscInfo;
} WHV_X64_RDTSC_CONTEXT;
C_ASSERT(sizeof(WHV_X64_RDTSC_CONTEXT) == 40);
typedef struct WHV_X64_APIC_SMI_CONTEXT {
UINT64 ApicIcr;
} WHV_X64_APIC_SMI_CONTEXT;
C_ASSERT(sizeof(WHV_X64_APIC_SMI_CONTEXT) == 8);
#endif /* defined(__x86_64__) */
#if defined(__x86_64__)
#define WHV_HYPERCALL_CONTEXT_MAX_XMM_REGISTERS 6
typedef struct WHV_X64_HYPERCALL_CONTEXT {
UINT64 Rax;
UINT64 Rbx;
UINT64 Rcx;
UINT64 Rdx;
UINT64 R8;
UINT64 Rsi;
UINT64 Rdi;
UINT64 Reserved0;
WHV_UINT128 XmmRegisters[WHV_HYPERCALL_CONTEXT_MAX_XMM_REGISTERS];
UINT64 Reserved1[2];
} WHV_X64_HYPERCALL_CONTEXT, WHV_HYPERCALL_CONTEXT, *PWHV_HYPERCALL_CONTEXT;
C_ASSERT(sizeof(WHV_HYPERCALL_CONTEXT) == 176);
#elif defined(__aarch64__)
typedef struct WHV_ARM64_HYPERCALL_CONTEXT {
WHV_INTERCEPT_MESSAGE_HEADER Header;
UINT16 Immediate;
UINT16 Reserved1;
UINT32 Reserved2;
UINT64 X[18];
} WHV_ARM64_HYPERCALL_CONTEXT, WHV_HYPERCALL_CONTEXT, *PWHV_HYPERCALL_CONTEXT;
#endif /* defined(__x86_64__) || defined(__aarch64__) */
#if defined(__x86_64__)
typedef struct WHV_X64_APIC_INIT_SIPI_CONTEXT {
UINT64 ApicIcr;
} WHV_X64_APIC_INIT_SIPI_CONTEXT;
C_ASSERT(sizeof(WHV_X64_APIC_INIT_SIPI_CONTEXT) == 8);
typedef enum WHV_X64_APIC_WRITE_TYPE {
WHvX64ApicWriteTypeLdr = 0xD0,
WHvX64ApicWriteTypeDfr = 0xE0,
WHvX64ApicWriteTypeSvr = 0xF0,
WHvX64ApicWriteTypeLint0 = 0x350,
WHvX64ApicWriteTypeLint1 = 0x360
} WHV_X64_APIC_WRITE_TYPE;
typedef struct WHV_X64_APIC_WRITE_CONTEXT {
WHV_X64_APIC_WRITE_TYPE Type;
UINT32 Reserved;
UINT64 WriteValue;
} WHV_X64_APIC_WRITE_CONTEXT;
C_ASSERT(sizeof(WHV_X64_APIC_WRITE_CONTEXT) == 16);
#endif /* defined(__x86_64__) */
typedef struct WHV_RUN_VP_EXIT_CONTEXT {
WHV_RUN_VP_EXIT_REASON ExitReason;
UINT32 Reserved;
#if defined(__x86_64__)
WHV_VP_EXIT_CONTEXT VpContext;
#elif defined(__aarch64__)
UINT64 Reserved1;
#endif
__C89_NAMELESS union {
WHV_MEMORY_ACCESS_CONTEXT MemoryAccess;
WHV_RUN_VP_CANCELED_CONTEXT CancelReason;
WHV_HYPERCALL_CONTEXT Hypercall;
WHV_SYNIC_SINT_DELIVERABLE_CONTEXT SynicSintDeliverable;
#if defined(__x86_64__)
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_X64_APIC_EOI_CONTEXT ApicEoi;
WHV_X64_RDTSC_CONTEXT ReadTsc;
WHV_X64_APIC_SMI_CONTEXT ApicSmi;
WHV_X64_APIC_INIT_SIPI_CONTEXT ApicInitSipi;
WHV_X64_APIC_WRITE_CONTEXT ApicWrite;
UINT64 AsUINT64[22];
#elif defined(__aarch64__)
WHV_UNRECOVERABLE_EXCEPTION_CONTEXT UnrecoverableException;
WHV_INVALID_VP_REGISTER_CONTEXT InvalidVpRegister;
WHV_REGISTER_CONTEXT Register;
WHV_ARM64_RESET_CONTEXT Arm64Reset;
UINT64 AsUINT64[32];
#endif
};
} WHV_RUN_VP_EXIT_CONTEXT;
#if defined(__x86_64__)
C_ASSERT(sizeof(WHV_RUN_VP_EXIT_CONTEXT) == 224);
#elif defined(__aarch64__)
C_ASSERT(sizeof(WHV_RUN_VP_EXIT_CONTEXT) == 272);
#endif
#if defined(__x86_64__)
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 TargetVtl : 8;
UINT64 Reserved : 40;
UINT32 Destination;
UINT32 Vector;
} WHV_INTERRUPT_CONTROL;
C_ASSERT(sizeof(WHV_INTERRUPT_CONTROL) == 16);
#elif defined(__aarch64__)
typedef enum WHV_INTERRUPT_TYPE {
WHvArm64InterruptTypeFixed = 0x0000,
WHvArm64InterruptTypeMaximum = 0x0008
} WHV_INTERRUPT_TYPE;
typedef union WHV_INTERRUPT_CONTROL2 {
UINT64 AsUINT64;
__C89_NAMELESS struct {
WHV_INTERRUPT_TYPE InterruptType;
UINT32 Reserved1 : 2;
UINT32 Asserted : 1;
UINT32 Retarget : 1;
UINT32 Reserved2 : 28;
};
} WHV_INTERRUPT_CONTROL2;
C_ASSERT(sizeof(WHV_INTERRUPT_CONTROL2) == 8);
typedef struct WHV_INTERRUPT_CONTROL {
UINT64 TargetPartition;
WHV_INTERRUPT_CONTROL2 InterruptControl;
UINT64 DestinationAddress;
UINT32 RequestedVector;
UINT8 TargetVtl;
UINT8 ReservedZ0;
UINT16 ReservedZ1;
} WHV_INTERRUPT_CONTROL;
C_ASSERT(sizeof(WHV_INTERRUPT_CONTROL) == 32);
#endif /* defined(__x86_64__) || defined(__aarch64__) */
typedef struct WHV_DOORBELL_MATCH_DATA {
WHV_GUEST_PHYSICAL_ADDRESS GuestAddress;
UINT64 Value;
UINT32 Length;
UINT32 MatchOnValue : 1;
UINT32 MatchOnLength : 1;
UINT32 Reserved : 30;
} WHV_DOORBELL_MATCH_DATA;
C_ASSERT(sizeof(WHV_DOORBELL_MATCH_DATA) == 24);
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;
C_ASSERT(sizeof(WHV_PARTITION_MEMORY_COUNTERS) == 24);
typedef enum WHV_PROCESSOR_COUNTER_SET {
WHvProcessorCounterSetRuntime = 0,
WHvProcessorCounterSetIntercepts = 1,
WHvProcessorCounterSetEvents = 2,
#if defined(__x86_64__)
WHvProcessorCounterSetApic = 3,
#endif
WHvProcessorCounterSetSyntheticFeatures = 4
} WHV_PROCESSOR_COUNTER_SET;
typedef struct WHV_PROCESSOR_RUNTIME_COUNTERS {
UINT64 TotalRuntime100ns;
UINT64 HypervisorRuntime100ns;
} WHV_PROCESSOR_RUNTIME_COUNTERS;
C_ASSERT(sizeof(WHV_PROCESSOR_RUNTIME_COUNTERS) == 16);
typedef struct WHV_PROCESSOR_INTERCEPT_COUNTER {
UINT64 Count;
UINT64 Time100ns;
} WHV_PROCESSOR_INTERCEPT_COUNTER;
C_ASSERT(sizeof(WHV_PROCESSOR_INTERCEPT_COUNTER) == 16);
typedef struct WHV_PROCESSOR_INTERCEPT_COUNTERS {
#if defined(__x86_64__)
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_INTERCEPT_COUNTER NestedPageFaultIntercepts;
WHV_PROCESSOR_INTERCEPT_COUNTER Hypercalls;
WHV_PROCESSOR_INTERCEPT_COUNTER RdpmcInstructions;
#elif defined(__aarch64__)
WHV_PROCESSOR_INTERCEPT_COUNTER OtherIntercepts;
WHV_PROCESSOR_INTERCEPT_COUNTER PendingInterrupts;
WHV_PROCESSOR_INTERCEPT_COUNTER NestedPageFaultIntercepts;
WHV_PROCESSOR_INTERCEPT_COUNTER Hypercalls;
WHV_PROCESSOR_INTERCEPT_COUNTER Reserved[10];
#endif /* defined(__x86_64__) || defined(__aarch64__) */
} WHV_PROCESSOR_ACTIVITY_COUNTERS;
C_ASSERT(sizeof(WHV_PROCESSOR_ACTIVITY_COUNTERS) == 224);
typedef struct WHV_PROCESSOR_EVENT_COUNTERS {
UINT64 PageFaultCount;
UINT64 ExceptionCount;
UINT64 InterruptCount;
} WHV_PROCESSOR_GUEST_EVENT_COUNTERS;
C_ASSERT(sizeof(WHV_PROCESSOR_GUEST_EVENT_COUNTERS) == 24);
#if defined(__x86_64__)
typedef struct WHV_PROCESSOR_APIC_COUNTERS {
UINT64 MmioAccessCount;
UINT64 EoiAccessCount;
UINT64 TprAccessCount;
UINT64 SentIpiCount;
UINT64 SelfIpiCount;
} WHV_PROCESSOR_APIC_COUNTERS;
C_ASSERT(sizeof(WHV_PROCESSOR_APIC_COUNTERS) == 40);
#endif /* defined(__x86_64__) */
typedef struct WHV_PROCESSOR_SYNTHETIC_FEATURES_COUNTERS {
UINT64 SyntheticInterruptsCount;
UINT64 LongSpinWaitHypercallsCount;
UINT64 OtherHypercallsCount;
UINT64 SyntheticInterruptHypercallsCount;
UINT64 VirtualInterruptHypercallsCount;
UINT64 VirtualMmuHypercallsCount;
} WHV_PROCESSOR_SYNTHETIC_FEATURES_COUNTERS;
C_ASSERT(sizeof(WHV_PROCESSOR_SYNTHETIC_FEATURES_COUNTERS) == 48);
typedef union WHV_VTL_PERMISSION_SET {
UINT32 AsUINT32;
__C89_NAMELESS struct {
UINT16 VtlPermissionFrom1[2];
};
} WHV_VTL_PERMISSION_SET;
typedef enum WHV_ADVISE_GPA_RANGE_CODE {
WHvAdviseGpaRangeCodePopulate = 0x00000000,
WHvAdviseGpaRangeCodePin = 0x00000001,
WHvAdviseGpaRangeCodeUnpin = 0x00000002
} WHV_ADVISE_GPA_RANGE_CODE;
#if defined(__x86_64__)
typedef enum WHV_VIRTUAL_PROCESSOR_STATE_TYPE {
WHvVirtualProcessorStateTypeSynicMessagePage = 0x00000000,
WHvVirtualProcessorStateTypeSynicEventFlagPage = 0x00000001,
WHvVirtualProcessorStateTypeSynicTimerState = 0x00000002,
WHvVirtualProcessorStateTypeInterruptControllerState2 = 0x00001000,
WHvVirtualProcessorStateTypeXsaveState = 0x00001001,
WHvVirtualProcessorStateTypeNestedState = 0x00001002
} WHV_VIRTUAL_PROCESSOR_STATE_TYPE;
#elif defined(__aarch64__)
#define WHV_VIRTUAL_PROCESSOR_STATE_TYPE_PFN (1U << 31)
#define WHV_VIRTUAL_PROCESSOR_STATE_TYPE_ANY_VP (1U << 30)
typedef enum WHV_VIRTUAL_PROCESSOR_STATE_TYPE {
WHvVirtualProcessorStateTypeInterruptControllerState = 0x00000000 | WHV_VIRTUAL_PROCESSOR_STATE_TYPE_PFN,
WHvVirtualProcessorStateTypeSynicMessagePage = 0x00000002 | WHV_VIRTUAL_PROCESSOR_STATE_TYPE_PFN,
WHvVirtualProcessorStateTypeSynicEventFlagPage = 0x00000003 | WHV_VIRTUAL_PROCESSOR_STATE_TYPE_PFN,
WHvVirtualProcessorStateTypeSynicTimerState = 0x00000004,
WHvVirtualProcessorStateTypeGlobalInterruptState = 0x00000006 | WHV_VIRTUAL_PROCESSOR_STATE_TYPE_PFN | WHV_VIRTUAL_PROCESSOR_STATE_TYPE_ANY_VP,
WHvVirtualProcessorStateTypeSveState = 0x00000007 | WHV_VIRTUAL_PROCESSOR_STATE_TYPE_PFN
} WHV_VIRTUAL_PROCESSOR_STATE_TYPE;
#endif /* defined(__x86_64__) || defined(__aarch64__) */
typedef enum WHV_NESTED_STATE_TYPE {
WHvNestedStateTypeVmx,
WHvNestedStateTypeSvm
} WHV_NESTED_STATE_TYPE;
typedef struct WHV_NESTED_ENLIGHTENMENTS_CONTROL {
__C89_NAMELESS union {
UINT32 AsUINT32;
__C89_NAMELESS struct {
UINT32 DirectHypercall:1;
UINT32 VirtualizationException:1;
UINT32 Reserved:30;
};
} Features;
__C89_NAMELESS union {
UINT32 AsUINT32;
__C89_NAMELESS struct {
UINT32 InterPartitionCommunication:1;
UINT32 Reserved:31;
};
} HypercallControls;
} WHV_NESTED_ENLIGHTENMENTS_CONTROL;
typedef struct WHV_X64_VMX_NESTED_STATE {
WHV_NESTED_STATE_TYPE Vendor;
__C89_NAMELESS struct {
UINT32 GuestMode : 1;
UINT32 Vmxon : 1;
UINT32 CurrentVmcsValid : 1;
UINT32 VmEntryPending : 1;
UINT32 VmcsEnlightened : 1;
UINT32 EnlightenedVmEntry : 1;
UINT32 Reserved : 26;
} Flags;
WHV_NESTED_ENLIGHTENMENTS_CONTROL NestedEnlightenmentsControl;
UINT64 Pdpt[4];
UINT64 VmxonRegionGpa;
UINT64 VmcsGpa;
UINT64 CurrentEnlightenedVmcs;
__C89_NAMELESS struct {
UINT32 Tpr;
UINT32 Ppr;
UINT32 Isr[8];
UINT32 Irr[8];
UINT32 IcrLow;
UINT32 IcrHigh;
} VirtualApicRegs;
UINT8 Reserved[3944];
DECLSPEC_ALIGN(4096) UINT8 VmcsBytes[4096];
} WHV_X64_VMX_NESTED_STATE;
typedef struct WHV_SVM_VMCB_SELECTOR {
UINT16 Selector;
UINT16 Attrib;
UINT32 Limit;
UINT64 Base;
} WHV_SVM_VMCB_SELECTOR;
typedef struct WHV_SVM_NESTED_HOST_STATE {
UINT64 Rip;
UINT64 Rsp;
UINT64 Rflags;
UINT64 Rax;
WHV_SVM_VMCB_SELECTOR Es;
WHV_SVM_VMCB_SELECTOR Cs;
WHV_SVM_VMCB_SELECTOR Ss;
WHV_SVM_VMCB_SELECTOR Ds;
WHV_SVM_VMCB_SELECTOR Gdtr;
WHV_SVM_VMCB_SELECTOR Idtr;
UINT64 Efer;
UINT64 Cr0;
UINT64 Cr3;
UINT64 Cr4;
UINT64 VirtualTpr;
UINT64 Reserved[6];
} WHV_SVM_NESTED_HOST_STATE;
typedef struct WHV_X64_SVM_NESTED_STATE {
WHV_NESTED_STATE_TYPE Vendor;
__C89_NAMELESS struct {
UINT32 GuestMode : 1;
UINT32 VmEntryPending : 1;
UINT32 HostSaveGpaValid : 1;
UINT32 CurrentVmcbValid : 1;
UINT32 Reserved : 28;
} Flags;
WHV_NESTED_ENLIGHTENMENTS_CONTROL NestedEnlightenmentsControl;
UINT64 HostSaveGpa;
UINT64 VmControlMsr;
UINT64 VirtualTscRatioMsr;
UINT64 VmcbGpa;
WHV_SVM_NESTED_HOST_STATE HostState;
UINT8 Reserved[3832];
DECLSPEC_ALIGN(4096) UINT8 VmcbBytes[4096];
} WHV_X64_SVM_NESTED_STATE;
typedef union WHV_X64_NESTED_STATE {
WHV_X64_VMX_NESTED_STATE Vmx;
WHV_X64_SVM_NESTED_STATE Svm;
} WHV_X64_NESTED_STATE;
C_ASSERT(sizeof(WHV_X64_NESTED_STATE) == (2 * 4096));
#if defined (__aarch64__)
typedef struct WHV_ARM64_INTERRUPT_STATE {
__C89_NAMELESS struct {
UINT8 Enabled : 1;
UINT8 EdgeTriggered : 1;
UINT8 Asserted : 1;
UINT8 SetPending : 1;
UINT8 Active : 1;
UINT8 Direct : 1;
UINT8 Reserved0 : 2;
};
UINT8 GicrIpriorityrConfigured;
UINT8 GicrIpriorityrActive;
UINT8 Reserved1;
} WHV_ARM64_INTERRUPT_STATE;
typedef struct WHV_ARM64_GLOBAL_INTERRUPT_STATE {
UINT32 InterruptId;
UINT32 ActiveVpIndex;
__C89_NAMELESS union {
UINT32 TargetMpidr;
UINT32 TargetVpIndex;
};
WHV_ARM64_INTERRUPT_STATE InterruptState;
} WHV_ARM64_GLOBAL_INTERRUPT_STATE;
#define WHV_ARM64_GLOBAL_INTERRUPT_CONTROLLER_STATE_VERSION_CURRENT (1)
typedef struct WHV_ARM64_GLOBAL_INTERRUPT_CONTROLLER_STATE {
UINT8 Version;
UINT8 GicVersion;
UINT8 Reserved0[2];
UINT32 NumInterrupts;
UINT64 GicdCtlrEnableGrp1A;
WHV_ARM64_GLOBAL_INTERRUPT_STATE Interrupts[ANYSIZE_ARRAY];
} WHV_ARM64_GLOBAL_INTERRUPT_CONTROLLER_STATE;
#define WHV_ARM64_INTERRUPT_CONTROLLER_STATE_VERSION_CURRENT (1)
typedef struct WHV_ARM64_LOCAL_INTERRUPT_CONTROLLER_STATE {
UINT8 Version;
UINT8 GicVersion;
UINT8 Reserved0[6];
UINT64 IccIgrpen1El1;
UINT64 GicrCtlrEnableLpis;
UINT64 IccBpr1El1;
UINT64 IccPmrEl1;
UINT64 GicrPropbaser;
UINT64 GicrPendbaser;
UINT32 IchAp1REl2[4];
WHV_ARM64_INTERRUPT_STATE BankedInterruptState[32];
} WHV_ARM64_LOCAL_INTERRUPT_CONTROLLER_STATE;
typedef struct WHV_ARM64_VP_STATE_SVE {
USHORT Version;
USHORT RegisterDataOffset;
UINT32 VectorLength;
UINT64 Reserved0;
} WHV_ARM64_VP_STATE_SVE;
#endif /* defined(__aarch64__) */
typedef struct WHV_SYNIC_EVENT_PARAMETERS {
UINT32 VpIndex;
UINT8 TargetSint;
WHV_VTL TargetVtl;
UINT16 FlagNumber;
} WHV_SYNIC_EVENT_PARAMETERS;
C_ASSERT(sizeof(WHV_SYNIC_EVENT_PARAMETERS) == 8);
typedef enum WHV_ALLOCATE_VPCI_RESOURCE_FLAGS {
WHvAllocateVpciResourceFlagNone = 0x00000000,
WHvAllocateVpciResourceFlagAllowDirectP2P = 0x00000001
} WHV_ALLOCATE_VPCI_RESOURCE_FLAGS;
DEFINE_ENUM_FLAG_OPERATORS(WHV_ALLOCATE_VPCI_RESOURCE_FLAGS);
#define WHV_MAX_DEVICE_ID_SIZE_IN_CHARS 200
typedef struct WHV_SRIOV_RESOURCE_DESCRIPTOR {
WCHAR PnpInstanceId[WHV_MAX_DEVICE_ID_SIZE_IN_CHARS];
LUID VirtualFunctionId;
UINT16 VirtualFunctionIndex;
UINT16 Reserved;
} WHV_SRIOV_RESOURCE_DESCRIPTOR;
C_ASSERT(sizeof(WHV_SRIOV_RESOURCE_DESCRIPTOR) == 412);
typedef enum WHV_VPCI_DEVICE_NOTIFICATION_TYPE {
WHvVpciDeviceNotificationUndefined = 0,
WHvVpciDeviceNotificationMmioRemapping = 1,
WHvVpciDeviceNotificationSurpriseRemoval = 2
} WHV_VPCI_DEVICE_NOTIFICATION_TYPE;
typedef struct WHV_VPCI_DEVICE_NOTIFICATION {
WHV_VPCI_DEVICE_NOTIFICATION_TYPE NotificationType;
UINT32 Reserved1;
__C89_NAMELESS union {
UINT64 Reserved2;
};
} WHV_VPCI_DEVICE_NOTIFICATION;
C_ASSERT(sizeof(WHV_VPCI_DEVICE_NOTIFICATION) == 16);
typedef enum WHV_CREATE_VPCI_DEVICE_FLAGS {
WHvCreateVpciDeviceFlagNone = 0x00000000,
WHvCreateVpciDeviceFlagPhysicallyBacked = 0x00000001,
WHvCreateVpciDeviceFlagUseLogicalInterrupts = 0x00000002
} WHV_CREATE_VPCI_DEVICE_FLAGS;
DEFINE_ENUM_FLAG_OPERATORS(WHV_CREATE_VPCI_DEVICE_FLAGS);
typedef enum WHV_VPCI_DEVICE_PROPERTY_CODE {
WHvVpciDevicePropertyCodeUndefined = 0,
WHvVpciDevicePropertyCodeHardwareIDs = 1,
WHvVpciDevicePropertyCodeProbedBARs = 2
} WHV_VPCI_DEVICE_PROPERTY_CODE;
typedef struct WHV_VPCI_HARDWARE_IDS {
UINT16 VendorID;
UINT16 DeviceID;
UINT8 RevisionID;
UINT8 ProgIf;
UINT8 SubClass;
UINT8 BaseClass;
UINT16 SubVendorID;
UINT16 SubSystemID;
} WHV_VPCI_HARDWARE_IDS;
C_ASSERT(sizeof(WHV_VPCI_HARDWARE_IDS) == 12);
#define WHV_VPCI_TYPE0_BAR_COUNT 6
typedef struct WHV_VPCI_PROBED_BARS {
UINT32 Value[WHV_VPCI_TYPE0_BAR_COUNT];
} WHV_VPCI_PROBED_BARS;
C_ASSERT(sizeof(WHV_VPCI_PROBED_BARS) == 24);
typedef enum WHV_VPCI_MMIO_RANGE_FLAGS {
WHvVpciMmioRangeFlagReadAccess = 0x00000001,
WHvVpciMmioRangeFlagWriteAccess = 0x00000002
} WHV_VPCI_MMIO_RANGE_FLAGS;
DEFINE_ENUM_FLAG_OPERATORS(WHV_VPCI_MMIO_RANGE_FLAGS);
typedef enum WHV_VPCI_DEVICE_REGISTER_SPACE {
WHvVpciConfigSpace = -1,
WHvVpciBar0 = 0,
WHvVpciBar1 = 1,
WHvVpciBar2 = 2,
WHvVpciBar3 = 3,
WHvVpciBar4 = 4,
WHvVpciBar5 = 5
} WHV_VPCI_DEVICE_REGISTER_SPACE;
typedef struct WHV_VPCI_MMIO_MAPPING {
WHV_VPCI_DEVICE_REGISTER_SPACE Location;
WHV_VPCI_MMIO_RANGE_FLAGS Flags;
UINT64 SizeInBytes;
UINT64 OffsetInBytes;
PVOID VirtualAddress;
} WHV_VPCI_MMIO_MAPPING;
C_ASSERT(sizeof(WHV_VPCI_MMIO_MAPPING) == 32);
typedef struct WHV_VPCI_DEVICE_REGISTER {
WHV_VPCI_DEVICE_REGISTER_SPACE Location;
UINT32 SizeInBytes;
UINT64 OffsetInBytes;
} WHV_VPCI_DEVICE_REGISTER;
C_ASSERT(sizeof(WHV_VPCI_DEVICE_REGISTER) == 16);
typedef enum WHV_VPCI_INTERRUPT_TARGET_FLAGS {
WHvVpciInterruptTargetFlagNone = 0x00000000,
WHvVpciInterruptTargetFlagMulticast = 0x00000001
} WHV_VPCI_INTERRUPT_TARGET_FLAGS;
DEFINE_ENUM_FLAG_OPERATORS(WHV_VPCI_INTERRUPT_TARGET_FLAGS);
typedef struct WHV_VPCI_INTERRUPT_TARGET {
UINT32 Vector;
WHV_VPCI_INTERRUPT_TARGET_FLAGS Flags;
UINT32 ProcessorCount;
UINT32 Processors[ANYSIZE_ARRAY];
} WHV_VPCI_INTERRUPT_TARGET;
C_ASSERT(sizeof(WHV_VPCI_INTERRUPT_TARGET) == 16);
typedef enum WHV_TRIGGER_TYPE {
#if defined(__x86_64__)
WHvTriggerTypeInterrupt = 0,
#endif
WHvTriggerTypeSynicEvent = 1,
WHvTriggerTypeDeviceInterrupt = 2
} WHV_TRIGGER_TYPE;
typedef struct WHV_TRIGGER_PARAMETERS {
WHV_TRIGGER_TYPE TriggerType;
UINT32 Reserved;
__C89_NAMELESS union {
#if defined(__x86_64__)
WHV_INTERRUPT_CONTROL Interrupt;
#endif
WHV_SYNIC_EVENT_PARAMETERS SynicEvent;
__C89_NAMELESS struct {
UINT64 LogicalDeviceId;
UINT64 MsiAddress;
UINT32 MsiData;
UINT32 Reserved;
} DeviceInterrupt;
};
} WHV_TRIGGER_PARAMETERS;
C_ASSERT(sizeof(WHV_TRIGGER_PARAMETERS) == 32);
typedef PVOID WHV_TRIGGER_HANDLE;
typedef enum WHV_VIRTUAL_PROCESSOR_PROPERTY_CODE {
WHvVirtualProcessorPropertyCodeNumaNode = 0x00000000
} WHV_VIRTUAL_PROCESSOR_PROPERTY_CODE;
typedef struct WHV_VIRTUAL_PROCESSOR_PROPERTY {
WHV_VIRTUAL_PROCESSOR_PROPERTY_CODE PropertyCode;
UINT32 Reserved;
__C89_NAMELESS union {
USHORT NumaNode;
UINT64 Padding;
};
} WHV_VIRTUAL_PROCESSOR_PROPERTY;
C_ASSERT(sizeof(WHV_VIRTUAL_PROCESSOR_PROPERTY) == 16);
typedef enum WHV_NOTIFICATION_PORT_TYPE {
WHvNotificationPortTypeEvent = 2,
WHvNotificationPortTypeDoorbell = 4
} WHV_NOTIFICATION_PORT_TYPE;
typedef struct WHV_NOTIFICATION_PORT_PARAMETERS {
WHV_NOTIFICATION_PORT_TYPE NotificationPortType;
UINT16 Reserved;
UINT8 Reserved1;
UINT8 ConnectionVtl;
__C89_NAMELESS union {
WHV_DOORBELL_MATCH_DATA Doorbell;
__C89_NAMELESS struct {
UINT32 ConnectionId;
} Event;
};
} WHV_NOTIFICATION_PORT_PARAMETERS;
C_ASSERT(sizeof(WHV_NOTIFICATION_PORT_PARAMETERS) == 32);
typedef enum WHV_NOTIFICATION_PORT_PROPERTY_CODE {
WHvNotificationPortPropertyPreferredTargetVp = 1,
WHvNotificationPortPropertyPreferredTargetDuration = 5
} WHV_NOTIFICATION_PORT_PROPERTY_CODE;
typedef UINT64 WHV_NOTIFICATION_PORT_PROPERTY;
#define WHV_ANY_VP (0xFFFFFFFF)
#define WHV_NOTIFICATION_PORT_PREFERRED_DURATION_MAX (0xFFFFFFFFFFFFFFFFULL)
typedef PVOID WHV_NOTIFICATION_PORT_HANDLE;
#define WHV_SYNIC_MESSAGE_SIZE 256
#endif /* defined(__x86_64__) || defined(__aarch64__) */
#endif /* _WINHVAPIDEFS_H_ */