reactos/sdk/include/ddk/d3dkmthk.h
2024-10-19 13:45:59 -07:00

6040 lines
289 KiB
C

/******************************Module*Header**********************************\
*
* Module Name: d3dkmthk.h
*
* Content: Windows Display Driver Model (WDDM) kernel mode thunk interfaces
*
* Copyright (c) Microsoft Corporation.
* Licensed under the MIT License.
*
\*****************************************************************************/
#ifndef _D3DKMTHK_H_
#define _D3DKMTHK_H_
#include <d3dkmdt.h>
#pragma region Desktop Family
#if WINAPI_FAMILY_PARTITION(WINAPI_PARTITION_DESKTOP)
#pragma warning(push)
#pragma warning(disable:4201) // anonymous unions warning
#pragma warning(disable:4200) // zero-sized array in struct/union
#pragma warning(disable:4214) // nonstandard extension used: bit field types other than int
typedef struct _OBJECT_ATTRIBUTES OBJECT_ATTRIBUTES;
typedef OBJECT_ATTRIBUTES *POBJECT_ATTRIBUTES;
//
// Available only for Vista (LONGHORN) and later and for
// multiplatform tools such as debugger extensions
//
#if defined(__REACTOS__) || ((NTDDI_VERSION >= NTDDI_LONGHORN) || defined(D3DKMDT_SPECIAL_MULTIPLATFORM_TOOL))
typedef struct _D3DKMT_CREATEDEVICEFLAGS
{
UINT LegacyMode : 1; // 0x00000001
UINT RequestVSync : 1; // 0x00000002
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WIN8)
UINT DisableGpuTimeout : 1; // 0x00000004
UINT Reserved : 29; // 0xFFFFFFF8
#else
UINT Reserved : 30; // 0xFFFFFFFC
#endif
} D3DKMT_CREATEDEVICEFLAGS;
typedef struct _D3DKMT_CREATEDEVICE
{
union
{
D3DKMT_HANDLE hAdapter; // in: identifies the adapter for user-mode creation
VOID* pAdapter; // in: identifies the adapter for kernel-mode creation
D3DKMT_PTR_HELPER(pAdapter_Align)
};
D3DKMT_CREATEDEVICEFLAGS Flags;
D3DKMT_HANDLE hDevice; // out: Identifies the device
D3DKMT_PTR(VOID*, pCommandBuffer); // out: D3D10 compatibility.
UINT CommandBufferSize; // out: D3D10 compatibility.
D3DKMT_PTR(D3DDDI_ALLOCATIONLIST*, pAllocationList); // out: D3D10 compatibility.
UINT AllocationListSize; // out: D3D10 compatibility.
D3DKMT_PTR(D3DDDI_PATCHLOCATIONLIST*, pPatchLocationList); // out: D3D10 compatibility.
UINT PatchLocationListSize; // out: D3D10 compatibility.
} D3DKMT_CREATEDEVICE;
typedef struct _D3DKMT_DESTROYDEVICE
{
D3DKMT_HANDLE hDevice; // in: Indentifies the device
}D3DKMT_DESTROYDEVICE;
typedef enum _D3DKMT_CLIENTHINT
{
D3DKMT_CLIENTHINT_UNKNOWN = 0,
D3DKMT_CLIENTHINT_OPENGL = 1,
D3DKMT_CLIENTHINT_CDD = 2, // Internal
D3DKMT_CLIENTHINT_OPENCL = 3,
D3DKMT_CLIENTHINT_VULKAN = 4,
D3DKMT_CLIENTHINT_CUDA = 5,
D3DKMT_CLIENTHINT_RESERVED = 6,
D3DKMT_CLIENTHINT_DX7 = 7,
D3DKMT_CLIENTHINT_DX8 = 8,
D3DKMT_CLIENTHINT_DX9 = 9,
D3DKMT_CLIENTHINT_DX10 = 10,
D3DKMT_CLIENTHINT_DX11 = 11,
D3DKMT_CLIENTHINT_DX12 = 12,
D3DKMT_CLIENTHINT_9ON12 = 13,
D3DKMT_CLIENTHINT_11ON12 = 14,
D3DKMT_CLIENTHINT_MFT_ENCODE = 15,
D3DKMT_CLIENTHINT_GLON12 = 16,
D3DKMT_CLIENTHINT_CLON12 = 17,
D3DKMT_CLIENTHINT_DML_TENSORFLOW = 18,
D3DKMT_CLIENTHINT_ONEAPI_LEVEL0 = 19,
D3DKMT_CLIENTHINT_MAX
} D3DKMT_CLIENTHINT;
typedef struct _D3DKMT_CREATECONTEXT
{
D3DKMT_HANDLE hDevice; // in: Handle to the device owning this context.
UINT NodeOrdinal; // in: Identifier for the node targetted by this context.
UINT EngineAffinity; // in: Engine affinity within the specified node.
D3DDDI_CREATECONTEXTFLAGS Flags; // in: Context creation flags.
D3DKMT_PTR(VOID*, pPrivateDriverData); // in: Private driver data
UINT PrivateDriverDataSize; // in: Size of private driver data
D3DKMT_CLIENTHINT ClientHint; // in: Hints which client is creating this
D3DKMT_HANDLE hContext; // out: Handle of the created context.
D3DKMT_PTR(VOID*, pCommandBuffer); // out: Pointer to the first command buffer.
UINT CommandBufferSize; // out: Command buffer size (bytes).
D3DKMT_PTR(D3DDDI_ALLOCATIONLIST*, pAllocationList); // out: Pointer to the first allocation list.
UINT AllocationListSize; // out: Allocation list size (elements).
D3DKMT_PTR(D3DDDI_PATCHLOCATIONLIST*, pPatchLocationList); // out: Pointer to the first patch location list.
UINT PatchLocationListSize; // out: Patch location list size (elements).
D3DGPU_VIRTUAL_ADDRESS CommandBuffer; // out: GPU virtual address of the command buffer. _ADVSCH_
} D3DKMT_CREATECONTEXT;
typedef struct _D3DKMT_DESTROYCONTEXT
{
D3DKMT_HANDLE hContext; // in: Identifies the context being destroyed.
} D3DKMT_DESTROYCONTEXT;
typedef struct _D3DKMT_CREATESYNCHRONIZATIONOBJECT
{
D3DKMT_HANDLE hDevice; // in: Handle to the device.
D3DDDI_SYNCHRONIZATIONOBJECTINFO Info; // in: Attributes of the synchronization object.
D3DKMT_HANDLE hSyncObject; // out: Handle to the synchronization object created.
} D3DKMT_CREATESYNCHRONIZATIONOBJECT;
typedef struct _D3DKMT_CREATESYNCHRONIZATIONOBJECT2
{
D3DKMT_HANDLE hDevice; // in: Handle to the device.
D3DDDI_SYNCHRONIZATIONOBJECTINFO2 Info; // in/out: Attributes of the synchronization object.
D3DKMT_HANDLE hSyncObject; // out: Handle to the synchronization object created.
} D3DKMT_CREATESYNCHRONIZATIONOBJECT2;
typedef struct _D3DKMT_DESTROYSYNCHRONIZATIONOBJECT
{
D3DKMT_HANDLE hSyncObject; // in: Identifies the synchronization objects being destroyed.
} D3DKMT_DESTROYSYNCHRONIZATIONOBJECT;
typedef struct _D3DKMT_OPENSYNCHRONIZATIONOBJECT
{
D3DKMT_HANDLE hSharedHandle; // in: shared handle to synchronization object to be opened.
D3DKMT_HANDLE hSyncObject; // out: Handle to sync object in this process.
D3DKMT_ALIGN64 UINT64 Reserved[8];
} D3DKMT_OPENSYNCHRONIZATIONOBJECT;
typedef struct _D3DKMT_WAITFORSYNCHRONIZATIONOBJECT
{
D3DKMT_HANDLE hContext; // in: Identifies the context that needs to wait.
UINT ObjectCount; // in: Specifies the number of object to wait on.
D3DKMT_HANDLE ObjectHandleArray[D3DDDI_MAX_OBJECT_WAITED_ON]; // in: Specifies the object to wait on.
} D3DKMT_WAITFORSYNCHRONIZATIONOBJECT;
typedef struct _D3DKMT_WAITFORSYNCHRONIZATIONOBJECT2
{
D3DKMT_HANDLE hContext; // in: Identifies the context that needs to wait.
UINT ObjectCount; // in: Specifies the number of object to wait on.
D3DKMT_HANDLE ObjectHandleArray[D3DDDI_MAX_OBJECT_WAITED_ON]; // in: Specifies the object to wait on.
union
{
struct {
D3DKMT_ALIGN64 UINT64 FenceValue; // in: fence value to be waited.
} Fence;
D3DKMT_ALIGN64 UINT64 Reserved[8];
};
} D3DKMT_WAITFORSYNCHRONIZATIONOBJECT2;
typedef struct _D3DKMT_SIGNALSYNCHRONIZATIONOBJECT
{
D3DKMT_HANDLE hContext; // in: Identifies the context that needs to signal.
UINT ObjectCount; // in: Specifies the number of object to signal.
D3DKMT_HANDLE ObjectHandleArray[D3DDDI_MAX_OBJECT_SIGNALED]; // in: Specifies the object to be signaled.
D3DDDICB_SIGNALFLAGS Flags; // in: Specifies signal behavior.
} D3DKMT_SIGNALSYNCHRONIZATIONOBJECT;
typedef struct _D3DKMT_SIGNALSYNCHRONIZATIONOBJECT2
{
D3DKMT_HANDLE hContext; // in: Identifies the context that needs to signal.
UINT ObjectCount; // in: Specifies the number of object to signal.
D3DKMT_HANDLE ObjectHandleArray[D3DDDI_MAX_OBJECT_SIGNALED]; // in: Specifies the object to be signaled.
D3DDDICB_SIGNALFLAGS Flags; // in: Specifies signal behavior.
ULONG BroadcastContextCount; // in: Specifies the number of context
// to broadcast this command buffer to.
D3DKMT_HANDLE BroadcastContext[D3DDDI_MAX_BROADCAST_CONTEXT]; // in: Specifies the handle of the context to
// broadcast to.
union
{
struct {
D3DKMT_ALIGN64 UINT64 FenceValue; // in: fence value to be signaled;
} Fence;
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WIN8)
HANDLE CpuEventHandle; // in: handle of a CPU event to be signaled
#endif // (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WIN8)
D3DKMT_ALIGN64 UINT64 Reserved[8];
};
} D3DKMT_SIGNALSYNCHRONIZATIONOBJECT2;
typedef struct _D3DKMT_LOCK
{
D3DKMT_HANDLE hDevice; // in: identifies the device
D3DKMT_HANDLE hAllocation; // in: allocation to lock
// out: New handle representing the allocation after the lock.
UINT PrivateDriverData; // in: Used by UMD for AcquireAperture
UINT NumPages;
D3DKMT_PTR(CONST UINT*, pPages);
D3DKMT_PTR(VOID*, pData); // out: pointer to memory
D3DDDICB_LOCKFLAGS Flags; // in: Bit field defined by D3DDDI_LOCKFLAGS
D3DGPU_VIRTUAL_ADDRESS GpuVirtualAddress; // out: GPU's Virtual Address of locked allocation. _ADVSCH_
} D3DKMT_LOCK;
typedef struct _D3DKMT_UNLOCK
{
D3DKMT_HANDLE hDevice; // in: Identifies the device
UINT NumAllocations; // in: Number of allocations in the array
D3DKMT_PTR(CONST D3DKMT_HANDLE*, phAllocations); // in: array of allocations to unlock
} D3DKMT_UNLOCK;
typedef enum _D3DKMDT_MODE_PRUNING_REASON
{
D3DKMDT_MPR_UNINITIALIZED = 0, // mode was pruned or is supported because of:
D3DKMDT_MPR_ALLCAPS = 1, // all of the monitor caps (only used to imply lack of support - for support, specific reason is always indicated)
D3DKMDT_MPR_DESCRIPTOR_MONITOR_SOURCE_MODE = 2, // monitor source mode in the monitor descriptor
D3DKMDT_MPR_DESCRIPTOR_MONITOR_FREQUENCY_RANGE = 3, // monitor frequency range in the monitor descriptor
D3DKMDT_MPR_DESCRIPTOR_OVERRIDE_MONITOR_SOURCE_MODE = 4, // monitor source mode in the monitor descriptor override
D3DKMDT_MPR_DESCRIPTOR_OVERRIDE_MONITOR_FREQUENCY_RANGE = 5, // monitor frequency range in the monitor descriptor override
D3DKMDT_MPR_DEFAULT_PROFILE_MONITOR_SOURCE_MODE = 6, // monitor source mode in the default monitor profile
D3DKMDT_MPR_DRIVER_RECOMMENDED_MONITOR_SOURCE_MODE = 7, // monitor source mode recommended by the driver
D3DKMDT_MPR_MONITOR_FREQUENCY_RANGE_OVERRIDE = 8, // monitor frequency range override
D3DKMDT_MPR_CLONE_PATH_PRUNED = 9, // Mode is pruned because other path(s) in clone cluster has(have) no mode supported by monitor
D3DKMDT_MPR_MAXVALID = 10
}
D3DKMDT_MODE_PRUNING_REASON;
// This structure takes 8 bytes.
// The unnamed UINT of size 0 forces alignment of the structure to
// make it exactly occupy 8 bytes, see MSDN docs on C++ bitfields
// for more details
typedef struct _D3DKMDT_DISPLAYMODE_FLAGS
{
#if (DXGKDDI_INTERFACE_VERSION < DXGKDDI_INTERFACE_VERSION_WIN8)
BOOLEAN ValidatedAgainstMonitorCaps : 1;
BOOLEAN RoundedFakeMode : 1;
D3DKMDT_MODE_PRUNING_REASON ModePruningReason : 4;
UINT Reserved : 28;
#else
UINT ValidatedAgainstMonitorCaps : 1;
UINT RoundedFakeMode : 1;
UINT : 0;
D3DKMDT_MODE_PRUNING_REASON ModePruningReason : 4;
UINT Stereo : 1;
UINT AdvancedScanCapable : 1;
#if (DXGKDDI_INTERFACE_VERSION < DXGKDDI_INTERFACE_VERSION_WDDM2_0)
UINT Reserved : 26;
#else
UINT PreferredTiming : 1;
UINT PhysicalModeSupported : 1;
#if (DXGKDDI_INTERFACE_VERSION < DXGKDDI_INTERFACE_VERSION_WDDM2_9)
UINT Reserved : 24;
#else
UINT VirtualRefreshRate : 1;
UINT Reserved : 23;
#endif // DXGKDDI_INTERFACE_VERSION_WDDM2_9
#endif
#endif
}
D3DKMDT_DISPLAYMODE_FLAGS;
typedef struct _D3DKMT_DISPLAYMODE
{
UINT Width;
UINT Height;
D3DDDIFORMAT Format;
UINT IntegerRefreshRate;
D3DDDI_RATIONAL RefreshRate;
D3DDDI_VIDEO_SIGNAL_SCANLINE_ORDERING ScanLineOrdering;
D3DDDI_ROTATION DisplayOrientation;
UINT DisplayFixedOutput;
D3DKMDT_DISPLAYMODE_FLAGS Flags;
} D3DKMT_DISPLAYMODE;
typedef struct _D3DKMT_GETDISPLAYMODELIST
{
D3DKMT_HANDLE hAdapter; // in: adapter handle
D3DDDI_VIDEO_PRESENT_SOURCE_ID VidPnSourceId; // in: adapter's VidPN source ID
D3DKMT_PTR(D3DKMT_DISPLAYMODE*, pModeList); // out:
UINT ModeCount; // in/out:
} D3DKMT_GETDISPLAYMODELIST;
typedef struct _D3DKMT_DISPLAYMODELIST
{
D3DDDI_VIDEO_PRESENT_SOURCE_ID VidPnSourceId;
UINT ModeCount;
D3DKMT_DISPLAYMODE pModeList[0];
} D3DKMT_DISPLAYMODELIST;
typedef struct _D3DKMT_SETDISPLAYMODE_FLAGS
{
BOOLEAN PreserveVidPn : 1;
UINT Reserved : 31;
}
D3DKMT_SETDISPLAYMODE_FLAGS;
typedef struct _D3DKMT_SETDISPLAYMODE
{
D3DKMT_HANDLE hDevice; // in: Identifies the device
D3DKMT_HANDLE hPrimaryAllocation; // in:
D3DDDI_VIDEO_SIGNAL_SCANLINE_ORDERING ScanLineOrdering; // in:
D3DDDI_ROTATION DisplayOrientation; // in:
UINT PrivateDriverFormatAttribute; // out: Private Format Attribute of the current primary surface if DxgkSetDisplayMode failed with STATUS_GRAPHICS_INCOMPATIBLE_PRIVATE_FORMAT
D3DKMT_SETDISPLAYMODE_FLAGS Flags; // in:
} D3DKMT_SETDISPLAYMODE;
typedef struct _D3DKMT_MULTISAMPLEMETHOD
{
UINT NumSamples;
UINT NumQualityLevels;
UINT Reserved; //workaround for NTRAID#Longhorn-1124385-2005/03/14-kanqiu
} D3DKMT_MULTISAMPLEMETHOD;
typedef struct _D3DKMT_GETMULTISAMPLEMETHODLIST
{
D3DKMT_HANDLE hAdapter; // in: adapter handle
D3DDDI_VIDEO_PRESENT_SOURCE_ID VidPnSourceId; // in: adapter's VidPN source ID
UINT Width; // in:
UINT Height; // in:
D3DDDIFORMAT Format; // in:
D3DKMT_PTR(D3DKMT_MULTISAMPLEMETHOD*, pMethodList); // out:
UINT MethodCount; // in/out:
} D3DKMT_GETMULTISAMPLEMETHODLIST;
typedef struct _D3DKMT_PRESENTFLAGS
{
union
{
struct
{
UINT Blt : 1; // 0x00000001
UINT ColorFill : 1; // 0x00000002
UINT Flip : 1; // 0x00000004
UINT FlipDoNotFlip : 1; // 0x00000008
UINT FlipDoNotWait : 1; // 0x00000010
UINT FlipRestart : 1; // 0x00000020
UINT DstRectValid : 1; // 0x00000040
UINT SrcRectValid : 1; // 0x00000080
UINT RestrictVidPnSource : 1; // 0x00000100
UINT SrcColorKey : 1; // 0x00000200
UINT DstColorKey : 1; // 0x00000400
UINT LinearToSrgb : 1; // 0x00000800
UINT PresentCountValid : 1; // 0x00001000
UINT Rotate : 1; // 0x00002000
UINT PresentToBitmap : 1; // 0x00004000
UINT RedirectedFlip : 1; // 0x00008000
UINT RedirectedBlt : 1; // 0x00010000
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WIN8)
UINT FlipStereo : 1; // 0x00020000 // This is a flip from a stereo alloc. Used in addition to Flip.
UINT FlipStereoTemporaryMono : 1; // 0x00040000 // This is a flip from a stereo alloc. The left image should used to produce both images. Used in addition to Flip.
UINT FlipStereoPreferRight : 1; // 0x00080000 // This is a flip from a stereo alloc. Use the right image when cloning to a mono monitor. Used in addition to Flip.
UINT BltStereoUseRight : 1; // 0x00100000 // This is a Blt from a stereo alloc to a mono alloc. The right image should be used.
UINT PresentHistoryTokenOnly : 1; // 0x00200000 // Submit Present History Token only.
UINT PresentRegionsValid : 1; // 0x00400000 // Ptr to present regions is valid
UINT PresentDDA : 1; // 0x00800000 // Present from a DDA swapchain
UINT ProtectedContentBlankedOut : 1; // 0x01000000
UINT RemoteSession : 1; // 0x02000000
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM1_3)
UINT CrossAdapter : 1; // 0x04000000
UINT DurationValid : 1; // 0x08000000
UINT PresentIndirect : 1; // 0x10000000 // Present to an indirect-display adapter
UINT PresentHMD : 1; // 0x20000000 // Present from an HMD swapchain.
UINT Reserved : 2; // 0xC0000000
#else
UINT Reserved : 6; // 0xFC000000
#endif // (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM1_3)
#else
UINT Reserved : 15; // 0xFFFE0000
#endif
};
UINT Value;
};
} D3DKMT_PRESENTFLAGS;
typedef enum _D3DKMT_PRESENT_MODEL
{
D3DKMT_PM_UNINITIALIZED = 0,
D3DKMT_PM_REDIRECTED_GDI = 1,
D3DKMT_PM_REDIRECTED_FLIP = 2,
D3DKMT_PM_REDIRECTED_BLT = 3,
D3DKMT_PM_REDIRECTED_VISTABLT = 4,
D3DKMT_PM_SCREENCAPTUREFENCE = 5,
D3DKMT_PM_REDIRECTED_GDI_SYSMEM = 6,
D3DKMT_PM_REDIRECTED_COMPOSITION = 7,
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_1)
D3DKMT_PM_SURFACECOMPLETE = 8,
#endif
D3DKMT_PM_FLIPMANAGER = 9,
} D3DKMT_PRESENT_MODEL;
typedef enum _D3DKMT_FLIPMODEL_INDEPENDENT_FLIP_STAGE
{
D3DKMT_FLIPMODEL_INDEPENDENT_FLIP_STAGE_FLIP_SUBMITTED = 0,
D3DKMT_FLIPMODEL_INDEPENDENT_FLIP_STAGE_FLIP_COMPLETE = 1
} D3DKMT_FLIPMODEL_INDEPENDENT_FLIP_STAGE;
typedef struct _D3DKMT_FLIPMODEL_PRESENTHISTORYTOKENFLAGS
{
union
{
struct
{
UINT Video : 1; // 0x00000001
UINT RestrictedContent : 1; // 0x00000002
UINT ClipToView : 1; // 0x00000004
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WIN8)
UINT StereoPreferRight : 1; // 0x00000008
UINT TemporaryMono : 1; // 0x00000010
UINT FlipRestart : 1; // 0x00000020
UINT HDRMetaDataChanged : 1; // 0x00000040
UINT AlphaMode : 2; // 0x00000180
UINT SignalLimitOnTokenCompletion : 1; // 0x00000200
UINT YCbCrFlags : 3; // 0x00001C00
UINT IndependentFlip : 1; // 0x00002000
D3DKMT_FLIPMODEL_INDEPENDENT_FLIP_STAGE IndependentFlipStage : 2; // 0x0000C000
UINT IndependentFlipReleaseCount : 2; // 0x00030000
UINT IndependentFlipForceNotifyDwm : 1; // 0x00040000
UINT UseCustomDuration : 1; // 0x00080000
UINT IndependentFlipRequestDwmConfirm:1; // 0x00100000
UINT IndependentFlipCandidate : 1; // 0x00200000
UINT IndependentFlipCheckNeeded : 1; // 0x00400000
UINT IndependentFlipTrueImmediate : 1; // 0x00800000
UINT IndependentFlipRequestDwmExit : 1; // 0x01000000
UINT CompSurfaceNotifiedEarly : 1; // 0x02000000
UINT IndependentFlipDoNotFlip : 1; // 0x04000000
UINT RequirePairedToken : 1; // 0x08000000
UINT VariableRefreshOverrideEligible :1; // 0x10000000
UINT Reserved : 3; // 0xE0000000
#else
UINT Reserved : 29; // 0xFFFFFFF8
#endif
};
UINT Value;
};
} D3DKMT_FLIPMODEL_PRESENTHISTORYTOKENFLAGS;
#define D3DKMT_MAX_PRESENT_HISTORY_RECTS 16
typedef struct _D3DKMT_DIRTYREGIONS
{
UINT NumRects;
RECT Rects[D3DKMT_MAX_PRESENT_HISTORY_RECTS];
} D3DKMT_DIRTYREGIONS;
typedef struct _D3DKMT_COMPOSITION_PRESENTHISTORYTOKEN
{
D3DKMT_ALIGN64 ULONG64 hPrivateData;
} D3DKMT_COMPOSITION_PRESENTHISTORYTOKEN;
typedef struct _D3DKMT_FLIPMANAGER_PRESENTHISTORYTOKEN
{
D3DKMT_ALIGN64 ULONG64 hPrivateData;
D3DKMT_ALIGN64 ULONGLONG PresentAtQpc;
union
{
struct
{
UINT Discard : 1;
UINT PresentAt : 1;
UINT hPrivateDataIsPointer : 1;
UINT Reserved : 29;
};
UINT Value;
}Flags;
} D3DKMT_FLIPMANAGER_PRESENTHISTORYTOKEN;
typedef enum _D3DKMT_AUXILIARYPRESENTINFO_TYPE
{
D3DKMT_AUXILIARYPRESENTINFO_TYPE_FLIPMANAGER = 0
} D3DKMT_AUXILIARYPRESENTINFO_TYPE;
typedef struct _D3DKMT_AUXILIARYPRESENTINFO
{
UINT size;
D3DKMT_AUXILIARYPRESENTINFO_TYPE type;
} D3DKMT_AUXILIARYPRESENTINFO;
typedef struct _D3DKMT_FLIPMANAGER_AUXILIARYPRESENTINFO
{
// in: Base information
D3DKMT_AUXILIARYPRESENTINFO auxiliaryPresentInfo;
// in: Tracing ID of owner flip manager
UINT flipManagerTracingId;
// in: Whether or not the application requested a different custom duration
// than the previous present
BOOL customDurationChanged;
// out: The adapter LUID/VidPn source of the flip output
LUID FlipAdapterLuid;
D3DDDI_VIDEO_PRESENT_SOURCE_ID VidPnSourceId;
// out: Independent flip stage
D3DKMT_FLIPMODEL_INDEPENDENT_FLIP_STAGE independentFlipStage;
// out: The DPC frame time of the frame on which the flip was completed
D3DKMT_ALIGN64 ULONGLONG FlipCompletedQpc;
// out: The approved frame duration
UINT HwPresentDurationQpc;
// out: Whether or not the present was canceled in the scheduler
BOOL WasCanceled;
} D3DKMT_FLIPMANAGER_AUXILIARYPRESENTINFO;
typedef struct _D3DKMT_GDIMODEL_PRESENTHISTORYTOKEN
{
D3DKMT_ALIGN64 ULONG64 hLogicalSurface;
D3DKMT_ALIGN64 ULONG64 hPhysicalSurface;
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WIN8)
RECT ScrollRect;
POINT ScrollOffset;
#endif
D3DKMT_DIRTYREGIONS DirtyRegions;
} D3DKMT_GDIMODEL_PRESENTHISTORYTOKEN;
typedef struct _D3DKMT_GDIMODEL_SYSMEM_PRESENTHISTORYTOKEN
{
D3DKMT_ALIGN64 ULONG64 hlsurf;
DWORD dwDirtyFlags;
D3DKMT_ALIGN64 UINT64 uiCookie;
} D3DKMT_GDIMODEL_SYSMEM_PRESENTHISTORYTOKEN;
typedef ULONGLONG D3DKMT_VISTABLTMODEL_PRESENTHISTORYTOKEN;
typedef struct _D3DKMT_FENCE_PRESENTHISTORYTOKEN
{
D3DKMT_ALIGN64 UINT64 Key;
} D3DKMT_FENCE_PRESENTHISTORYTOKEN;
typedef struct _D3DKMT_BLTMODEL_PRESENTHISTORYTOKEN
{
D3DKMT_ALIGN64 ULONG64 hLogicalSurface;
D3DKMT_ALIGN64 ULONG64 hPhysicalSurface;
D3DKMT_ALIGN64 ULONG64 EventId;
D3DKMT_DIRTYREGIONS DirtyRegions;
} D3DKMT_BLTMODEL_PRESENTHISTORYTOKEN;
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WIN8)
#define D3DKMT_MAX_PRESENT_HISTORY_SCATTERBLTS 12
typedef struct _D3DKMT_SCATTERBLT
{
D3DKMT_ALIGN64 ULONG64 hLogicalSurfaceDestination;
D3DKMT_ALIGN64 LONG64 hDestinationCompSurfDWM;
D3DKMT_ALIGN64 UINT64 DestinationCompositionBindingId;
RECT SourceRect;
POINT DestinationOffset;
} D3DKMT_SCATTERBLT;
typedef struct _D3DKMT_SCATTERBLTS
{
UINT NumBlts;
D3DKMT_SCATTERBLT Blts[D3DKMT_MAX_PRESENT_HISTORY_SCATTERBLTS];
} D3DKMT_SCATTERBLTS;
#endif
typedef struct _D3DKMT_FLIPMODEL_PRESENTHISTORYTOKEN
{
D3DKMT_ALIGN64 UINT64 FenceValue;
D3DKMT_ALIGN64 ULONG64 hLogicalSurface;
D3DKMT_ALIGN64 D3DKMT_UINT_PTR dxgContext;
D3DDDI_VIDEO_PRESENT_SOURCE_ID VidPnSourceId;
UINT SwapChainIndex;
D3DKMT_ALIGN64 UINT64 PresentLimitSemaphoreId;
D3DDDI_FLIPINTERVAL_TYPE FlipInterval;
D3DKMT_FLIPMODEL_PRESENTHISTORYTOKENFLAGS Flags;
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WIN8)
D3DKMT_ALIGN64 LONG64 hCompSurf;
LUID compSurfLuid;
D3DKMT_ALIGN64 UINT64 confirmationCookie;
D3DKMT_ALIGN64 UINT64 CompositionSyncKey;
UINT RemainingTokens;
RECT ScrollRect;
POINT ScrollOffset;
UINT PresentCount;
FLOAT RevealColor[4]; // index 0 == R, ... , 3 == A
D3DDDI_ROTATION Rotation;
union
{
D3DKMT_SCATTERBLTS ScatterBlts; // Unused
struct
{
HANDLE hSyncObject; // NT handle to FlipEx fence.
D3DDDI_HDR_METADATA_TYPE HDRMetaDataType;
union
{
D3DDDI_HDR_METADATA_HDR10 HDRMetaDataHDR10;
D3DDDI_HDR_METADATA_HDR10PLUS HDRMetaDataHDR10Plus;
};
};
};
UINT InkCookie;
RECT SourceRect;
UINT DestWidth;
UINT DestHeight;
RECT TargetRect;
// DXGI_MATRIX_3X2_F: _11 _12 _21 _22 _31 _32
FLOAT Transform[6];
UINT CustomDuration;
D3DDDI_FLIPINTERVAL_TYPE CustomDurationFlipInterval;
UINT PlaneIndex;
#endif
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_0)
D3DDDI_COLOR_SPACE_TYPE ColorSpace;
#endif
D3DKMT_DIRTYREGIONS DirtyRegions;
} D3DKMT_FLIPMODEL_PRESENTHISTORYTOKEN;
// User mode timeout is in milliseconds, kernel mode timeout is in 100 nanoseconds
#define FLIPEX_TIMEOUT_USER (2000)
#define FLIPEX_TIMEOUT_KERNEL (FLIPEX_TIMEOUT_USER*10000)
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_1)
typedef struct _D3DKMT_SURFACECOMPLETE_PRESENTHISTORYTOKEN
{
D3DKMT_ALIGN64 ULONG64 hLogicalSurface;
} D3DKMT_SURFACECOMPLETE_PRESENTHISTORYTOKEN;
#endif
typedef struct _D3DKMT_PRESENTHISTORYTOKEN
{
D3DKMT_PRESENT_MODEL Model;
// The size of the present history token in bytes including Model.
// Should be set to zero by when submitting a token.
// It will be initialized when reading present history and can be used to
// go to the next token in the present history buffer.
UINT TokenSize;
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WIN8)
// The binding id as specified by the Composition Surface
UINT64 CompositionBindingId;
#endif
union
{
D3DKMT_FLIPMODEL_PRESENTHISTORYTOKEN Flip;
D3DKMT_BLTMODEL_PRESENTHISTORYTOKEN Blt;
D3DKMT_VISTABLTMODEL_PRESENTHISTORYTOKEN VistaBlt;
D3DKMT_GDIMODEL_PRESENTHISTORYTOKEN Gdi;
D3DKMT_FENCE_PRESENTHISTORYTOKEN Fence;
D3DKMT_GDIMODEL_SYSMEM_PRESENTHISTORYTOKEN GdiSysMem;
D3DKMT_COMPOSITION_PRESENTHISTORYTOKEN Composition;
D3DKMT_FLIPMANAGER_PRESENTHISTORYTOKEN FlipManager;
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_1)
D3DKMT_SURFACECOMPLETE_PRESENTHISTORYTOKEN SurfaceComplete;
#endif
}
Token;
} D3DKMT_PRESENTHISTORYTOKEN;
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WIN8)
typedef struct _D3DKMT_PRESENT_RGNS
{
UINT DirtyRectCount;
D3DKMT_PTR(_Field_size_( DirtyRectCount ) const RECT*, pDirtyRects);
UINT MoveRectCount;
D3DKMT_PTR(_Field_size_( MoveRectCount ) const D3DKMT_MOVE_RECT*, pMoveRects);
}D3DKMT_PRESENT_RGNS;
#endif
typedef struct _D3DKMT_PRESENT
{
union
{
D3DKMT_HANDLE hDevice; // in: D3D10 compatibility.
D3DKMT_HANDLE hContext; // in: Indentifies the context
};
D3DKMT_PTR(HWND, hWindow); // in: window to present to
D3DDDI_VIDEO_PRESENT_SOURCE_ID VidPnSourceId; // in: VidPn source ID if RestrictVidPnSource is flagged
D3DKMT_HANDLE hSource; // in: Source allocation to present from
D3DKMT_HANDLE hDestination; // in: Destination allocation whenever non-zero
UINT Color; // in: color value in ARGB 32 bit format
RECT DstRect; // in: unclipped dest rect
RECT SrcRect; // in: unclipped src rect
UINT SubRectCnt; // in: count of sub rects
D3DKMT_PTR(CONST RECT*, pSrcSubRects); // in: sub rects in source space
UINT PresentCount; // in: present counter
D3DDDI_FLIPINTERVAL_TYPE FlipInterval; // in: flip interval
D3DKMT_PRESENTFLAGS Flags; // in:
ULONG BroadcastContextCount; // in: Specifies the number of context
// to broadcast this command buffer to.
D3DKMT_HANDLE BroadcastContext[D3DDDI_MAX_BROADCAST_CONTEXT]; // in: Specifies the handle of the context to
// broadcast to.
HANDLE PresentLimitSemaphore;
D3DKMT_PRESENTHISTORYTOKEN PresentHistoryToken;
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WIN8)
D3DKMT_PRESENT_RGNS* pPresentRegions;
#endif
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM1_3)
union
{
D3DKMT_HANDLE hAdapter; // in: iGpu adapter for PHT redirection. Valid only when the CrossAdapter flag is set.
D3DKMT_HANDLE hIndirectContext; // in: indirect adapter context for redirecting through the DoD present path. Only
// valid if PresentIndirect flag is set.
};
UINT Duration; // in: Per-present duration. Valid only when the DurationValid flag is set.
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_0)
D3DKMT_PTR(_Field_size_(BroadcastContextCount)
D3DKMT_HANDLE*, BroadcastSrcAllocation); // in: LDA
D3DKMT_PTR(_Field_size_opt_(BroadcastContextCount)
D3DKMT_HANDLE*, BroadcastDstAllocation); // in: LDA
UINT PrivateDriverDataSize; // in:
D3DKMT_PTR(_Field_size_bytes_(PrivateDriverDataSize)
PVOID, pPrivateDriverData); // in: Private driver data to pass to DdiPresent and DdiSetVidPnSourceAddress
BOOLEAN bOptimizeForComposition; // out: DWM is involved in composition
#endif // (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_0)
#endif // (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM1_3)
} D3DKMT_PRESENT;
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_3)
typedef struct _D3DKMT_PRESENT_REDIRECTEDS_FLAGS
{
union
{
struct
{
UINT Reserved : 32; // 0xFFFFFFFF
};
UINT Value;
};
}D3DKMT_PRESENT_REDIRECTED_FLAGS;
typedef struct _D3DKMT_PRESENT_REDIRECTED
{
D3DKMT_HANDLE hSyncObj; // in: Sync object PHT waits on
D3DKMT_HANDLE hDevice; // in: Device associated with the present
D3DKMT_ALIGN64 ULONGLONG WaitedFenceValue; // in: Fence value of hSyncObj that PHT waits on
D3DKMT_PRESENTHISTORYTOKEN PresentHistoryToken;
D3DKMT_PRESENT_REDIRECTED_FLAGS Flags;
D3DKMT_HANDLE hSource; // in: Source allocation to present from
UINT PrivateDriverDataSize; // in:
D3DKMT_PTR(_Field_size_bytes_(PrivateDriverDataSize)
PVOID, pPrivateDriverData); // in: Private driver data to pass to DdiPresent and DdiSetVidPnSourceAddress
}D3DKMT_PRESENT_REDIRECTED;
#endif
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM3_0)
typedef struct _D3DKMT_CANCEL_PRESENTS_FLAGS
{
union
{
// D3DKMT_CANCEL_PRESENTS_OPERATION_REPROGRAM_INTERRUPT flags
struct
{
UINT NewVSyncInterruptState : 1;
UINT Reserved : 31;
} ReprogramInterrupt;
UINT Value;
};
}D3DKMT_CANCEL_PRESENTS_FLAGS;
typedef enum D3DKMT_CANCEL_PRESENTS_OPERATION
{
D3DKMT_CANCEL_PRESENTS_OPERATION_CANCEL_FROM = 0,
D3DKMT_CANCEL_PRESENTS_OPERATION_REPROGRAM_INTERRUPT = 1
} D3DKMT_CANCEL_PRESENTS_OPERATION;
typedef struct _D3DKMT_CANCEL_PRESENTS
{
UINT cbSize;
D3DKMT_HANDLE hDevice;
D3DKMT_CANCEL_PRESENTS_FLAGS Flags;
D3DKMT_CANCEL_PRESENTS_OPERATION Operation;
D3DKMT_ALIGN64 UINT64 CancelFromPresentId;
LUID CompSurfaceLuid;
D3DKMT_ALIGN64 UINT64 BindId;
}D3DKMT_CANCEL_PRESENTS;
#endif
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_4)
typedef struct _D3DKMT_SUBMITPRESENTBLTTOHWQUEUE
{
D3DKMT_HANDLE hHwQueue;
D3DKMT_ALIGN64 UINT64 HwQueueProgressFenceId;
D3DKMT_PRESENT PrivatePresentData;
} D3DKMT_SUBMITPRESENTBLTTOHWQUEUE;
#endif
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_5)
typedef struct _D3DKMT_SUBMITPRESENTTOHWQUEUE
{
D3DKMT_PTR(_Field_size_(PrivatePresentData.BroadcastContextCount + 1)
D3DKMT_HANDLE*, hHwQueues);
D3DKMT_PRESENT PrivatePresentData;
} D3DKMT_SUBMITPRESENTTOHWQUEUE;
#endif
#define D3DKMT_MAX_MULTIPLANE_OVERLAY_PLANES 8
#define D3DKMT_MAX_MULTIPLANE_OVERLAY_ALLOCATIONS_PER_PLANE 256
typedef enum D3DKMT_MULTIPLANE_OVERLAY_FLAGS
{
D3DKMT_MULTIPLANE_OVERLAY_FLAG_VERTICAL_FLIP = 0x1,
D3DKMT_MULTIPLANE_OVERLAY_FLAG_HORIZONTAL_FLIP = 0x2,
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM3_0)
D3DKMT_MULTIPLANE_OVERLAY_FLAG_STATIC_CHECK = 0x4,
#endif // DXGKDDI_INTERFACE_VERSION_WDDM3_0
} D3DKMT_MULTIPLANE_OVERLAY_FLAGS;
typedef enum D3DKMT_MULTIPLANE_OVERLAY_BLEND
{
D3DKMT_MULTIPLANE_OVERLAY_BLEND_OPAQUE = 0x0,
D3DKMT_MULTIPLANE_OVERLAY_BLEND_ALPHABLEND = 0x1,
} D3DKMT_MULTIPLANE_OVERLAY_BLEND;
typedef enum D3DKMT_MULTIPLANE_OVERLAY_VIDEO_FRAME_FORMAT
{
D3DKMT_MULIIPLANE_OVERLAY_VIDEO_FRAME_FORMAT_PROGRESSIVE = 0,
D3DKMT_MULTIPLANE_OVERLAY_VIDEO_FRAME_FORMAT_INTERLACED_TOP_FIELD_FIRST = 1,
D3DKMT_MULTIPLANE_OVERLAY_VIDEO_FRAME_FORMAT_INTERLACED_BOTTOM_FIELD_FIRST = 2
} D3DKMT_MULTIPLANE_OVERLAY_VIDEO_FRAME_FORMAT;
typedef enum D3DKMT_MULTIPLANE_OVERLAY_YCbCr_FLAGS
{
D3DKMT_MULTIPLANE_OVERLAY_YCbCr_FLAG_NOMINAL_RANGE = 0x1, // 16 - 235 vs. 0 - 255
D3DKMT_MULTIPLANE_OVERLAY_YCbCr_FLAG_BT709 = 0x2, // BT.709 vs. BT.601
D3DKMT_MULTIPLANE_OVERLAY_YCbCr_FLAG_xvYCC = 0x4, // xvYCC vs. conventional YCbCr
} D3DKMT_MULTIPLANE_OVERLAY_YCbCr_FLAGS;
typedef enum D3DKMT_MULTIPLANE_OVERLAY_STEREO_FORMAT
{
DXGKMT_MULTIPLANE_OVERLAY_STEREO_FORMAT_MONO = 0,
D3DKMT_MULTIPLANE_OVERLAY_STEREO_FORMAT_HORIZONTAL = 1,
D3DKMT_MULTIPLANE_OVERLAY_STEREO_FORMAT_VERTICAL = 2,
DXGKMT_MULTIPLANE_OVERLAY_STEREO_FORMAT_SEPARATE = 3,
DXGKMT_MULTIPLANE_OVERLAY_STEREO_FORMAT_MONO_OFFSET = 4,
DXGKMT_MULTIPLANE_OVERLAY_STEREO_FORMAT_ROW_INTERLEAVED = 5,
DXGKMT_MULTIPLANE_OVERLAY_STEREO_FORMAT_COLUMN_INTERLEAVED = 6,
DXGKMT_MULTIPLANE_OVERLAY_STEREO_FORMAT_CHECKERBOARD = 7
} D3DKMT_MULTIPLANE_OVERLAY_STEREO_FORMAT;
typedef enum _DXGKMT_MULTIPLANE_OVERLAY_STEREO_FLIP_MODE
{
DXGKMT_MULTIPLANE_OVERLAY_STEREO_FLIP_NONE = 0,
DXGKMT_MULTIPLANE_OVERLAY_STEREO_FLIP_FRAME0 = 1,
DXGKMT_MULTIPLANE_OVERLAY_STEREO_FLIP_FRAME1 = 2,
} DXGKMT_MULTIPLANE_OVERLAY_STEREO_FLIP_MODE;
typedef enum _DXGKMT_MULTIPLANE_OVERLAY_STRETCH_QUALITY
{
DXGKMT_MULTIPLANE_OVERLAY_STRETCH_QUALITY_BILINEAR = 0x1, // Bilinear
DXGKMT_MULTIPLANE_OVERLAY_STRETCH_QUALITY_HIGH = 0x2, // Maximum
} DXGKMT_MULTIPLANE_OVERLAY_STRETCH_QUALITY;
typedef struct D3DKMT_MULTIPLANE_OVERLAY_ATTRIBUTES
{
UINT Flags; // D3DKMT_MULTIPLANE_OVERLAY_FLAGS
RECT SrcRect;
RECT DstRect;
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM1_3)
RECT ClipRect;
#endif
D3DDDI_ROTATION Rotation;
D3DKMT_MULTIPLANE_OVERLAY_BLEND Blend;
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM1_3)
UINT DirtyRectCount;
D3DKMT_PTR(RECT*, pDirtyRects);
#else
UINT NumFilters;
D3DKMT_PTR(void*, pFilters);
#endif
D3DKMT_MULTIPLANE_OVERLAY_VIDEO_FRAME_FORMAT VideoFrameFormat;
UINT YCbCrFlags; // D3DKMT_MULTIPLANE_OVERLAY_YCbCr_FLAGS
D3DKMT_MULTIPLANE_OVERLAY_STEREO_FORMAT StereoFormat;
BOOL StereoLeftViewFrame0;
BOOL StereoBaseViewFrame0;
DXGKMT_MULTIPLANE_OVERLAY_STEREO_FLIP_MODE StereoFlipMode;
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM1_3)
DXGKMT_MULTIPLANE_OVERLAY_STRETCH_QUALITY StretchQuality;
#endif
} D3DKMT_MULTIPLANE_OVERLAY_ATTRIBUTES;
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM_1_3)
typedef struct D3DKMT_CHECK_MULTIPLANE_OVERLAY_PLANE
{
D3DKMT_HANDLE hResource;
LUID CompSurfaceLuid;
D3DDDI_VIDEO_PRESENT_SOURCE_ID VidPnSourceId;
D3DKMT_MULTIPLANE_OVERLAY_ATTRIBUTES PlaneAttributes;
} D3DKMT_CHECK_MULTIPLANE_OVERLAY_PLANE;
typedef struct D3DKMT_CHECK_MULTIPLANE_OVERLAY_SUPPORT_RETURN_INFO
{
union
{
struct
{
UINT FailingPlane : 4; // The 0 based index of the first plane that could not be supported
UINT TryAgain : 1; // The configuration is not supported due to a transition condition, which should shortly go away
UINT Reserved : 27;
};
UINT Value;
};
} D3DKMT_CHECK_MULTIPLANE_OVERLAY_SUPPORT_RETURN_INFO;
typedef struct _D3DKMT_CHECKMULTIPLANEOVERLAYSUPPORT
{
D3DKMT_HANDLE hDevice; // in : Indentifies the device
UINT PlaneCount; // in : Number of resources to pin
D3DKMT_PTR(D3DKMT_CHECK_MULTIPLANE_OVERLAY_PLANE*, pOverlayPlanes); // in : Array of resource handles to pin
BOOL Supported;
D3DKMT_CHECK_MULTIPLANE_OVERLAY_SUPPORT_RETURN_INFO ReturnInfo;
} D3DKMT_CHECKMULTIPLANEOVERLAYSUPPORT;
#endif
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM_2_0)
typedef struct _D3DKMT_MULTIPLANE_OVERLAY_ATTRIBUTES2
{
UINT Flags; // D3DKMT_MULTIPLANE_OVERLAY_FLAGS
RECT SrcRect; // Specifies the source rectangle, of type RECT, relative to the source resource.
RECT DstRect; // Specifies the destination rectangle, of type RECT, relative to the monitor resolution.
RECT ClipRect; // Specifies any additional clipping, of type RECT, relative to the DstRect rectangle,
// after the data has been stretched according to the values of SrcRect and DstRect.
// The driver and hardware can use the ClipRect member to apply a common stretch factor
// as the clipping changes when an app occludes part of the DstRect destination rectangle.
D3DDDI_ROTATION Rotation; // Specifies the clockwise rotation of the overlay plane, given as a value from the D3DDDI_ROTATION enumeration.
D3DKMT_MULTIPLANE_OVERLAY_BLEND Blend; // Specifies the blend mode that applies to this overlay plane and the plane beneath it, given as a value from the DXGK_MULTIPLANE_OVERLAY_BLEND enumeration.
UINT DirtyRectCount;
D3DKMT_PTR(RECT*, pDirtyRects);
D3DKMT_MULTIPLANE_OVERLAY_VIDEO_FRAME_FORMAT VideoFrameFormat; // DXGK_MULTIPLANE_OVERLAY_VIDEO_FRAME_FORMAT
D3DDDI_COLOR_SPACE_TYPE ColorSpace;
D3DKMT_MULTIPLANE_OVERLAY_STEREO_FORMAT StereoFormat; // DXGK_MULTIPLANE_OVERLAY_STEREO_FORMAT
BOOL StereoLeftViewFrame0; // Reserved for system use. Must always be FALSE.
BOOL StereoBaseViewFrame0; // Reserved for system use. Must always be FALSE.
DXGKMT_MULTIPLANE_OVERLAY_STEREO_FLIP_MODE StereoFlipMode; // DXGK_MULTIPLANE_OVERLAY_STEREO_FLIP_MODE
DXGKMT_MULTIPLANE_OVERLAY_STRETCH_QUALITY StretchQuality; // DXGK_MULTIPLANE_OVERLAY_STRETCH_QUALITY
UINT Reserved1;
} D3DKMT_MULTIPLANE_OVERLAY_ATTRIBUTES2;
typedef struct _D3DKMT_CHECK_MULTIPLANE_OVERLAY_PLANE2
{
UINT LayerIndex;
D3DKMT_HANDLE hResource;
LUID CompSurfaceLuid;
D3DDDI_VIDEO_PRESENT_SOURCE_ID VidPnSourceId;
D3DKMT_MULTIPLANE_OVERLAY_ATTRIBUTES2 PlaneAttributes;
} D3DKMT_CHECK_MULTIPLANE_OVERLAY_PLANE2;
typedef struct _D3DKMT_CHECKMULTIPLANEOVERLAYSUPPORT2
{
D3DKMT_HANDLE hAdapter; // in: adapter handle
D3DKMT_HANDLE hDevice; // in : Indentifies the device
UINT PlaneCount; // in : Number of resources to pin
D3DKMT_PTR(D3DKMT_CHECK_MULTIPLANE_OVERLAY_PLANE2*, pOverlayPlanes); // in : Array of resource handles to pin
BOOL Supported;
D3DKMT_CHECK_MULTIPLANE_OVERLAY_SUPPORT_RETURN_INFO ReturnInfo;
} D3DKMT_CHECKMULTIPLANEOVERLAYSUPPORT2;
typedef struct _D3DKMT_MULTIPLANE_OVERLAY2
{
UINT LayerIndex;
BOOL Enabled;
D3DKMT_HANDLE hAllocation;
D3DKMT_MULTIPLANE_OVERLAY_ATTRIBUTES2 PlaneAttributes;
} D3DKMT_MULTIPLANE_OVERLAY2;
typedef struct _D3DKMT_PRESENT_MULTIPLANE_OVERLAY2
{
D3DKMT_HANDLE hAdapter; // in: adapter handle
union
{
D3DKMT_HANDLE hDevice; // in: D3D10 compatibility.
D3DKMT_HANDLE hContext; // in: Indentifies the context
};
ULONG BroadcastContextCount; // in: Specifies the number of context
// to broadcast this command buffer to.
D3DKMT_HANDLE BroadcastContext[D3DDDI_MAX_BROADCAST_CONTEXT]; // in: Specifies the handle of the context to
// broadcast to.
D3DDDI_VIDEO_PRESENT_SOURCE_ID VidPnSourceId; // in: VidPn source ID if RestrictVidPnSource is flagged
UINT PresentCount; // in: present counter
D3DDDI_FLIPINTERVAL_TYPE FlipInterval; // in: flip interval
D3DKMT_PRESENTFLAGS Flags; // in:
UINT PresentPlaneCount;
D3DKMT_PTR(D3DKMT_MULTIPLANE_OVERLAY2*, pPresentPlanes);
UINT Duration;
} D3DKMT_PRESENT_MULTIPLANE_OVERLAY2;
#endif // DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_0
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_1)
typedef struct _D3DKMT_MULTIPLANE_OVERLAY_ATTRIBUTES3
{
UINT Flags; // D3DKMT_MULTIPLANE_OVERLAY_FLAGS
RECT SrcRect; // Specifies the source rectangle, of type RECT, relative to the source resource.
RECT DstRect; // Specifies the destination rectangle, of type RECT, relative to the monitor resolution.
RECT ClipRect; // Specifies any additional clipping, of type RECT, relative to the DstRect rectangle,
// after the data has been stretched according to the values of SrcRect and DstRect.
// The driver and hardware can use the ClipRect member to apply a common stretch factor
// as the clipping changes when an app occludes part of the DstRect destination rectangle.
D3DDDI_ROTATION Rotation; // Specifies the clockwise rotation of the overlay plane, given as a value from the D3DDDI_ROTATION enumeration.
D3DKMT_MULTIPLANE_OVERLAY_BLEND Blend; // Specifies the blend mode that applies to this overlay plane and the plane beneath it, given as a value from the DXGK_MULTIPLANE_OVERLAY_BLEND enumeration.
UINT DirtyRectCount;
D3DKMT_PTR(_Field_size_(DirtyRectCount) RECT*, pDirtyRects);
D3DDDI_COLOR_SPACE_TYPE ColorSpace;
DXGKMT_MULTIPLANE_OVERLAY_STRETCH_QUALITY StretchQuality; // DXGK_MULTIPLANE_OVERLAY_STRETCH_QUALITY
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_3)
UINT SDRWhiteLevel;
#endif
} D3DKMT_MULTIPLANE_OVERLAY_ATTRIBUTES3;
typedef struct _D3DKMT_CHECK_MULTIPLANE_OVERLAY_PLANE3
{
UINT LayerIndex;
D3DKMT_HANDLE hResource;
LUID CompSurfaceLuid;
D3DDDI_VIDEO_PRESENT_SOURCE_ID VidPnSourceId;
D3DKMT_PTR(D3DKMT_MULTIPLANE_OVERLAY_ATTRIBUTES3*, pPlaneAttributes);
} D3DKMT_CHECK_MULTIPLANE_OVERLAY_PLANE3;
typedef struct _D3DKMT_MULTIPLANE_OVERLAY_POST_COMPOSITION_FLAGS
{
union
{
struct
{
UINT VerticalFlip : 1; // 0x00000001
UINT HorizontalFlip : 1; // 0x00000002
UINT Reserved :30; // 0xFFFFFFFC
};
UINT Value;
};
} D3DKMT_MULTIPLANE_OVERLAY_POST_COMPOSITION_FLAGS;
typedef struct _D3DKMT_MULTIPLANE_OVERLAY_POST_COMPOSITION
{
D3DKMT_MULTIPLANE_OVERLAY_POST_COMPOSITION_FLAGS Flags;
RECT SrcRect;
RECT DstRect;
D3DDDI_ROTATION Rotation;
} D3DKMT_MULTIPLANE_OVERLAY_POST_COMPOSITION;
typedef struct _D3DKMT_MULTIPLANE_OVERLAY_POST_COMPOSITION_WITH_SOURCE
{
D3DDDI_VIDEO_PRESENT_SOURCE_ID VidPnSourceId;
D3DKMT_MULTIPLANE_OVERLAY_POST_COMPOSITION PostComposition;
} D3DKMT_MULTIPLANE_OVERLAY_POST_COMPOSITION_WITH_SOURCE;
typedef struct _D3DKMT_CHECKMULTIPLANEOVERLAYSUPPORT3
{
D3DKMT_HANDLE hAdapter; // in: adapter handle
D3DKMT_HANDLE hDevice; // in : Indentifies the device
UINT PlaneCount; // in : Number of resources to pin
// Note: Array-of-pointers don't work in 32bit WSL
_Field_size_(PlaneCount)
D3DKMT_CHECK_MULTIPLANE_OVERLAY_PLANE3** ppOverlayPlanes; // in : Array of pointers to overlay planes
UINT PostCompositionCount; // in : Number of resources to pin
_Field_size_(PostCompositionCount)
D3DKMT_MULTIPLANE_OVERLAY_POST_COMPOSITION_WITH_SOURCE** ppPostComposition; // in : Array of pointers to overlay planes
BOOL Supported;
D3DKMT_CHECK_MULTIPLANE_OVERLAY_SUPPORT_RETURN_INFO ReturnInfo;
} D3DKMT_CHECKMULTIPLANEOVERLAYSUPPORT3;
typedef struct _D3DKMT_PLANE_SPECIFIC_INPUT_FLAGS
{
union
{
struct
{
UINT Enabled : 1; // 0x00000001
UINT Reserved :31; // 0xFFFFFFFE
};
UINT Value;
};
} D3DKMT_PLANE_SPECIFIC_INPUT_FLAGS;
typedef struct _D3DKMT_PLANE_SPECIFIC_OUTPUT_FLAGS
{
union
{
struct
{
UINT FlipConvertedToImmediate : 1; // 0x00000001
UINT Reserved :31; // 0xFFFFFFFE
};
UINT Value;
};
} D3DKMT_PLANE_SPECIFIC_OUTPUT_FLAGS;
typedef struct _D3DKMT_MULTIPLANE_OVERLAY3
{
UINT LayerIndex;
D3DKMT_PLANE_SPECIFIC_INPUT_FLAGS InputFlags;
D3DDDI_FLIPINTERVAL_TYPE FlipInterval;
UINT MaxImmediateFlipLine;
UINT AllocationCount;
D3DKMT_PTR(_Field_size_(AllocationCount)
D3DKMT_HANDLE*, pAllocationList);
UINT DriverPrivateDataSize;
D3DKMT_PTR(_Field_size_bytes_(DriverPrivateDataSize)
VOID*, pDriverPrivateData);
D3DKMT_PTR(const D3DKMT_MULTIPLANE_OVERLAY_ATTRIBUTES3*, pPlaneAttributes);
D3DKMT_HANDLE hFlipToFence;
D3DKMT_HANDLE hFlipAwayFence;
D3DKMT_ALIGN64 UINT64 FlipToFenceValue;
D3DKMT_ALIGN64 UINT64 FlipAwayFenceValue;
} D3DKMT_MULTIPLANE_OVERLAY3;
typedef struct _D3DKMT_PRESENT_MULTIPLANE_OVERLAY_FLAGS
{
union
{
struct
{
UINT FlipStereo : 1; // 0x00000001 This is a flip from a stereo alloc. Used in addition to FlipImmediate or FlipOnNextVSync.
UINT FlipStereoTemporaryMono : 1; // 0x00000002 This is a flip from a stereo alloc. The left image should used. Used in addition to FlipImmediate or FlipOnNextVSync.
UINT FlipStereoPreferRight : 1; // 0x00000004 This is a flip from a stereo alloc. The right image should used when cloning to a mono monitor. Used in addition to FlipImmediate or FlipOnNextVSync.
UINT FlipDoNotWait : 1; // 0x00000008
UINT FlipDoNotFlip : 1; // 0x00000010
UINT FlipRestart : 1; // 0x00000020
UINT DurationValid : 1; // 0x00000040
UINT HDRMetaDataValid : 1; // 0x00000080
UINT HMD : 1; // 0x00000100
UINT TrueImmediate : 1; // 0x00000200 If a present interval is 0, allow tearing rather than override a previously queued flip
UINT Reserved :22; // 0xFFFFFE00
};
UINT Value;
};
} D3DKMT_PRESENT_MULTIPLANE_OVERLAY_FLAGS;
typedef struct _D3DKMT_PRESENT_MULTIPLANE_OVERLAY3
{
D3DKMT_HANDLE hAdapter; // in: adapter handle
UINT ContextCount;
D3DKMT_PTR(_Field_size_(ContextCount)
D3DKMT_HANDLE*, pContextList);
D3DDDI_VIDEO_PRESENT_SOURCE_ID VidPnSourceId; // in: VidPn source ID if RestrictVidPnSource is flagged
UINT PresentCount; // in: present counter
D3DKMT_PRESENT_MULTIPLANE_OVERLAY_FLAGS Flags; // in:
UINT PresentPlaneCount;
// Note: Array-of-pointers don't work in 32bit WSL
_Field_size_(PresentPlaneCount)
D3DKMT_MULTIPLANE_OVERLAY3** ppPresentPlanes;
D3DKMT_PTR(D3DKMT_MULTIPLANE_OVERLAY_POST_COMPOSITION*, pPostComposition);
UINT Duration;
D3DDDI_HDR_METADATA_TYPE HDRMetaDataType;
UINT HDRMetaDataSize;
D3DKMT_PTR(_Field_size_bytes_(HDRMetaDataSize)
const VOID*, pHDRMetaData);
UINT BoostRefreshRateMultiplier;
} D3DKMT_PRESENT_MULTIPLANE_OVERLAY3;
#endif // DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_1
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_2)
typedef struct _D3DKMT_MULTIPLANE_OVERLAY_CAPS
{
union
{
struct
{
UINT Rotation : 1; // Full rotation
UINT RotationWithoutIndependentFlip : 1; // Rotation, but without simultaneous IndependentFlip support
UINT VerticalFlip : 1; // Can flip the data vertically
UINT HorizontalFlip : 1; // Can flip the data horizontally
UINT StretchRGB : 1; // Supports stretching RGB formats
UINT StretchYUV : 1; // Supports stretching YUV formats
UINT BilinearFilter : 1; // Blinear filtering
UINT HighFilter : 1; // Better than bilinear filtering
UINT Shared : 1; // MPO resources are shared across VidPnSources
UINT Immediate : 1; // Immediate flip support
UINT Plane0ForVirtualModeOnly : 1; // Stretching plane 0 will also stretch the HW cursor and should only be used for virtual mode support
UINT Version3DDISupport : 1; // Driver supports the 2.2 MPO DDIs
UINT Reserved : 20;
};
UINT Value;
};
} D3DKMT_MULTIPLANE_OVERLAY_CAPS;
typedef struct _D3DKMT_GET_MULTIPLANE_OVERLAY_CAPS
{
D3DKMT_HANDLE hAdapter; // in: adapter handle
D3DDDI_VIDEO_PRESENT_SOURCE_ID VidPnSourceId; // in
UINT MaxPlanes; // out: Total number of planes currently supported
UINT MaxRGBPlanes; // out: Number of RGB planes currently supported
UINT MaxYUVPlanes; // out: Number of YUV planes currently supported
D3DKMT_MULTIPLANE_OVERLAY_CAPS OverlayCaps; // out: Overlay capabilities
float MaxStretchFactor; // out
float MaxShrinkFactor; // out
} D3DKMT_GET_MULTIPLANE_OVERLAY_CAPS;
typedef struct _D3DKMT_GET_POST_COMPOSITION_CAPS
{
D3DKMT_HANDLE hAdapter; // in: adapter handle
D3DDDI_VIDEO_PRESENT_SOURCE_ID VidPnSourceId; // in
float MaxStretchFactor; // out
float MaxShrinkFactor; // out
} D3DKMT_GET_POST_COMPOSITION_CAPS;
typedef struct _D3DKMT_MULTIPLANEOVERLAY_STRETCH_SUPPORT
{
UINT VidPnSourceId;
BOOL Update;
BOOL Supported;
} D3DKMT_MULTIPLANEOVERLAY_STRETCH_SUPPORT;
#endif // DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_2
typedef struct D3DKMT_MULTIPLANE_OVERLAY
{
UINT LayerIndex;
BOOL Enabled;
D3DKMT_HANDLE hAllocation;
D3DKMT_MULTIPLANE_OVERLAY_ATTRIBUTES PlaneAttributes;
} D3DKMT_MULTIPLANE_OVERLAY;
typedef struct D3DKMT_PRESENT_MULTIPLANE_OVERLAY
{
union
{
D3DKMT_HANDLE hDevice; // in: D3D10 compatibility.
D3DKMT_HANDLE hContext; // in: Indentifies the context
};
ULONG BroadcastContextCount; // in: Specifies the number of context
// to broadcast this command buffer to.
D3DKMT_HANDLE BroadcastContext[D3DDDI_MAX_BROADCAST_CONTEXT]; // in: Specifies the handle of the context to
// broadcast to.
D3DDDI_VIDEO_PRESENT_SOURCE_ID VidPnSourceId; // in: VidPn source ID if RestrictVidPnSource is flagged
UINT PresentCount; // in: present counter
D3DDDI_FLIPINTERVAL_TYPE FlipInterval; // in: flip interval
D3DKMT_PRESENTFLAGS Flags; // in:
UINT PresentPlaneCount;
D3DKMT_MULTIPLANE_OVERLAY* pPresentPlanes;
UINT Duration;
} D3DKMT_PRESENT_MULTIPLANE_OVERLAY;
typedef struct _D3DKMT_RENDERFLAGS
{
UINT ResizeCommandBuffer : 1; // 0x00000001
UINT ResizeAllocationList : 1; // 0x00000002
UINT ResizePatchLocationList : 1; // 0x00000004
UINT NullRendering : 1; // 0x00000008
UINT PresentRedirected : 1; // 0x00000010
UINT RenderKm : 1; // 0x00000020 Cannot be used with DxgkRender
UINT RenderKmReadback : 1; // 0x00000040 Cannot be used with DxgkRender
UINT Reserved : 25; // 0xFFFFFF80
} D3DKMT_RENDERFLAGS;
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WIN8)
typedef struct _D3DKMT_OUTPUTDUPLPRESENTFLAGS
{
union
{
struct
{
UINT ProtectedContentBlankedOut : 1;
UINT RemoteSession : 1;
UINT FullScreenPresent : 1;
UINT PresentIndirect : 1;
UINT Reserved : 28;
};
UINT Value;
};
}D3DKMT_OUTPUTDUPLPRESENTFLAGS;
typedef struct _D3DKMT_OUTPUTDUPLPRESENT
{
D3DKMT_HANDLE hContext; // in: Indentifies the context
D3DKMT_HANDLE hSource; // in: Source allocation to present from
D3DDDI_VIDEO_PRESENT_SOURCE_ID VidPnSourceId;
ULONG BroadcastContextCount; // in: Specifies the number of context
D3DKMT_HANDLE BroadcastContext[D3DDDI_MAX_BROADCAST_CONTEXT]; // in: Specifies the handle of the context to
D3DKMT_PRESENT_RGNS PresentRegions; // in: Dirty and move regions
D3DKMT_OUTPUTDUPLPRESENTFLAGS Flags;
D3DKMT_HANDLE hIndirectContext;
} D3DKMT_OUTPUTDUPLPRESENT;
#endif
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_6)
typedef struct _D3DKMT_OUTPUTDUPLPRESENTTOHWQUEUE
{
D3DKMT_HANDLE hSource; // in: Source allocation to present from
D3DDDI_VIDEO_PRESENT_SOURCE_ID VidPnSourceId;
ULONG BroadcastHwQueueCount;
D3DKMT_PTR(_Field_size_(BroadcastHwQueueCount)
D3DKMT_HANDLE*, hHwQueues);
D3DKMT_PRESENT_RGNS PresentRegions; // in: Dirty and move regions
D3DKMT_OUTPUTDUPLPRESENTFLAGS Flags;
D3DKMT_HANDLE hIndirectHwQueue;
} D3DKMT_OUTPUTDUPLPRESENTTOHWQUEUE;
#endif
typedef struct _D3DKMT_RENDER
{
union
{
D3DKMT_HANDLE hDevice; // in: D3D10 compatibility.
D3DKMT_HANDLE hContext; // in: Indentifies the context
};
UINT CommandOffset; // in: offset in bytes from start
UINT CommandLength; // in: number of bytes
UINT AllocationCount; // in: Number of allocations in allocation list.
UINT PatchLocationCount; // in: Number of patch locations in patch allocation list.
D3DKMT_PTR(VOID*, pNewCommandBuffer); // out: Pointer to the next command buffer to use.
// in: When RenderKm flag is set, it points to a command buffer.
UINT NewCommandBufferSize; // in: Size requested for the next command buffer.
// out: Size of the next command buffer to use.
D3DKMT_PTR(D3DDDI_ALLOCATIONLIST*, pNewAllocationList); // out: Pointer to the next allocation list to use.
// in: When RenderKm flag is set, it points to an allocation list.
UINT NewAllocationListSize; // in: Size requested for the next allocation list.
// out: Size of the new allocation list.
D3DKMT_PTR(D3DDDI_PATCHLOCATIONLIST*, pNewPatchLocationList); // out: Pointer to the next patch location list.
UINT NewPatchLocationListSize; // in: Size requested for the next patch location list.
// out: Size of the new patch location list.
D3DKMT_RENDERFLAGS Flags; // in:
D3DKMT_ALIGN64 ULONGLONG PresentHistoryToken; // in: Present history token for redirected present calls
ULONG BroadcastContextCount; // in: Specifies the number of context
// to broadcast this command buffer to.
D3DKMT_HANDLE BroadcastContext[D3DDDI_MAX_BROADCAST_CONTEXT]; // in: Specifies the handle of the context to
// broadcast to.
ULONG QueuedBufferCount; // out: Number of DMA buffer queued to this context after this submission.
D3DKMT_ALIGN64 D3DGPU_VIRTUAL_ADDRESS NewCommandBuffer; // out: GPU virtual address of next command buffer to use. _ADVSCH_
D3DKMT_PTR(VOID*, pPrivateDriverData); // in: pointer to private driver data. _ADVSCH_
UINT PrivateDriverDataSize; // in: size of private driver data. _ADVSCH_
} D3DKMT_RENDER;
typedef enum _D3DKMT_STANDARDALLOCATIONTYPE
{
D3DKMT_STANDARDALLOCATIONTYPE_EXISTINGHEAP = 1,
D3DKMT_STANDARDALLOCATIONTYPE_INTERNALBACKINGSTORE = 2,
D3DKMT_STANDARDALLOCATIONTYPE_MAX,
} D3DKMT_STANDARDALLOCATIONTYPE;
typedef struct _D3DKMT_STANDARDALLOCATION_EXISTINGHEAP
{
D3DKMT_ALIGN64 D3DKMT_SIZE_T Size; // in: Size in bytes of existing heap
} D3DKMT_STANDARDALLOCATION_EXISTINGHEAP;
typedef struct _D3DKMT_CREATESTANDARDALLOCATIONFLAGS
{
union
{
struct
{
UINT Reserved : 32; // 0xFFFFFFFF
};
UINT Value;
};
} D3DKMT_CREATESTANDARDALLOCATIONFLAGS;
typedef struct _D3DKMT_CREATESTANDARDALLOCATION
{
//
// update onecoreuap/windows/core/ntuser/inc/whwin32.tpl when adding new memeber
// to this struct
//
D3DKMT_STANDARDALLOCATIONTYPE Type;
union
{
D3DKMT_STANDARDALLOCATION_EXISTINGHEAP ExistingHeapData;
};
D3DKMT_CREATESTANDARDALLOCATIONFLAGS Flags;
} D3DKMT_CREATESTANDARDALLOCATION;
typedef struct _D3DKMT_CREATEALLOCATIONFLAGS
{
UINT CreateResource : 1; // 0x00000001
UINT CreateShared : 1; // 0x00000002
UINT NonSecure : 1; // 0x00000004
UINT CreateProtected : 1; // 0x00000008 Cannot be used when allocation is created from the user mode.
UINT RestrictSharedAccess : 1; // 0x00000010
UINT ExistingSysMem : 1; // 0x00000020 Cannot be used when allocation is created from the user mode.
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WIN8)
UINT NtSecuritySharing : 1; // 0x00000040
UINT ReadOnly : 1; // 0x00000080
UINT CreateWriteCombined : 1; // 0x00000100 Cannot be used when allocation is created from the user mode.
UINT CreateCached : 1; // 0x00000200 Cannot be used when allocation is created from the user mode.
UINT SwapChainBackBuffer : 1; // 0x00000400 Specifies whether an allocation corresponds to a swap chain back buffer.
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM1_3)
UINT CrossAdapter : 1; // 0x00000800
UINT OpenCrossAdapter : 1; // 0x00001000 Cannot be used when allocation is created from the user mode.
UINT PartialSharedCreation : 1; // 0x00002000
UINT Zeroed : 1; // 0x00004000 // out: set when allocation fulfilled by zero pages
UINT WriteWatch : 1; // 0x00008000 // in: request Mm to track writes to pages of this allocation
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_3)
UINT StandardAllocation : 1; // 0x00010000 // in: use pStandardAllocation instead of pPrivateDriverData
UINT ExistingSection : 1; // 0x00020000 // in: Use Section Handle instead of SysMem in D3DDI_ALLOCATIONINFO2
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_6)
UINT AllowNotZeroed : 1; // 0x00040000 // in: indicate zeroed pages are not required
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_7)
UINT PhysicallyContiguous : 1; // 0x00080000 // in: indicate allocation must be physically contguous
UINT NoKmdAccess : 1; // 0x00100000 // in: KMD is not notified about the allocation
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM3_0)
UINT SharedDisplayable : 1; // 0x00200000
UINT Reserved : 10; // 0xFFC00000
#else
UINT Reserved : 11; // 0xFFE00000
#endif // (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM3_0)
#else
UINT Reserved : 13; // 0xFFF80000
#endif // (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_7)
#else
UINT Reserved : 14; // 0xFFFC0000
#endif //(DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_6)
#else
UINT Reserved : 16; // 0xFFFF0000
#endif //(DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_3)
#else
UINT Reserved : 21; // 0xFFFFF800
#endif // (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM1_3)
#else
UINT Reserved : 26; // 0xFFFFFFC0
#endif
} D3DKMT_CREATEALLOCATIONFLAGS;
typedef struct _D3DKMT_CREATEALLOCATION
{
D3DKMT_HANDLE hDevice;
D3DKMT_HANDLE hResource; //in/out:valid only within device
D3DKMT_HANDLE hGlobalShare; //out:Shared handle if CreateShared and not NtSecuritySharing
D3DKMT_PTR(_Field_size_bytes_(PrivateRuntimeDataSize)
CONST VOID*, pPrivateRuntimeData);
UINT PrivateRuntimeDataSize;
union
{
//
// update onecoreuap/windows/core/ntuser/inc/whwin32.tpl when adding new memeber
// to this union
//
D3DKMT_CREATESTANDARDALLOCATION* pStandardAllocation;
_Field_size_bytes_(PrivateDriverDataSize)
CONST VOID* pPrivateDriverData;
D3DKMT_PTR_HELPER( AlignUnionTo64_1)
};
UINT PrivateDriverDataSize;
UINT NumAllocations;
union
{
_Field_size_(NumAllocations) D3DDDI_ALLOCATIONINFO* pAllocationInfo;
#if ((DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WIN7) || \
(D3D_UMD_INTERFACE_VERSION >= D3D_UMD_INTERFACE_VERSION_WIN7))
_Field_size_(NumAllocations) D3DDDI_ALLOCATIONINFO2* pAllocationInfo2; // _ADVSCH_
#endif
D3DKMT_PTR_HELPER( AlignUnionTo64_2)
};
D3DKMT_CREATEALLOCATIONFLAGS Flags;
D3DKMT_PTR(HANDLE, hPrivateRuntimeResourceHandle); // opaque handle used for event tracing
} D3DKMT_CREATEALLOCATION;
typedef struct _D3DKMT_OPENRESOURCE
{
D3DKMT_HANDLE hDevice; // in : Indentifies the device
D3DKMT_HANDLE hGlobalShare; // in : Shared resource handle
UINT NumAllocations; // in : Number of allocations associated with the resource
union {
_Field_size_(NumAllocations) D3DDDI_OPENALLOCATIONINFO* pOpenAllocationInfo; // in : Array of open allocation structs
#if ((DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WIN7) || \
(D3D_UMD_INTERFACE_VERSION >= D3D_UMD_INTERFACE_VERSION_WIN7))
_Field_size_(NumAllocations) D3DDDI_OPENALLOCATIONINFO2* pOpenAllocationInfo2; // in : Array of open allocation structs // _ADVSCH_
#endif
D3DKMT_PTR_HELPER(AlignUnionTo64)
};
D3DKMT_PTR(_Field_size_bytes_(PrivateRuntimeDataSize) VOID*, pPrivateRuntimeData); // in : Caller supplied buffer where the runtime private data associated with this resource will be copied
UINT PrivateRuntimeDataSize; // in : Size in bytes of the pPrivateRuntimeData buffer
D3DKMT_PTR(_Field_size_bytes_(ResourcePrivateDriverDataSize) VOID*, pResourcePrivateDriverData); // in : Caller supplied buffer where the driver private data associated with the resource will be copied
UINT ResourcePrivateDriverDataSize; // in : Size in bytes of the pResourcePrivateDriverData buffer
D3DKMT_PTR(_Field_size_bytes_(TotalPrivateDriverDataBufferSize) VOID*, pTotalPrivateDriverDataBuffer); // in : Caller supplied buffer where the Driver private data will be stored
UINT TotalPrivateDriverDataBufferSize; // in/out : Size in bytes of pTotalPrivateDriverDataBuffer / Size in bytes of data written to pTotalPrivateDriverDataBuffer
D3DKMT_HANDLE hResource; // out : Handle for this resource in this process
}D3DKMT_OPENRESOURCE;
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WIN8)
typedef struct _D3DKMT_OPENRESOURCEFROMNTHANDLE
{
D3DKMT_HANDLE hDevice; // in : Indentifies the device
D3DKMT_PTR( HANDLE, hNtHandle); // in : Process's NT handle
UINT NumAllocations; // in : Number of allocations associated with the resource
D3DKMT_PTR(_Field_size_(NumAllocations) D3DDDI_OPENALLOCATIONINFO2*, pOpenAllocationInfo2); // in : Array of open allocation structs // _ADVSCH_
UINT PrivateRuntimeDataSize; // in : Size in bytes of the pPrivateRuntimeData buffer
D3DKMT_PTR(_Field_size_bytes_(PrivateRuntimeDataSize) VOID*, pPrivateRuntimeData); // in : Caller supplied buffer where the runtime private data associated with this resource will be copied
UINT ResourcePrivateDriverDataSize; // in : Size in bytes of the pResourcePrivateDriverData buffer
D3DKMT_PTR(_Field_size_bytes_(ResourcePrivateDriverDataSize) VOID*, pResourcePrivateDriverData); // in : Caller supplied buffer where the driver private data associated with the resource will be copied
UINT TotalPrivateDriverDataBufferSize; // in/out : Size in bytes of pTotalPrivateDriverDataBuffer / Size in bytes of data written to pTotalPrivateDriverDataBuffer
D3DKMT_PTR(_Field_size_bytes_(TotalPrivateDriverDataBufferSize) VOID*, pTotalPrivateDriverDataBuffer); // in : Caller supplied buffer where the Driver private data will be stored
D3DKMT_HANDLE hResource; // out : Handle for this resource in this process
D3DKMT_HANDLE hKeyedMutex; // out: Handle to the keyed mutex in this process
D3DKMT_PTR(_In_reads_bytes_opt_(PrivateRuntimeDataSize) VOID*, pKeyedMutexPrivateRuntimeData); // in: Buffer containing initial private data.
// If NULL then PrivateRuntimeDataSize must be 0.
// It will only be copied if the keyed mutex does not already have private data.
UINT KeyedMutexPrivateRuntimeDataSize; // in: Size in bytes of pPrivateRuntimeData.
D3DKMT_HANDLE hSyncObject; // out: Handle to sync object in this process.
} D3DKMT_OPENRESOURCEFROMNTHANDLE;
typedef struct _D3DKMT_OPENSYNCOBJECTFROMNTHANDLE
{
D3DKMT_PTR(HANDLE, hNtHandle); // in : NT handle for the sync object.
D3DKMT_HANDLE hSyncObject; // out: Handle to sync object in this process.
} D3DKMT_OPENSYNCOBJECTFROMNTHANDLE;
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_0)
typedef struct _D3DKMT_OPENSYNCOBJECTFROMNTHANDLE2
{
D3DKMT_PTR(HANDLE, hNtHandle); // in : NT handle for the sync object.
D3DKMT_HANDLE hDevice; // in : Device handle to use this sync object on.
D3DDDI_SYNCHRONIZATIONOBJECT_FLAGS Flags; // in : specifies sync object behavior for this device.
D3DKMT_HANDLE hSyncObject; // out: Handle to sync object in this process.
union
{
struct
{
D3DKMT_PTR(VOID*, FenceValueCPUVirtualAddress); // out: Read-only mapping of the fence value for the CPU
D3DKMT_ALIGN64 D3DGPU_VIRTUAL_ADDRESS FenceValueGPUVirtualAddress; // out: Read/write mapping of the fence value for the GPU
UINT EngineAffinity; // in: Defines physical adapters where the GPU VA should be mapped
} MonitoredFence;
D3DKMT_ALIGN64 UINT64 Reserved[8];
};
} D3DKMT_OPENSYNCOBJECTFROMNTHANDLE2;
typedef struct _D3DKMT_OPENSYNCOBJECTNTHANDLEFROMNAME
{
DWORD dwDesiredAccess;
D3DKMT_PTR(OBJECT_ATTRIBUTES*, pObjAttrib);
D3DKMT_PTR(HANDLE, hNtHandle);
} D3DKMT_OPENSYNCOBJECTNTHANDLEFROMNAME;
#endif // DXGKDDI_INTERFACE_VERSION_WDDM2_0
typedef struct _D3DKMT_OPENNTHANDLEFROMNAME
{
DWORD dwDesiredAccess;
D3DKMT_PTR(OBJECT_ATTRIBUTES*, pObjAttrib);
D3DKMT_PTR(HANDLE, hNtHandle);
} D3DKMT_OPENNTHANDLEFROMNAME;
#define SHARED_ALLOCATION_WRITE 0x1
#define SHARED_ALLOCATION_ALL_ACCESS (STANDARD_RIGHTS_REQUIRED | SHARED_ALLOCATION_WRITE)
typedef struct _D3DKMT_QUERYRESOURCEINFOFROMNTHANDLE
{
D3DKMT_HANDLE hDevice; // in : Indentifies the device
D3DKMT_PTR(HANDLE, hNtHandle); // in : Global resource handle to open
D3DKMT_PTR(VOID*, pPrivateRuntimeData); // in : Ptr to buffer that will receive runtime private data for the resource
UINT PrivateRuntimeDataSize; // in/out : Size in bytes of buffer passed in for runtime private data / If pPrivateRuntimeData was NULL then size in bytes of buffer required for the runtime private data otherwise size in bytes of runtime private data copied into the buffer
UINT TotalPrivateDriverDataSize; // out : Size in bytes of buffer required to hold all the DriverPrivate data for all of the allocations associated withe the resource
UINT ResourcePrivateDriverDataSize; // out : Size in bytes of the driver's resource private data
UINT NumAllocations; // out : Number of allocations associated with this resource
}D3DKMT_QUERYRESOURCEINFOFROMNTHANDLE;
#endif
typedef struct _D3DKMT_QUERYRESOURCEINFO
{
D3DKMT_HANDLE hDevice; // in : Indentifies the device
D3DKMT_HANDLE hGlobalShare; // in : Global resource handle to open
D3DKMT_PTR(VOID*, pPrivateRuntimeData); // in : Ptr to buffer that will receive runtime private data for the resource
UINT PrivateRuntimeDataSize; // in/out : Size in bytes of buffer passed in for runtime private data / If pPrivateRuntimeData was NULL then size in bytes of buffer required for the runtime private data otherwise size in bytes of runtime private data copied into the buffer
UINT TotalPrivateDriverDataSize; // out : Size in bytes of buffer required to hold all the DriverPrivate data for all of the allocations associated withe the resource
UINT ResourcePrivateDriverDataSize; // out : Size in bytes of the driver's resource private data
UINT NumAllocations; // out : Number of allocations associated with this resource
}D3DKMT_QUERYRESOURCEINFO;
typedef struct _D3DKMT_DESTROYALLOCATION
{
D3DKMT_HANDLE hDevice; // in: Indentifies the device
D3DKMT_HANDLE hResource;
D3DKMT_PTR(CONST D3DKMT_HANDLE*, phAllocationList); // in: pointer to an array allocation handles to destroy
UINT AllocationCount; // in: Number of allocations in phAllocationList
} D3DKMT_DESTROYALLOCATION;
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_0)
typedef struct _D3DKMT_DESTROYALLOCATION2
{
D3DKMT_HANDLE hDevice; // in: Indentifies the device
D3DKMT_HANDLE hResource;
D3DKMT_PTR(CONST D3DKMT_HANDLE*, phAllocationList); // in: pointer to an array allocation handles to destroy
UINT AllocationCount; // in: Number of allocations in phAllocationList
D3DDDICB_DESTROYALLOCATION2FLAGS Flags; // in: Bit field defined by D3DDDICB_DESTROYALLOCATION2FLAGS
} D3DKMT_DESTROYALLOCATION2;
#endif // DXGKDDI_INTERFACE_VERSION_WDDM2_0
typedef struct _D3DKMT_SETALLOCATIONPRIORITY
{
D3DKMT_HANDLE hDevice; // in: Indentifies the device
D3DKMT_HANDLE hResource; // in: Specify the resource to set priority to.
D3DKMT_PTR(CONST D3DKMT_HANDLE*, phAllocationList); // in: pointer to an array allocation handles to destroy
UINT AllocationCount; // in: Number of allocations in phAllocationList
D3DKMT_PTR(CONST UINT*, pPriorities); // in: New priority for each of the allocation in the array.
} D3DKMT_SETALLOCATIONPRIORITY;
typedef enum _D3DKMT_ALLOCATIONRESIDENCYSTATUS
{
D3DKMT_ALLOCATIONRESIDENCYSTATUS_RESIDENTINGPUMEMORY=1,
D3DKMT_ALLOCATIONRESIDENCYSTATUS_RESIDENTINSHAREDMEMORY=2,
D3DKMT_ALLOCATIONRESIDENCYSTATUS_NOTRESIDENT=3,
} D3DKMT_ALLOCATIONRESIDENCYSTATUS;
typedef struct _D3DKMT_QUERYALLOCATIONRESIDENCY
{
D3DKMT_HANDLE hDevice; // in: Indentifies the device
D3DKMT_HANDLE hResource; // in: pointer to resource owning the list of allocation.
D3DKMT_PTR(CONST D3DKMT_HANDLE*, phAllocationList); // in: pointer to an array allocation to get residency status.
UINT AllocationCount; // in: Number of allocations in phAllocationList
D3DKMT_PTR(D3DKMT_ALLOCATIONRESIDENCYSTATUS*, pResidencyStatus); // out: Residency status of each allocation in the array.
} D3DKMT_QUERYALLOCATIONRESIDENCY;
typedef struct _D3DKMT_GETRUNTIMEDATA
{
D3DKMT_HANDLE hAdapter;
D3DKMT_HANDLE hGlobalShare; // in: shared handle
D3DKMT_PTR(VOID*, pRuntimeData); // out: in: for a version?
UINT RuntimeDataSize; // in:
} D3DKMT_GETRUNTIMEDATA;
typedef enum _KMTUMDVERSION
{
KMTUMDVERSION_DX9 = 0,
KMTUMDVERSION_DX10,
KMTUMDVERSION_DX11,
KMTUMDVERSION_DX12,
NUM_KMTUMDVERSIONS
} KMTUMDVERSION;
typedef struct _D3DKMT_UMDFILENAMEINFO
{
KMTUMDVERSION Version; // In: UMD version
WCHAR UmdFileName[MAX_PATH]; // Out: UMD file name
} D3DKMT_UMDFILENAMEINFO;
#define D3DKMT_COMPONENTIZED_INDICATOR L'#'
#define D3DKMT_SUBKEY_DX9 L"DX9"
#define D3DKMT_SUBKEY_OPENGL L"OpenGL"
typedef struct _D3DKMT_OPENGLINFO
{
WCHAR UmdOpenGlIcdFileName[MAX_PATH];
ULONG Version;
ULONG Flags;
} D3DKMT_OPENGLINFO;
typedef struct _D3DKMT_SEGMENTSIZEINFO
{
D3DKMT_ALIGN64 ULONGLONG DedicatedVideoMemorySize;
D3DKMT_ALIGN64 ULONGLONG DedicatedSystemMemorySize;
D3DKMT_ALIGN64 ULONGLONG SharedSystemMemorySize;
} D3DKMT_SEGMENTSIZEINFO;
typedef struct _D3DKMT_SEGMENTGROUPSIZEINFO
{
UINT32 PhysicalAdapterIndex;
D3DKMT_SEGMENTSIZEINFO LegacyInfo;
D3DKMT_ALIGN64 ULONGLONG LocalMemory;
D3DKMT_ALIGN64 ULONGLONG NonLocalMemory;
D3DKMT_ALIGN64 ULONGLONG NonBudgetMemory;
} D3DKMT_SEGMENTGROUPSIZEINFO;
typedef struct _D3DKMT_WORKINGSETFLAGS
{
UINT UseDefault : 1; // 0x00000001
UINT Reserved : 31; // 0xFFFFFFFE
} D3DKMT_WORKINGSETFLAGS;
typedef struct _D3DKMT_WORKINGSETINFO
{
D3DKMT_WORKINGSETFLAGS Flags;
ULONG MinimumWorkingSetPercentile;
ULONG MaximumWorkingSetPercentile;
} D3DKMT_WORKINGSETINFO;
typedef struct _D3DKMT_FLIPINFOFLAGS
{
UINT FlipInterval : 1; // 0x00000001 // Set when kmd driver support FlipInterval natively
UINT Reserved : 31; // 0xFFFFFFFE
} D3DKMT_FLIPINFOFLAGS;
typedef struct _D3DKMT_FLIPQUEUEINFO
{
UINT MaxHardwareFlipQueueLength; // Max flip can be queued for hardware flip queue.
UINT MaxSoftwareFlipQueueLength; // Max flip can be queued for software flip queue for non-legacy device.
D3DKMT_FLIPINFOFLAGS FlipFlags;
} D3DKMT_FLIPQUEUEINFO;
typedef struct _D3DKMT_ADAPTERADDRESS
{
UINT BusNumber; // Bus number on which the physical device is located.
UINT DeviceNumber; // Index of the physical device on the bus.
UINT FunctionNumber; // Function number of the adapter on the physical device.
} D3DKMT_ADAPTERADDRESS;
typedef struct _D3DKMT_ADAPTERREGISTRYINFO
{
WCHAR AdapterString[MAX_PATH];
WCHAR BiosString[MAX_PATH];
WCHAR DacType[MAX_PATH];
WCHAR ChipType[MAX_PATH];
} D3DKMT_ADAPTERREGISTRYINFO;
typedef struct _D3DKMT_CURRENTDISPLAYMODE
{
D3DDDI_VIDEO_PRESENT_SOURCE_ID VidPnSourceId;
D3DKMT_DISPLAYMODE DisplayMode;
} D3DKMT_CURRENTDISPLAYMODE;
typedef struct _D3DKMT_VIRTUALADDRESSFLAGS // _ADVSCH_
{
UINT VirtualAddressSupported : 1;
UINT Reserved : 31;
} D3DKMT_VIRTUALADDRESSFLAGS;
typedef struct _D3DKMT_VIRTUALADDRESSINFO // _ADVSCH_
{
D3DKMT_VIRTUALADDRESSFLAGS VirtualAddressFlags;
} D3DKMT_VIRTUALADDRESSINFO;
typedef enum _QAI_DRIVERVERSION
{
KMT_DRIVERVERSION_WDDM_1_0 = 1000,
KMT_DRIVERVERSION_WDDM_1_1_PRERELEASE = 1102,
KMT_DRIVERVERSION_WDDM_1_1 = 1105,
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WIN8)
KMT_DRIVERVERSION_WDDM_1_2 = 1200,
#endif
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM1_3)
KMT_DRIVERVERSION_WDDM_1_3 = 1300,
#endif // DXGKDDI_INTERFACE_VERSION_WDDM1_3
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_0)
KMT_DRIVERVERSION_WDDM_2_0 = 2000,
#endif // DXGKDDI_INTERFACE_VERSION_WDDM2_0
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_1)
KMT_DRIVERVERSION_WDDM_2_1 = 2100,
#endif // DXGKDDI_INTERFACE_VERSION_WDDM2_1
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_2)
KMT_DRIVERVERSION_WDDM_2_2 = 2200,
#endif // DXGKDDI_INTERFACE_VERSION_WDDM2_2
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_3)
KMT_DRIVERVERSION_WDDM_2_3 = 2300,
#endif // DXGKDDI_INTERFACE_VERSION_WDDM2_3
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_4)
KMT_DRIVERVERSION_WDDM_2_4 = 2400,
#endif // DXGKDDI_INTERFACE_VERSION_WDDM2_4
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_5)
KMT_DRIVERVERSION_WDDM_2_5 = 2500,
#endif // DXGKDDI_INTERFACE_VERSION_WDDM2_5
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_6)
KMT_DRIVERVERSION_WDDM_2_6 = 2600,
#endif // DXGKDDI_INTERFACE_VERSION_WDDM2_6
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_7)
KMT_DRIVERVERSION_WDDM_2_7 = 2700,
#endif // DXGKDDI_INTERFACE_VERSION_WDDM2_7
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_8)
KMT_DRIVERVERSION_WDDM_2_8 = 2800,
#endif // DXGKDDI_INTERFACE_VERSION_WDDM2_8
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_9)
KMT_DRIVERVERSION_WDDM_2_9 = 2900,
#endif // DXGKDDI_INTERFACE_VERSION_WDDM2_9
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM3_0)
KMT_DRIVERVERSION_WDDM_3_0 = 3000
#endif // DXGKDDI_INTERFACE_VERSION_WDDM3_0
} D3DKMT_DRIVERVERSION;
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WIN8)
typedef struct _D3DKMT_ADAPTERTYPE
{
union
{
struct
{
UINT RenderSupported : 1;
UINT DisplaySupported : 1;
UINT SoftwareDevice : 1;
UINT PostDevice : 1;
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM1_3)
UINT HybridDiscrete : 1;
UINT HybridIntegrated : 1;
UINT IndirectDisplayDevice : 1;
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_3)
UINT Paravirtualized : 1;
UINT ACGSupported : 1;
UINT SupportSetTimingsFromVidPn : 1;
UINT Detachable : 1;
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_6)
UINT ComputeOnly : 1;
UINT Prototype : 1;
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_9)
UINT RuntimePowerManagement : 1;
UINT Reserved : 18;
#else
UINT Reserved : 19;
#endif // (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_9)
#else
UINT Reserved : 21;
#endif // (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_6)
#else
UINT Reserved : 25;
#endif // (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_3)
#else
UINT Reserved : 28;
#endif // (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM1_3)
};
UINT Value;
};
} D3DKMT_ADAPTERTYPE;
typedef struct _D3DKMT_OUTPUTDUPLCONTEXTSCOUNT
{
D3DDDI_VIDEO_PRESENT_SOURCE_ID VidPnSourceId;
UINT OutputDuplicationCount;
} D3DKMT_OUTPUTDUPLCONTEXTSCOUNT;
typedef struct _D3DKMT_UMD_DRIVER_VERSION
{
D3DKMT_ALIGN64 LARGE_INTEGER DriverVersion;
} D3DKMT_UMD_DRIVER_VERSION;
typedef struct _D3DKMT_KMD_DRIVER_VERSION
{
D3DKMT_ALIGN64 LARGE_INTEGER DriverVersion;
} D3DKMT_KMD_DRIVER_VERSION;
typedef struct _D3DKMT_DIRECTFLIP_SUPPORT
{
BOOL Supported;
} D3DKMT_DIRECTFLIP_SUPPORT;
typedef struct _D3DKMT_MULTIPLANEOVERLAY_SUPPORT
{
BOOL Supported;
} D3DKMT_MULTIPLANEOVERLAY_SUPPORT;
#endif
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM1_3_PATH_INDEPENDENT_ROTATION)
typedef struct _D3DKMT_MULTIPLANEOVERLAY_HUD_SUPPORT
{
UINT VidPnSourceId; // Not yet used.
BOOL Update;
BOOL KernelSupported;
BOOL HudSupported;
} D3DKMT_MULTIPLANEOVERLAY_HUD_SUPPORT;
#endif // DXGKDDI_INTERFACE_VERSION_WDDM1_3_PATH_INDEPENDENT_ROTATION
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM1_3)
typedef struct _D3DKMT_DLIST_DRIVER_NAME
{
WCHAR DListFileName[MAX_PATH]; // Out: DList driver file name
} D3DKMT_DLIST_DRIVER_NAME;
typedef struct _D3DKMT_CPDRIVERNAME
{
WCHAR ContentProtectionFileName[MAX_PATH];
} D3DKMT_CPDRIVERNAME;
typedef struct _D3DKMT_MIRACASTCOMPANIONDRIVERNAME
{
WCHAR MiracastCompanionDriverName[MAX_PATH];
} D3DKMT_MIRACASTCOMPANIONDRIVERNAME;
#endif // DXGKDDI_INTERFACE_VERSION_WDDM1_3
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_0)
typedef struct _D3DKMT_XBOX
{
BOOL IsXBOX;
} D3DKMT_XBOX;
typedef struct _D3DKMT_INDEPENDENTFLIP_SUPPORT
{
BOOL Supported;
} D3DKMT_INDEPENDENTFLIP_SUPPORT;
typedef struct _D3DKMT_MULTIPLANEOVERLAY_DECODE_SUPPORT
{
BOOL Supported;
} D3DKMT_MULTIPLANEOVERLAY_DECODE_SUPPORT;
typedef struct _D3DKMT_ISBADDRIVERFORHWPROTECTIONDISABLED
{
BOOL Disabled;
} D3DKMT_ISBADDRIVERFORHWPROTECTIONDISABLED;
typedef struct _D3DKMT_MULTIPLANEOVERLAY_SECONDARY_SUPPORT
{
BOOL Supported;
} D3DKMT_MULTIPLANEOVERLAY_SECONDARY_SUPPORT;
typedef struct _D3DKMT_INDEPENDENTFLIP_SECONDARY_SUPPORT
{
BOOL Supported;
} D3DKMT_INDEPENDENTFLIP_SECONDARY_SUPPORT;
typedef struct _D3DKMT_PANELFITTER_SUPPORT
{
BOOL Supported;
} D3DKMT_PANELFITTER_SUPPORT;
typedef struct _D3DKMT_PHYSICAL_ADAPTER_COUNT
{
UINT Count;
} D3DKMT_PHYSICAL_ADAPTER_COUNT;
typedef struct _D3DKMT_DEVICE_IDS
{
UINT VendorID;
UINT DeviceID;
UINT SubVendorID;
UINT SubSystemID;
UINT RevisionID;
UINT BusType;
} D3DKMT_DEVICE_IDS;
typedef struct _D3DKMT_QUERY_DEVICE_IDS
{
UINT PhysicalAdapterIndex; // in:
D3DKMT_DEVICE_IDS DeviceIds; // out:
} D3DKMT_QUERY_DEVICE_IDS;
typedef enum _D3DKMT_PNP_KEY_TYPE
{
D3DKMT_PNP_KEY_HARDWARE = 1,
D3DKMT_PNP_KEY_SOFTWARE = 2
} D3DKMT_PNP_KEY_TYPE;
typedef struct _D3DKMT_QUERY_PHYSICAL_ADAPTER_PNP_KEY
{
UINT PhysicalAdapterIndex;
D3DKMT_PNP_KEY_TYPE PnPKeyType;
D3DKMT_PTR(_Field_size_opt_(*pCchDest) WCHAR*, pDest);
D3DKMT_PTR(UINT*, pCchDest);
} D3DKMT_QUERY_PHYSICAL_ADAPTER_PNP_KEY;
typedef enum _D3DKMT_MIRACAST_DRIVER_TYPE
{
D3DKMT_MIRACAST_DRIVER_NOT_SUPPORTED = 0,
D3DKMT_MIRACAST_DRIVER_IHV = 1,
D3DKMT_MIRACAST_DRIVER_MS = 2,
} D3DKMT_MIRACAST_DRIVER_TYPE;
typedef struct _D3DKMT_QUERY_MIRACAST_DRIVER_TYPE
{
D3DKMT_MIRACAST_DRIVER_TYPE MiracastDriverType;
} D3DKMT_QUERY_MIRACAST_DRIVER_TYPE;
typedef struct _D3DKMT_GPUMMU_CAPS
{
union
{
struct
{
UINT ReadOnlyMemorySupported : 1;
UINT NoExecuteMemorySupported : 1;
UINT CacheCoherentMemorySupported : 1;
UINT Reserved : 29;
};
UINT Value;
} Flags;
UINT VirtualAddressBitCount;
} D3DKMT_GPUMMU_CAPS;
typedef struct _D3DKMT_QUERY_GPUMMU_CAPS
{
UINT PhysicalAdapterIndex; // in:
D3DKMT_GPUMMU_CAPS Caps; // out:
} D3DKMT_QUERY_GPUMMU_CAPS;
#endif // DXGKDDI_INTERFACE_VERSION_WDDM2_0
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_2)
typedef struct _D3DKMT_MPO3DDI_SUPPORT
{
BOOL Supported;
} D3DKMT_MPO3DDI_SUPPORT;
typedef struct _D3DKMT_HWDRM_SUPPORT
{
BOOLEAN Supported;
} D3DKMT_HWDRM_SUPPORT;
typedef struct _D3DKMT_MPOKERNELCAPS_SUPPORT
{
BOOL Supported;
} D3DKMT_MPOKERNELCAPS_SUPPORT;
typedef struct _D3DKMT_GET_DEVICE_VIDPN_OWNERSHIP_INFO
{
D3DKMT_HANDLE hDevice; // in : Indentifies the device
BOOLEAN bFailedDwmAcquireVidPn; // out : True if Dwm Acquire VidPn failed due to another Dwm device having ownership
} D3DKMT_GET_DEVICE_VIDPN_OWNERSHIP_INFO;
#endif // DXGKDDI_INTERFACE_VERSION_WDDM2_2
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_4)
typedef struct _D3DKMT_BLOCKLIST_INFO
{
UINT Size;
WCHAR BlockList[1];
} D3DKMT_BLOCKLIST_INFO;
typedef struct _D3DKMT_QUERY_ADAPTER_UNIQUE_GUID
{
WCHAR AdapterUniqueGUID[40];
} D3DKMT_QUERY_ADAPTER_UNIQUE_GUID;
typedef struct _D3DKMT_NODE_PERFDATA
{
UINT32 NodeOrdinal; // in: Node ordinal of the requested engine.
UINT32 PhysicalAdapterIndex; // in: The physical adapter index, in an LDA chain
D3DKMT_ALIGN64 ULONGLONG Frequency; // out: Clock frequency of the engine in hertz
D3DKMT_ALIGN64 ULONGLONG MaxFrequency; // out: Max engine clock frequency
D3DKMT_ALIGN64 ULONGLONG MaxFrequencyOC;// out: Max engine over clock frequency
ULONG Voltage; // out: Voltage of the engine in milli volts mV
ULONG VoltageMax; // out: Max voltage levels in milli volts.
ULONG VoltageMaxOC; // out: Max voltage level while overclocked in milli volts.
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_5)
D3DKMT_ALIGN64 ULONGLONG MaxTransitionLatency; // out: Max transition latency to change the frequency in 100 nanoseconds
#else
D3DKMT_ALIGN64 ULONGLONG Reserved;
#endif
} D3DKMT_NODE_PERFDATA;
typedef struct _D3DKMT_ADAPTER_PERFDATA
{
UINT32 PhysicalAdapterIndex; // in: The physical adapter index, in an LDA chain
D3DKMT_ALIGN64 ULONGLONG MemoryFrequency; // out: Clock frequency of the memory in hertz
D3DKMT_ALIGN64 ULONGLONG MaxMemoryFrequency; // out: Max memory clock frequency
D3DKMT_ALIGN64 ULONGLONG MaxMemoryFrequencyOC; // out: Clock frequency of the memory while overclocked in hertz.
D3DKMT_ALIGN64 ULONGLONG MemoryBandwidth; // out: Amount of memory transferred in bytes
D3DKMT_ALIGN64 ULONGLONG PCIEBandwidth; // out: Amount of memory transferred over PCI-E in bytes
ULONG FanRPM; // out: Fan rpm
ULONG Power; // out: Power draw of the adapter in tenths of a percentage
ULONG Temperature; // out: Temperature in deci-Celsius 1 = 0.1C
UCHAR PowerStateOverride; // out: Overrides dxgkrnls power view of linked adapters.
} D3DKMT_ADAPTER_PERFDATA;
typedef struct _D3DKMT_ADAPTER_PERFDATACAPS
{
UINT32 PhysicalAdapterIndex; // in: The physical adapter index, in an LDA chain
D3DKMT_ALIGN64 ULONGLONG MaxMemoryBandwidth; // out: Max memory bandwidth in bytes for 1 second
D3DKMT_ALIGN64 ULONGLONG MaxPCIEBandwidth; // out: Max pcie bandwidth in bytes for 1 second
ULONG MaxFanRPM; // out: Max fan rpm
ULONG TemperatureMax; // out: Max temperature before damage levels
ULONG TemperatureWarning; // out: The temperature level where throttling begins.
} D3DKMT_ADAPTER_PERFDATACAPS;
#define DXGK_MAX_GPUVERSION_NAME_LENGTH 32
typedef struct _D3DKMT_GPUVERSION
{
UINT32 PhysicalAdapterIndex; // in: The physical adapter index, in an LDA chain
WCHAR BiosVersion[DXGK_MAX_GPUVERSION_NAME_LENGTH]; //out: The gpu bios version
WCHAR GpuArchitecture[DXGK_MAX_GPUVERSION_NAME_LENGTH]; //out: The gpu architectures name.
} D3DKMT_GPUVERSION;
#endif // DXGKDDI_INTERFACE_VERSION_WDDM2_4
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_6)
typedef struct _D3DKMT_DRIVER_DESCRIPTION
{
WCHAR DriverDescription[4096]; //out: The driver description
} D3DKMT_DRIVER_DESCRIPTION;
typedef struct _D3DKMT_QUERY_SCANOUT_CAPS
{
D3DDDI_VIDEO_PRESENT_SOURCE_ID VidPnSourceId;
UINT Caps;
} D3DKMT_QUERY_SCANOUT_CAPS;
typedef enum _KMT_DISPLAY_UMD_VERSION
{
KMT_DISPLAY_UMDVERSION_1 = 0,
NUM_KMT_DISPLAY_UMDVERSIONS
} KMT_DISPLAY_UMD_VERSION;
typedef struct _D3DKMT_DISPLAY_UMD_FILENAMEINFO
{
KMT_DISPLAY_UMD_VERSION Version; // In: UMD version
WCHAR UmdFileName[MAX_PATH]; // Out: UMD file name
} D3DKMT_DISPLAY_UMD_FILENAMEINFO;
typedef struct _D3DKMT_PARAVIRTUALIZATION
{
// This adapter property originates from the VM/ Container, and is currently replicated on adapters.
// It precludes extended device functions (i.e. Escapes) for paravirtualized devices which not known at all,
// and therefore assumed not to be secure enough for demanding server scenarios.
BOOLEAN SecureContainer;
} D3DKMT_PARAVIRTUALIZATION;
#endif // DXGKDDI_INTERFACE_VERSION_WDDM2_6
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_8)
typedef struct _D3DKMT_HYBRID_DLIST_DLL_SUPPORT
{
BOOL Supported;
} D3DKMT_HYBRID_DLIST_DLL_SUPPORT;
#endif // DXGKDDI_INTERFACE_VERSION_WDDM2_8
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_9)
typedef enum _D3DKMT_CROSSADAPTERRESOURCE_SUPPORT_TIER
{
D3DKMT_CROSSADAPTERRESOURCE_SUPPORT_TIER_NONE = 0,
D3DKMT_CROSSADAPTERRESOURCE_SUPPORT_TIER_COPY = 1,
D3DKMT_CROSSADAPTERRESOURCE_SUPPORT_TIER_TEXTURE = 2,
D3DKMT_CROSSADAPTERRESOURCE_SUPPORT_TIER_SCANOUT = 3,
} D3DKMT_CROSSADAPTERRESOURCE_SUPPORT_TIER;
typedef struct _D3DKMT_CROSSADAPTERRESOURCE_SUPPORT
{
D3DKMT_CROSSADAPTERRESOURCE_SUPPORT_TIER SupportTier;
} D3DKMT_CROSSADAPTERRESOURCE_SUPPORT;
#endif // DXGKDDI_INTERFACE_VERSION_WDDM2_9
typedef enum _KMTQUERYADAPTERINFOTYPE
{
KMTQAITYPE_UMDRIVERPRIVATE = 0,
KMTQAITYPE_UMDRIVERNAME = 1,
KMTQAITYPE_UMOPENGLINFO = 2,
KMTQAITYPE_GETSEGMENTSIZE = 3,
KMTQAITYPE_ADAPTERGUID = 4,
KMTQAITYPE_FLIPQUEUEINFO = 5,
KMTQAITYPE_ADAPTERADDRESS = 6,
KMTQAITYPE_SETWORKINGSETINFO = 7,
KMTQAITYPE_ADAPTERREGISTRYINFO = 8,
KMTQAITYPE_CURRENTDISPLAYMODE = 9,
KMTQAITYPE_MODELIST = 10,
KMTQAITYPE_CHECKDRIVERUPDATESTATUS = 11,
KMTQAITYPE_VIRTUALADDRESSINFO = 12, // _ADVSCH_
KMTQAITYPE_DRIVERVERSION = 13,
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WIN8)
KMTQAITYPE_ADAPTERTYPE = 15,
KMTQAITYPE_OUTPUTDUPLCONTEXTSCOUNT = 16,
KMTQAITYPE_WDDM_1_2_CAPS = 17,
KMTQAITYPE_UMD_DRIVER_VERSION = 18,
KMTQAITYPE_DIRECTFLIP_SUPPORT = 19,
#endif
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM1_3)
KMTQAITYPE_MULTIPLANEOVERLAY_SUPPORT = 20,
KMTQAITYPE_DLIST_DRIVER_NAME = 21,
KMTQAITYPE_WDDM_1_3_CAPS = 22,
#endif // DXGKDDI_INTERFACE_VERSION_WDDM1_3
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM1_3_PATH_INDEPENDENT_ROTATION)
KMTQAITYPE_MULTIPLANEOVERLAY_HUD_SUPPORT = 23,
#endif // DXGKDDI_INTERFACE_VERSION_WDDM1_3_PATH_INDEPENDENT_ROTATION
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_0)
KMTQAITYPE_WDDM_2_0_CAPS = 24,
KMTQAITYPE_NODEMETADATA = 25,
KMTQAITYPE_CPDRIVERNAME = 26,
KMTQAITYPE_XBOX = 27,
KMTQAITYPE_INDEPENDENTFLIP_SUPPORT = 28,
KMTQAITYPE_MIRACASTCOMPANIONDRIVERNAME = 29,
KMTQAITYPE_PHYSICALADAPTERCOUNT = 30,
KMTQAITYPE_PHYSICALADAPTERDEVICEIDS = 31,
KMTQAITYPE_DRIVERCAPS_EXT = 32,
KMTQAITYPE_QUERY_MIRACAST_DRIVER_TYPE = 33,
KMTQAITYPE_QUERY_GPUMMU_CAPS = 34,
KMTQAITYPE_QUERY_MULTIPLANEOVERLAY_DECODE_SUPPORT = 35,
KMTQAITYPE_QUERY_HW_PROTECTION_TEARDOWN_COUNT = 36,
KMTQAITYPE_QUERY_ISBADDRIVERFORHWPROTECTIONDISABLED = 37,
KMTQAITYPE_MULTIPLANEOVERLAY_SECONDARY_SUPPORT = 38,
KMTQAITYPE_INDEPENDENTFLIP_SECONDARY_SUPPORT = 39,
#endif // DXGKDDI_INTERFACE_VERSION_WDDM2_0
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_1)
KMTQAITYPE_PANELFITTER_SUPPORT = 40,
#endif // DXGKDDI_INTERFACE_VERSION_WDDM2_1
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_2)
KMTQAITYPE_PHYSICALADAPTERPNPKEY = 41,
KMTQAITYPE_GETSEGMENTGROUPSIZE = 42,
KMTQAITYPE_MPO3DDI_SUPPORT = 43,
KMTQAITYPE_HWDRM_SUPPORT = 44,
KMTQAITYPE_MPOKERNELCAPS_SUPPORT = 45,
KMTQAITYPE_MULTIPLANEOVERLAY_STRETCH_SUPPORT = 46,
KMTQAITYPE_GET_DEVICE_VIDPN_OWNERSHIP_INFO = 47,
#endif // DXGKDDI_INTERFACE_VERSION_WDDM2_2
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_4)
KMTQAITYPE_QUERYREGISTRY = 48,
KMTQAITYPE_KMD_DRIVER_VERSION = 49,
KMTQAITYPE_BLOCKLIST_KERNEL = 50,
KMTQAITYPE_BLOCKLIST_RUNTIME = 51,
KMTQAITYPE_ADAPTERGUID_RENDER = 52,
KMTQAITYPE_ADAPTERADDRESS_RENDER = 53,
KMTQAITYPE_ADAPTERREGISTRYINFO_RENDER = 54,
KMTQAITYPE_CHECKDRIVERUPDATESTATUS_RENDER = 55,
KMTQAITYPE_DRIVERVERSION_RENDER = 56,
KMTQAITYPE_ADAPTERTYPE_RENDER = 57,
KMTQAITYPE_WDDM_1_2_CAPS_RENDER = 58,
KMTQAITYPE_WDDM_1_3_CAPS_RENDER = 59,
KMTQAITYPE_QUERY_ADAPTER_UNIQUE_GUID = 60,
KMTQAITYPE_NODEPERFDATA = 61,
KMTQAITYPE_ADAPTERPERFDATA = 62,
KMTQAITYPE_ADAPTERPERFDATA_CAPS = 63,
KMTQUITYPE_GPUVERSION = 64,
#endif // DXGKDDI_INTERFACE_VERSION_WDDM2_4
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_6)
KMTQAITYPE_DRIVER_DESCRIPTION = 65,
KMTQAITYPE_DRIVER_DESCRIPTION_RENDER = 66,
KMTQAITYPE_SCANOUT_CAPS = 67,
KMTQAITYPE_DISPLAY_UMDRIVERNAME = 71, // Added in 19H2
KMTQAITYPE_PARAVIRTUALIZATION_RENDER = 68,
#endif // DXGKDDI_INTERFACE_VERSION_WDDM2_6
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_7)
KMTQAITYPE_SERVICENAME = 69,
KMTQAITYPE_WDDM_2_7_CAPS = 70,
KMTQAITYPE_TRACKEDWORKLOAD_SUPPORT = 72,
#endif // DXGKDDI_INTERFACE_VERSION_WDDM2_7
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_8)
KMTQAITYPE_HYBRID_DLIST_DLL_SUPPORT = 73,
KMTQAITYPE_DISPLAY_CAPS = 74,
#endif // DXGKDDI_INTERFACE_VERSION_WDDM2_8
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_9)
KMTQAITYPE_WDDM_2_9_CAPS = 75,
KMTQAITYPE_CROSSADAPTERRESOURCE_SUPPORT = 76,
#endif // DXGKDDI_INTERFACE_VERSION_WDDM2_9
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM3_0)
KMTQAITYPE_WDDM_3_0_CAPS = 77,
#endif // DXGKDDI_INTERFACE_VERSION_WDDM3_0
// If a new enum will be used by DXGI or D3D11 software driver code, update the test content in the area.
// Search for KMTQAITYPE_PARAVIRTUALIZATION_RENDER in directx\dxg\dxgi\unittests for references.
} KMTQUERYADAPTERINFOTYPE;
typedef struct _D3DKMT_QUERYADAPTERINFO
{
D3DKMT_HANDLE hAdapter;
KMTQUERYADAPTERINFOTYPE Type;
D3DKMT_PTR(VOID*, pPrivateDriverData);
UINT PrivateDriverDataSize;
} D3DKMT_QUERYADAPTERINFO;
typedef struct _D3DKMT_OPENADAPTERFROMHDC
{
D3DKMT_PTR(HDC, hDc); // in: DC that maps to a single display
D3DKMT_HANDLE hAdapter; // out: adapter handle
LUID AdapterLuid; // out: adapter LUID
D3DDDI_VIDEO_PRESENT_SOURCE_ID VidPnSourceId; // out: VidPN source ID for that particular display
} D3DKMT_OPENADAPTERFROMHDC;
typedef struct _D3DKMT_OPENADAPTERFROMGDIDISPLAYNAME
{
WCHAR DeviceName[32]; // in: Name of GDI device from which to open an adapter instance
D3DKMT_HANDLE hAdapter; // out: adapter handle
LUID AdapterLuid; // out: adapter LUID
D3DDDI_VIDEO_PRESENT_SOURCE_ID VidPnSourceId; // out: VidPN source ID for that particular display
} D3DKMT_OPENADAPTERFROMGDIDISPLAYNAME;
typedef struct _D3DKMT_OPENADAPTERFROMDEVICENAME
{
D3DKMT_PTR(PCWSTR, pDeviceName); // in: NULL terminated string containing the device name to open
D3DKMT_HANDLE hAdapter; // out: adapter handle
LUID AdapterLuid; // out: adapter LUID
} D3DKMT_OPENADAPTERFROMDEVICENAME;
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WIN8)
#define MAX_ENUM_ADAPTERS 16
typedef struct _D3DKMT_ADAPTERINFO
{
D3DKMT_HANDLE hAdapter;
LUID AdapterLuid;
ULONG NumOfSources;
BOOL bPrecisePresentRegionsPreferred;
} D3DKMT_ADAPTERINFO;
typedef struct _D3DKMT_ENUMADAPTERS
{
_In_range_(0, MAX_ENUM_ADAPTERS) ULONG NumAdapters;
D3DKMT_ADAPTERINFO Adapters[MAX_ENUM_ADAPTERS];
} D3DKMT_ENUMADAPTERS;
typedef struct _D3DKMT_ENUMADAPTERS2
{
ULONG NumAdapters; // in/out: On input, the count of the pAdapters array buffer. On output, the number of adapters enumerated.
D3DKMT_PTR(D3DKMT_ADAPTERINFO*, pAdapters); // out: Array of enumerated adapters containing NumAdapters elements
} D3DKMT_ENUMADAPTERS2;
typedef struct _D3DKMT_OPENADAPTERFROMLUID
{
LUID AdapterLuid;
D3DKMT_HANDLE hAdapter;
} D3DKMT_OPENADAPTERFROMLUID;
typedef struct _D3DKMT_QUERYREMOTEVIDPNSOURCEFROMGDIDISPLAYNAME
{
WCHAR DeviceName[32]; // in: Name of GDI device from which to open an adapter instance
D3DDDI_VIDEO_PRESENT_SOURCE_ID VidPnSourceId; // out: VidPN source ID for that particular display
} D3DKMT_QUERYREMOTEVIDPNSOURCEFROMGDIDISPLAYNAME;
#endif
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_7)
typedef union _D3DKMT_ENUMADAPTERS_FILTER
{
// Setting none of these flags will still enumerate adapters,
// but there are fewer adapters than EnumAdapters2 enumerates.
// ComputeOnly adapters are left out of the default enumeration, to avoid breaking applications.
// DisplayOnly adapters are also left out of the default enumeration.
struct
{
ULONGLONG IncludeComputeOnly : 1;
ULONGLONG IncludeDisplayOnly : 1;
ULONGLONG Reserved : 62;
};
D3DKMT_ALIGN64 ULONGLONG Value;
} D3DKMT_ENUMADAPTERS_FILTER;
typedef struct _D3DKMT_ENUMADAPTERS3
{
D3DKMT_ENUMADAPTERS_FILTER Filter; // in: Defines the filter
ULONG NumAdapters; // in/out: On input, the count of the pAdapters array buffer. On output, the number of adapters enumerated.
D3DKMT_PTR(D3DKMT_ADAPTERINFO*, pAdapters); // out: Array of enumerated adapters containing NumAdapters elements
} D3DKMT_ENUMADAPTERS3;
#endif
typedef struct _D3DKMT_CLOSEADAPTER
{
D3DKMT_HANDLE hAdapter; // in: adapter handle
} D3DKMT_CLOSEADAPTER;
typedef struct _D3DKMT_GETSHAREDPRIMARYHANDLE
{
D3DKMT_HANDLE hAdapter; // in: adapter handle
D3DDDI_VIDEO_PRESENT_SOURCE_ID VidPnSourceId; // in: adapter's VidPN source ID
D3DKMT_HANDLE hSharedPrimary; // out: global shared primary handle (if one exists currently)
} D3DKMT_GETSHAREDPRIMARYHANDLE;
typedef struct _D3DKMT_SHAREDPRIMARYLOCKNOTIFICATION
{
LUID AdapterLuid;
D3DDDI_VIDEO_PRESENT_SOURCE_ID VidPnSourceId;
RECTL LockRect; // in: If zero rect then we are locking the whole primary else the lock sub-rect
} D3DKMT_SHAREDPRIMARYLOCKNOTIFICATION;
typedef struct _D3DKMT_SHAREDPRIMARYUNLOCKNOTIFICATION
{
LUID AdapterLuid;
D3DDDI_VIDEO_PRESENT_SOURCE_ID VidPnSourceId;
} D3DKMT_SHAREDPRIMARYUNLOCKNOTIFICATION;
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WIN8)
typedef struct _D3DKMT_PINDIRECTFLIPRESOURCES
{
D3DKMT_HANDLE hDevice; // in : Indentifies the device
UINT ResourceCount; // in : Number of resources to pin
D3DKMT_PTR(_Field_size_(ResourceCount) D3DKMT_HANDLE*, pResourceList); // in : Array of resource handles to pin
} D3DKMT_PINDIRECTFLIPRESOURCES;
typedef struct _D3DKMT_UNPINDIRECTFLIPRESOURCES
{
D3DKMT_HANDLE hDevice; // in : Indentifies the device
UINT ResourceCount; // in : Number of resources to unpin
D3DKMT_PTR(_Field_size_(ResourceCount) D3DKMT_HANDLE*, pResourceList); // in : Array of resource handles to unpin
} D3DKMT_UNPINDIRECTFLIPRESOURCES;
#endif
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_7)
typedef union _D3DKMT_PINRESOURCEFLAGS
{
struct
{
UINT DirectFlipResources : 1; // Used by DWM to indicate the resources are DirectFlip resources
// and should be pinned in-place.
UINT Reserved : 31;
};
UINT Value;
} D3DKMT_PINRESOURCEFLAGS;
typedef struct _D3DKMT_PINRESOURCES
{
D3DKMT_HANDLE hDevice; // in : Indentifies the device
UINT ResourceCount; // in : Number of resources to pin
D3DKMT_PTR(_Field_size_(ResourceCount) D3DKMT_HANDLE*, pResourceList); // in : Array of resource handles to pin
D3DKMT_PINRESOURCEFLAGS Flags; // in : Flags
D3DKMT_HANDLE hPagingQueue; // in opt : Handle to a paging queue used to synchronize the operation
D3DKMT_ALIGN64 UINT64 PagingFence; // out : Fence value returned if hPagingQueue is not NULL
} D3DKMT_PINRESOURCES;
typedef struct _D3DKMT_UNPINRESOURCES
{
D3DKMT_HANDLE hDevice; // in : Indentifies the device
UINT ResourceCount; // in : Number of resources to unpin
D3DKMT_PTR(_Field_size_(ResourceCount) D3DKMT_HANDLE*, pResourceList); // in : Array of resource handles to unpin
UINT Reserved;
} D3DKMT_UNPINRESOURCES;
#endif
typedef enum _D3DKMT_ESCAPETYPE
{
D3DKMT_ESCAPE_DRIVERPRIVATE = 0,
D3DKMT_ESCAPE_VIDMM = 1,
D3DKMT_ESCAPE_TDRDBGCTRL = 2,
D3DKMT_ESCAPE_VIDSCH = 3,
D3DKMT_ESCAPE_DEVICE = 4,
D3DKMT_ESCAPE_DMM = 5,
D3DKMT_ESCAPE_DEBUG_SNAPSHOT = 6,
// unused (7 was previously used to set driver update in-progress status, D3DKMT_ESCAPE_SETDRIVERUPDATESTATUS)
D3DKMT_ESCAPE_DRT_TEST = 8,
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WIN8)
D3DKMT_ESCAPE_DIAGNOSTICS = 9,
D3DKMT_ESCAPE_OUTPUTDUPL_SNAPSHOT = 10,
D3DKMT_ESCAPE_OUTPUTDUPL_DIAGNOSTICS = 11,
D3DKMT_ESCAPE_BDD_PNP = 12,
D3DKMT_ESCAPE_BDD_FALLBACK = 13,
D3DKMT_ESCAPE_ACTIVATE_SPECIFIC_DIAG = 14,
D3DKMT_ESCAPE_MODES_PRUNED_OUT = 15,
D3DKMT_ESCAPE_WHQL_INFO = 16,
D3DKMT_ESCAPE_BRIGHTNESS = 17,
D3DKMT_ESCAPE_EDID_CACHE = 18,
// unused (19 was previously D3DKMT_ESCAPE_GENERIC_ADAPTER_DIAG_INFO)
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM1_3)
D3DKMT_ESCAPE_MIRACAST_DISPLAY_REQUEST = 20,
D3DKMT_ESCAPE_HISTORY_BUFFER_STATUS = 21,
// 22 can be reused for future needs as it was never exposed for external purposes
D3DKMT_ESCAPE_MIRACAST_ADAPTER_DIAG_INFO = 23,
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_0)
D3DKMT_ESCAPE_FORCE_BDDFALLBACK_HEADLESS = 24,
D3DKMT_ESCAPE_REQUEST_MACHINE_CRASH = 25,
// unused (26 was previously D3DKMT_ESCAPE_HMD_GET_EDID_BASE_BLOCK)
D3DKMT_ESCAPE_SOFTGPU_ENABLE_DISABLE_HMD = 27,
D3DKMT_ESCAPE_PROCESS_VERIFIER_OPTION = 28,
D3DKMT_ESCAPE_ADAPTER_VERIFIER_OPTION = 29,
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_1)
D3DKMT_ESCAPE_IDD_REQUEST = 30,
D3DKMT_ESCAPE_DOD_SET_DIRTYRECT_MODE = 31,
D3DKMT_ESCAPE_LOG_CODEPOINT_PACKET = 32,
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_2)
D3DKMT_ESCAPE_LOG_USERMODE_DAIG_PACKET = 33,
D3DKMT_ESCAPE_GET_EXTERNAL_DIAGNOSTICS = 34,
// unused (35 previously was D3DKMT_ESCAPE_GET_PREFERRED_MODE)
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_3)
D3DKMT_ESCAPE_GET_DISPLAY_CONFIGURATIONS = 36,
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_4)
D3DKMT_ESCAPE_QUERY_IOMMU_STATUS = 37,
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_6)
D3DKMT_ESCAPE_CCD_DATABASE = 38,
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM3_0)
D3DKMT_ESCAPE_QUERY_DMA_REMAPPING_STATUS = 39,
#endif // DXGKDDI_INTERFACE_VERSION_WDDM3_0
#endif // DXGKDDI_INTERFACE_VERSION_WDDM2_6
#endif // DXGKDDI_INTERFACE_VERSION_WDDM2_4
#endif // DXGKDDI_INTERFACE_VERSION_WDDM2_3
#endif // DXGKDDI_INTERFACE_VERSION_WDDM2_2
#endif // DXGKDDI_INTERFACE_VERSION_WDDM2_1
#endif // DXGKDDI_INTERFACE_VERSION_WDDM2_0
#endif // DXGKDDI_INTERFACE_VERSION_WDDM1_3
D3DKMT_ESCAPE_WIN32K_START = 1024,
D3DKMT_ESCAPE_WIN32K_HIP_DEVICE_INFO = 1024,
D3DKMT_ESCAPE_WIN32K_QUERY_CD_ROTATION_BLOCK = 1025,
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM1_3)
D3DKMT_ESCAPE_WIN32K_DPI_INFO = 1026, // Use hContext for the desired hdev
D3DKMT_ESCAPE_WIN32K_PRESENTER_VIEW_INFO = 1027,
D3DKMT_ESCAPE_WIN32K_SYSTEM_DPI = 1028,
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_0)
D3DKMT_ESCAPE_WIN32K_BDD_FALLBACK = 1029,
D3DKMT_ESCAPE_WIN32K_DDA_TEST_CTL = 1030,
D3DKMT_ESCAPE_WIN32K_USER_DETECTED_BLACK_SCREEN = 1031,
// unused (1032 was previously D3DKMT_ESCAPE_WIN32K_HMD_ENUM)
// unused (1033 was previously D3DKMT_ESCAPE_WIN32K_HMD_CONTROL)
// unused (1034 was previously D3DKMT_ESCAPE_WIN32K_LPMDISPLAY_CONTROL)
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_5)
D3DKMT_ESCAPE_WIN32K_DISPBROKER_TEST = 1035,
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_6)
D3DKMT_ESCAPE_WIN32K_COLOR_PROFILE_INFO = 1036,
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_7)
D3DKMT_ESCAPE_WIN32K_SET_DIMMED_STATE = 1037,
D3DKMT_ESCAPE_WIN32K_SPECIALIZED_DISPLAY_TEST = 1038,
#endif // DXGKDDI_INTERFACE_VERSION_WDDM2_7
#endif // DXGKDDI_INTERFACE_VERSION_WDDM2_6
#endif // DXGKDDI_INTERFACE_VERSION_WDDM2_5
#endif // DXGKDDI_INTERFACE_VERSION_WDDM2_0
#endif // DXGKDDI_INTERFACE_VERSION_WDDM1_3
#endif // DXGKDDI_INTERFACE_VERSION_WIN8
} D3DKMT_ESCAPETYPE;
typedef struct _D3DKMT_DOD_SET_DIRTYRECT_MODE
{
BOOL bForceFullScreenDirty; // in: indicates if this adapter should always give full screen dirty for every Dod present
}D3DKMT_DOD_SET_DIRTYRECT_MODE;
typedef enum _D3DKMT_TDRDBGCTRLTYPE
{
D3DKMT_TDRDBGCTRLTYPE_FORCETDR = 0, //Simulate a TDR
D3DKMT_TDRDBGCTRLTYPE_DISABLEBREAK = 1, //Disable DebugBreak on timeout
D3DKMT_TDRDBGCTRLTYPE_ENABLEBREAK = 2, //Enable DebugBreak on timeout
D3DKMT_TDRDBGCTRLTYPE_UNCONDITIONAL = 3, //Disables all safety conditions (e.g. check for consecutive recoveries)
D3DKMT_TDRDBGCTRLTYPE_VSYNCTDR = 4, //Simulate a Vsync TDR
D3DKMT_TDRDBGCTRLTYPE_GPUTDR = 5, //Simulate a GPU TDR
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WIN8)
D3DKMT_TDRDBGCTRLTYPE_FORCEDODTDR = 6, //Simulate a Display Only Present TDR
D3DKMT_TDRDBGCTRLTYPE_FORCEDODVSYNCTDR = 7, //Simulate a Display Only Vsync TDR
D3DKMT_TDRDBGCTRLTYPE_ENGINETDR = 8, //Simulate an engine TDR
#endif
} D3DKMT_TDRDBGCTRLTYPE;
typedef enum _D3DKMT_VIDMMESCAPETYPE
{
D3DKMT_VIDMMESCAPETYPE_SETFAULT = 0,
D3DKMT_VIDMMESCAPETYPE_RUN_COHERENCY_TEST = 1,
D3DKMT_VIDMMESCAPETYPE_RUN_UNMAP_TO_DUMMY_PAGE_TEST = 2,
D3DKMT_VIDMMESCAPETYPE_APERTURE_CORRUPTION_CHECK = 3,
D3DKMT_VIDMMESCAPETYPE_SUSPEND_CPU_ACCESS_TEST = 4,
D3DKMT_VIDMMESCAPETYPE_EVICT = 5,
D3DKMT_VIDMMESCAPETYPE_EVICT_BY_NT_HANDLE = 6,
D3DKMT_VIDMMESCAPETYPE_GET_VAD_INFO = 7,
D3DKMT_VIDMMESCAPETYPE_SET_BUDGET = 8,
D3DKMT_VIDMMESCAPETYPE_SUSPEND_PROCESS = 9,
D3DKMT_VIDMMESCAPETYPE_RESUME_PROCESS = 10,
D3DKMT_VIDMMESCAPETYPE_GET_BUDGET = 11,
D3DKMT_VIDMMESCAPETYPE_SET_TRIM_INTERVALS = 12,
D3DKMT_VIDMMESCAPETYPE_EVICT_BY_CRITERIA = 13,
D3DKMT_VIDMMESCAPETYPE_WAKE = 14,
D3DKMT_VIDMMESCAPETYPE_DEFRAG = 15,
D3DKMT_VIDMMESCAPETYPE_DELAYEXECUTION = 16,
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_7)
D3DKMT_VIDMMESCAPETYPE_VALIDATE_INTEGRITY = 17,
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_9)
D3DKMT_VIDMMESCAPETYPE_SET_EVICTION_CONFIG = 18,
#endif // DXGKDDI_INTERFACE_VERSION_WDDM2_9
#endif // DXGKDDI_INTERFACE_VERSION_WDDM2_7
} D3DKMT_VIDMMESCAPETYPE;
typedef enum _D3DKMT_VIDSCHESCAPETYPE
{
D3DKMT_VIDSCHESCAPETYPE_PREEMPTIONCONTROL = 0, //Enable/Disable preemption
D3DKMT_VIDSCHESCAPETYPE_SUSPENDSCHEDULER = 1, //Suspend/Resume scheduler (obsolate)
D3DKMT_VIDSCHESCAPETYPE_TDRCONTROL = 2, //Tdr control
D3DKMT_VIDSCHESCAPETYPE_SUSPENDRESUME = 3, //Suspend/Resume scheduler
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WIN8)
D3DKMT_VIDSCHESCAPETYPE_ENABLECONTEXTDELAY = 4, //Enable/Disable context delay
#endif
D3DKMT_VIDSCHESCAPETYPE_CONFIGURE_TDR_LIMIT = 5, // Configure TdrLimitCount and TdrLimitTime
D3DKMT_VIDSCHESCAPETYPE_VGPU_RESET = 6, // Trigger VGPU reset
D3DKMT_VIDSCHESCAPETYPE_PFN_CONTROL = 7, // Periodic frame notification control
D3DKMT_VIDSCHESCAPETYPE_VIRTUAL_REFRESH_RATE = 8,
} D3DKMT_VIDSCHESCAPETYPE;
typedef enum _D3DKMT_DMMESCAPETYPE
{
D3DKMT_DMMESCAPETYPE_UNINITIALIZED = 0,
D3DKMT_DMMESCAPETYPE_GET_SUMMARY_INFO = 1,
D3DKMT_DMMESCAPETYPE_GET_VIDEO_PRESENT_SOURCES_INFO = 2,
D3DKMT_DMMESCAPETYPE_GET_VIDEO_PRESENT_TARGETS_INFO = 3,
D3DKMT_DMMESCAPETYPE_GET_ACTIVEVIDPN_INFO = 4,
D3DKMT_DMMESCAPETYPE_GET_MONITORS_INFO = 5,
D3DKMT_DMMESCAPETYPE_RECENTLY_COMMITTED_VIDPNS_INFO = 6,
D3DKMT_DMMESCAPETYPE_RECENT_MODECHANGE_REQUESTS_INFO = 7,
D3DKMT_DMMESCAPETYPE_RECENTLY_RECOMMENDED_VIDPNS_INFO = 8,
D3DKMT_DMMESCAPETYPE_RECENT_MONITOR_PRESENCE_EVENTS_INFO = 9,
D3DKMT_DMMESCAPETYPE_ACTIVEVIDPN_SOURCEMODESET_INFO = 10,
D3DKMT_DMMESCAPETYPE_ACTIVEVIDPN_COFUNCPATHMODALITY_INFO = 11,
D3DKMT_DMMESCAPETYPE_GET_LASTCLIENTCOMMITTEDVIDPN_INFO = 12,
D3DKMT_DMMESCAPETYPE_GET_VERSION_INFO = 13,
D3DKMT_DMMESCAPETYPE_VIDPN_MGR_DIAGNOSTICS = 14
} D3DKMT_DMMESCAPETYPE;
typedef struct _D3DKMT_HISTORY_BUFFER_STATUS
{
BOOLEAN Enabled;
UINT Reserved;
} D3DKMT_HISTORY_BUFFER_STATUS;
typedef enum _D3DKMT_VAD_ESCAPE_COMMAND
{
D3DKMT_VAD_ESCAPE_GETNUMVADS,
D3DKMT_VAD_ESCAPE_GETVAD,
D3DKMT_VAD_ESCAPE_GETVADRANGE,
D3DKMT_VAD_ESCAPE_GET_PTE,
D3DKMT_VAD_ESCAPE_GET_GPUMMU_CAPS,
D3DKMT_VAD_ESCAPE_GET_SEGMENT_CAPS,
} D3DKMT_VAD_ESCAPE_COMMAND;
typedef struct _D3DKMT_VAD_DESC
{
UINT VadIndex; // in: 0xFFFFFFFF to use the VAD address
D3DKMT_ALIGN64 UINT64 VadAddress; // in
UINT NumMappedRanges; // out
UINT VadType; // out: 0 - reserved, 1 - Mapped
D3DKMT_ALIGN64 UINT64 StartAddress; // out
D3DKMT_ALIGN64 UINT64 EndAddress; // out
} D3DKMT_VAD_DESC;
typedef struct _D3DKMT_VA_RANGE_DESC
{
D3DKMT_ALIGN64 UINT64 VadAddress; // in
UINT VaRangeIndex; // in
UINT PhysicalAdapterIndex; // in
D3DKMT_ALIGN64 UINT64 StartAddress; // out
D3DKMT_ALIGN64 UINT64 EndAddress; // out
D3DKMT_ALIGN64 UINT64 DriverProtection; // out
UINT OwnerType; // out: VIDMM_VAD_OWNER_TYPE
D3DKMT_ALIGN64 UINT64 pOwner; // out
D3DKMT_ALIGN64 UINT64 OwnerOffset; // out
UINT Protection; // out: D3DDDIGPUVIRTUALADDRESS_PROTECTION_TYPE
} D3DKMT_VA_RANGE_DESC;
typedef struct _D3DKMT_EVICTION_CRITERIA
{
D3DKMT_ALIGN64 UINT64 MinimumSize;
D3DKMT_ALIGN64 UINT64 MaximumSize;
struct
{
union
{
struct
{
UINT Primary : 1; // 0x00000001
UINT Reserved : 31; // 0xFFFFFFFE
} Flags;
UINT Value;
};
};
} D3DKMT_EVICTION_CRITERIA;
typedef enum _D3DKMT_DEFRAG_ESCAPE_OPERATION
{
D3DKMT_DEFRAG_ESCAPE_GET_FRAGMENTATION_STATS = 0,
D3DKMT_DEFRAG_ESCAPE_DEFRAG_UPWARD = 1,
D3DKMT_DEFRAG_ESCAPE_DEFRAG_DOWNWARD = 2,
D3DKMT_DEFRAG_ESCAPE_DEFRAG_PASS = 3,
D3DKMT_DEFRAG_ESCAPE_VERIFY_TRANSFER = 4,
} D3DKMT_DEFRAG_ESCAPE_OPERATION;
typedef struct _D3DKMT_PAGE_TABLE_LEVEL_DESC
{
UINT IndexBitCount;
D3DKMT_ALIGN64 UINT64 IndexMask;
D3DKMT_ALIGN64 UINT64 IndexShift;
D3DKMT_ALIGN64 UINT64 LowerLevelsMask;
D3DKMT_ALIGN64 UINT64 EntryCoverageInPages;
} D3DKMT_PAGE_TABLE_LEVEL_DESC;
typedef struct _DXGK_ESCAPE_GPUMMUCAPS
{
BOOLEAN ReadOnlyMemorySupported;
BOOLEAN NoExecuteMemorySupported;
BOOLEAN ZeroInPteSupported;
BOOLEAN CacheCoherentMemorySupported;
BOOLEAN LargePageSupported;
BOOLEAN DualPteSupported;
BOOLEAN AllowNonAlignedLargePageAddress;
UINT VirtualAddressBitCount;
UINT PageTableLevelCount;
D3DKMT_PAGE_TABLE_LEVEL_DESC PageTableLevelDesk[DXGK_MAX_PAGE_TABLE_LEVEL_COUNT];
} DXGK_ESCAPE_GPUMMUCAPS;
typedef struct _D3DKMT_GET_GPUMMU_CAPS
{
UINT PhysicalAdapterIndex; // In
DXGK_ESCAPE_GPUMMUCAPS GpuMmuCaps; // Out
} D3DKMT_GET_GPUMMU_CAPS;
#define D3DKMT_GET_PTE_MAX 64
typedef struct _D3DKMT_GET_PTE
{
UINT PhysicalAdapterIndex; // In
UINT PageTableLevel; // In
UINT PageTableIndex[DXGK_MAX_PAGE_TABLE_LEVEL_COUNT]; // In
BOOLEAN b64KBPte; // In - Valid only when dual PTEs are supported. Out - PT is 64KB.
UINT NumPtes; // In - Number of PTEs to fill. Out - number of filled PTEs
DXGK_PTE Pte[D3DKMT_GET_PTE_MAX]; // Out
UINT NumValidEntries; // Out
} D3DKMT_GET_PTE;
#define D3DKMT_MAX_SEGMENT_COUNT 32
typedef enum _D3DKMT_MEMORY_SEGMENT_GROUP
{
D3DKMT_MEMORY_SEGMENT_GROUP_LOCAL = 0,
D3DKMT_MEMORY_SEGMENT_GROUP_NON_LOCAL = 1
} D3DKMT_MEMORY_SEGMENT_GROUP;
typedef struct _D3DKMT_SEGMENT_CAPS
{
D3DKMT_ALIGN64 UINT64 Size;
UINT PageSize;
ULONG SegmentId;
BOOLEAN bAperture;
BOOLEAN bReservedSysMem;
D3DKMT_MEMORY_SEGMENT_GROUP BudgetGroup;
} D3DKMT_SEGMENT_CAPS;
typedef struct _D3DKMT_GET_SEGMENT_CAPS
{
UINT PhysicalAdapterIndex; // In
UINT NumSegments; // Out
D3DKMT_SEGMENT_CAPS SegmentCaps[D3DKMT_MAX_SEGMENT_COUNT]; // Out
} D3DKMT_GET_SEGMENT_CAPS;
typedef enum _D3DKMT_ESCAPE_PFN_CONTROL_COMMAND
{
D3DKMT_ESCAPE_PFN_CONTROL_DEFAULT,
D3DKMT_ESCAPE_PFN_CONTROL_FORCE_CPU,
D3DKMT_ESCAPE_PFN_CONTROL_FORCE_GPU
} D3DKMT_ESCAPE_PFN_CONTROL_COMMAND;
// params for D3DKMT_VIDSCHESCAPETYPE_VIRTUAL_REFRESH_RATE
typedef enum _D3DKMT_ESCAPE_VIRTUAL_REFRESH_RATE_TYPE
{
D3DKMT_ESCAPE_VIRTUAL_REFRESH_RATE_TYPE_SET_BASE_DESKTOP_DURATION = 0,
D3DKMT_ESCAPE_VIRTUAL_REFRESH_RATE_TYPE_SET_VSYNC_MULTIPLIER = 1,
D3DKMT_ESCAPE_VIRTUAL_REFRESH_RATE_TYPE_SET_PROCESS_BOOST_ELIGIBLE = 2,
} D3DKMT_ESCAPE_VIRTUAL_REFRESH_RATE_TYPE;
typedef struct _D3DKMT_ESCAPE_VIRTUAL_REFRESH_RATE
{
D3DKMT_ESCAPE_VIRTUAL_REFRESH_RATE_TYPE Type;
UINT VidPnSourceId;
BOOLEAN ProcessBoostEligible;
UINT VSyncMultiplier;
UINT BaseDesktopDuration;
UCHAR Reserved[16];
} D3DKMT_ESCAPE_VIRTUAL_REFRESH_RATE;
typedef struct _D3DKMT_VIDMM_ESCAPE
{
D3DKMT_VIDMMESCAPETYPE Type;
union
{
struct
{
union
{
struct
{
ULONG ProbeAndLock : 1;
ULONG SplitPoint : 1;
ULONG NoDemotion : 1;
ULONG SwizzlingAperture : 1;
ULONG PagingPathLockSubRange : 1;
ULONG PagingPathLockMinRange : 1;
ULONG ComplexLock : 1;
ULONG FailVARotation : 1;
ULONG NoWriteCombined : 1;
ULONG NoPrePatching : 1;
ULONG AlwaysRepatch : 1;
ULONG ExpectPreparationFailure : 1;
ULONG FailUserModeVAMapping : 1;
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WIN8)
ULONG NeverDiscardOfferedAllocation : 1;
ULONG AlwaysDiscardOfferedAllocation : 1;
ULONG Reserved : 17;
#else
ULONG Reserved : 19;
#endif
};
ULONG Value;
};
} SetFault;
struct
{
D3DKMT_HANDLE ResourceHandle;
D3DKMT_HANDLE AllocationHandle;
D3DKMT_PTR(HANDLE, hProcess); // 0 to evict memory for the current process, otherwise it is a process handle from OpenProcess(PROCESS_ALL_ACCESS, FALSE, ProcessId).
} Evict;
struct
{
D3DKMT_ALIGN64 UINT64 NtHandle; // Used by D3DKMT_VIDMMESCAPETYPE_EVICT_BY_NT_HANDLE
} EvictByNtHandle;
struct
{
union
{
struct
{
UINT NumVads;
} GetNumVads;
D3DKMT_VAD_DESC GetVad;
D3DKMT_VA_RANGE_DESC GetVadRange;
D3DKMT_GET_GPUMMU_CAPS GetGpuMmuCaps;
D3DKMT_GET_PTE GetPte;
D3DKMT_GET_SEGMENT_CAPS GetSegmentCaps;
};
D3DKMT_VAD_ESCAPE_COMMAND Command; // in
NTSTATUS Status; // out
} GetVads;
struct
{
D3DKMT_ALIGN64 ULONGLONG LocalMemoryBudget;
D3DKMT_ALIGN64 ULONGLONG SystemMemoryBudget;
} SetBudget;
struct
{
D3DKMT_PTR(HANDLE, hProcess);
BOOL bAllowWakeOnSubmission;
} SuspendProcess;
struct
{
D3DKMT_PTR(HANDLE, hProcess);
} ResumeProcess;
struct
{
D3DKMT_ALIGN64 UINT64 NumBytesToTrim;
} GetBudget;
struct
{
ULONG MinTrimInterval; // In 100ns units
ULONG MaxTrimInterval; // In 100ns units
ULONG IdleTrimInterval; // In 100ns units
} SetTrimIntervals;
D3DKMT_EVICTION_CRITERIA EvictByCriteria;
struct
{
BOOL bFlush;
} Wake;
struct
{
D3DKMT_DEFRAG_ESCAPE_OPERATION Operation;
UINT SegmentId;
D3DKMT_ALIGN64 ULONGLONG TotalCommitted;
D3DKMT_ALIGN64 ULONGLONG TotalFree;
D3DKMT_ALIGN64 ULONGLONG LargestGapBefore;
D3DKMT_ALIGN64 ULONGLONG LargestGapAfter;
} Defrag;
struct
{
D3DKMT_HANDLE hPagingQueue;
UINT PhysicalAdapterIndex;
ULONG Milliseconds;
D3DKMT_ALIGN64 ULONGLONG PagingFenceValue;
} DelayExecution;
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_7)
struct
{
UINT SegmentId;
} VerifyIntegrity;
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_9)
struct
{
D3DKMT_ALIGN64 LONGLONG TimerValue;
} DelayedEvictionConfig;
#endif // DXGKDDI_INTERFACE_VERSION_WDDM2_9
#endif // DXGKDDI_INTERFACE_VERSION_WDDM2_7
};
} D3DKMT_VIDMM_ESCAPE;
typedef struct _D3DKMT_VIDSCH_ESCAPE
{
D3DKMT_VIDSCHESCAPETYPE Type;
union
{
BOOL PreemptionControl; // enable/disable preemption
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WIN8)
BOOL EnableContextDelay; // enable/disable context delay
struct
{
ULONG TdrControl; // control tdr
union
{
ULONG NodeOrdinal; // valid if TdrControl is set to D3DKMT_TDRDBGCTRLTYPE_ENGINETDR
};
} TdrControl2;
#endif
BOOL SuspendScheduler; // suspend/resume scheduler (obsolate)
ULONG TdrControl; // control tdr
ULONG SuspendTime; // time period to suspend.
struct
{
UINT Count;
UINT Time; // In seconds
} TdrLimit;
D3DKMT_ESCAPE_PFN_CONTROL_COMMAND PfnControl; // periodic frame notification control
};
D3DKMT_ESCAPE_VIRTUAL_REFRESH_RATE VirtualRefreshRateControl;
} D3DKMT_VIDSCH_ESCAPE;
typedef struct _D3DKMT_TDRDBGCTRL_ESCAPE
{
D3DKMT_TDRDBGCTRLTYPE TdrControl; // control tdr
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WIN8)
union
{
ULONG NodeOrdinal; // valid if TdrControl is set to D3DKMT_TDRDBGCTRLTYPE_ENGINETDR
};
#endif
} D3DKMT_TDRDBGCTRL_ESCAPE;
// Upper boundary on the DMM escape data size (in bytes).
enum
{
D3DKMT_MAX_DMM_ESCAPE_DATASIZE = 100*1024
};
// NOTE: If (ProvidedBufferSize >= MinRequiredBufferSize), then MinRequiredBufferSize = size of the actual complete data set in the Data[] array.
typedef struct _D3DKMT_DMM_ESCAPE
{
_In_ D3DKMT_DMMESCAPETYPE Type;
_In_ D3DKMT_ALIGN64 D3DKMT_SIZE_T ProvidedBufferSize; // actual size of Data[] array, in bytes.
_Out_ D3DKMT_ALIGN64 D3DKMT_SIZE_T MinRequiredBufferSize; // minimum required size of Data[] array to contain requested data.
_Out_writes_bytes_(ProvidedBufferSize) UCHAR Data[1];
} D3DKMT_DMM_ESCAPE;
typedef enum _D3DKMT_BRIGHTNESS_INFO_TYPE
{
D3DKMT_BRIGHTNESS_INFO_GET_POSSIBLE_LEVELS = 1,
D3DKMT_BRIGHTNESS_INFO_GET = 2,
D3DKMT_BRIGHTNESS_INFO_SET = 3,
D3DKMT_BRIGHTNESS_INFO_GET_CAPS = 4,
D3DKMT_BRIGHTNESS_INFO_SET_STATE = 5,
D3DKMT_BRIGHTNESS_INFO_SET_OPTIMIZATION = 6,
D3DKMT_BRIGHTNESS_INFO_GET_REDUCTION = 7,
D3DKMT_BRIGHTNESS_INFO_BEGIN_MANUAL_MODE = 8,
D3DKMT_BRIGHTNESS_INFO_END_MANUAL_MODE = 9,
D3DKMT_BRIGHTNESS_INFO_TOGGLE_LOGGING = 10,
D3DKMT_BRIGHTNESS_INFO_GET_NIT_RANGES = 11,
} D3DKMT_BRIGHTNESS_INFO_TYPE;
typedef struct _D3DKMT_BRIGHTNESS_POSSIBLE_LEVELS
{
UCHAR LevelCount;
UCHAR BrightnessLevels[256];
} D3DKMT_BRIGHTNESS_POSSIBLE_LEVELS;
typedef struct _D3DKMT_BRIGHTNESS_INFO
{
D3DKMT_BRIGHTNESS_INFO_TYPE Type;
ULONG ChildUid;
union
{
D3DKMT_BRIGHTNESS_POSSIBLE_LEVELS PossibleLevels;
UCHAR Brightness;
DXGK_BRIGHTNESS_CAPS BrightnessCaps;
DXGK_BRIGHTNESS_STATE BrightnessState;
DXGK_BACKLIGHT_OPTIMIZATION_LEVEL OptimizationLevel;
DXGK_BACKLIGHT_INFO ReductionInfo;
BOOLEAN VerboseLogging;
DXGK_BRIGHTNESS_GET_NIT_RANGES_OUT NitRanges;
DXGK_BRIGHTNESS_GET_OUT GetBrightnessMillinits;
DXGK_BRIGHTNESS_SET_IN SetBrightnessMillinits;
};
} D3DKMT_BRIGHTNESS_INFO;
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_0)
typedef struct _D3DKMT_BDDFALLBACK_CTL
{
BOOLEAN ForceBddHeadlessNextFallback;
} D3DKMT_BDDFALLBACK_CTL;
typedef struct _D3DKMT_REQUEST_MACHINE_CRASH_ESCAPE
{
D3DKMT_ALIGN64 D3DKMT_ULONG_PTR Param1;
D3DKMT_ALIGN64 D3DKMT_ULONG_PTR Param2;
D3DKMT_ALIGN64 D3DKMT_ULONG_PTR Param3;
} D3DKMT_REQUEST_MACHINE_CRASH_ESCAPE;
//
// VERIFIER OPTIONS
//
typedef enum _D3DKMT_VERIFIER_OPTION_MODE
{
D3DKMT_VERIFIER_OPTION_QUERY,
D3DKMT_VERIFIER_OPTION_SET
} D3DKMT_VERIFIER_OPTION_MODE;
typedef enum _D3DKMT_PROCESS_VERIFIER_OPTION_TYPE
{
//
// Dxgkrnl (0xxx)
//
//
// VidMm (1xxx)
//
D3DKMT_PROCESS_VERIFIER_OPTION_VIDMM_FLAGS = 1000,
D3DKMT_PROCESS_VERIFIER_OPTION_VIDMM_RESTRICT_BUDGET = 1001,
//
// VidSch (2xxx)
//
} D3DKMT_PROCESS_VERIFIER_OPTION_TYPE;
typedef union _D3DKMT_PROCESS_VERIFIER_VIDMM_FLAGS
{
struct
{
UINT ForceSynchronousEvict : 1;
UINT NeverDeferEvictions : 1;
UINT AlwaysFailCommitOnReclaim : 1;
UINT AlwaysPlaceInDemotedLocation : 1;
UINT Reserved : 28;
};
UINT32 Value;
} D3DKMT_PROCESS_VERIFIER_VIDMM_FLAGS;
typedef struct _D3DKMT_PROCESS_VERIFIER_VIDMM_RESTRICT_BUDGET
{
D3DKMT_ALIGN64 UINT64 LocalBudget;
D3DKMT_ALIGN64 UINT64 NonLocalBudget;
} D3DKMT_PROCESS_VERIFIER_VIDMM_RESTRICT_BUDGET;
typedef union _D3DKMT_PROCESS_VERIFIER_OPTION_DATA
{
D3DKMT_PROCESS_VERIFIER_VIDMM_FLAGS VidMmFlags;
D3DKMT_PROCESS_VERIFIER_VIDMM_RESTRICT_BUDGET VidMmRestrictBudget;
} D3DKMT_PROCESS_VERIFIER_OPTION_DATA;
typedef struct _D3DKMT_PROCESS_VERIFIER_OPTION
{
D3DKMT_PTR(HANDLE, hProcess);
D3DKMT_PROCESS_VERIFIER_OPTION_TYPE Type;
D3DKMT_VERIFIER_OPTION_MODE Mode;
D3DKMT_PROCESS_VERIFIER_OPTION_DATA Data;
} D3DKMT_PROCESS_VERIFIER_OPTION;
typedef enum _D3DKMT_ADAPTER_VERIFIER_OPTION_TYPE
{
//
// Dxgkrnl (0xxx)
//
//
// VidMm (1xxx)
//
D3DKMT_ADAPTER_VERIFIER_OPTION_VIDMM_FLAGS = 1000,
D3DKMT_ADAPTER_VERIFIER_OPTION_VIDMM_TRIM_INTERVAL = 1001,
//
// VidSch (2xxx)
//
} D3DKMT_ADAPTER_VERIFIER_OPTION_TYPE;
typedef union _D3DKMT_ADAPTER_VERIFIER_VIDMM_FLAGS
{
struct
{
UINT AlwaysRepatch : 1;
UINT FailSharedPrimary : 1;
UINT FailProbeAndLock : 1;
UINT AlwaysDiscardOffer : 1;
UINT NeverDiscardOffer : 1;
UINT ForceComplexLock : 1;
UINT NeverPrepatch : 1;
UINT ExpectPreparationFailure : 1;
UINT TakeSplitPoint : 1;
UINT FailAcquireSwizzlingRange : 1;
UINT PagingPathLockSubrange : 1;
UINT PagingPathLockMinrange : 1;
UINT FailVaRotation : 1;
UINT NoDemotion : 1;
UINT FailDefragPass : 1;
UINT AlwaysProcessOfferList : 1;
UINT AlwaysDecommitOffer : 1;
UINT NeverMoveDefrag : 1;
UINT AlwaysRelocateDisplayableResources : 1;
UINT AlwaysFailGrowVPRMoves : 1;
UINT Reserved : 12;
};
UINT32 Value;
} D3DKMT_ADAPTER_VERIFIER_VIDMM_FLAGS;
typedef struct _D3DKMT_ADAPTER_VERIFIER_VIDMM_TRIM_INTERVAL
{
D3DKMT_ALIGN64 UINT64 MinimumTrimInterval;
D3DKMT_ALIGN64 UINT64 MaximumTrimInterval;
D3DKMT_ALIGN64 UINT64 IdleTrimInterval;
} D3DKMT_ADAPTER_VERIFIER_VIDMM_TRIM_INTERVAL;
typedef union _D3DKMT_ADAPTER_VERIFIER_OPTION_DATA
{
D3DKMT_ADAPTER_VERIFIER_VIDMM_FLAGS VidMmFlags;
D3DKMT_ADAPTER_VERIFIER_VIDMM_TRIM_INTERVAL VidMmTrimInterval;
} D3DKMT_ADAPTER_VERIFIER_OPTION_DATA;
typedef struct _D3DKMT_ADAPTER_VERIFIER_OPTION
{
D3DKMT_ADAPTER_VERIFIER_OPTION_TYPE Type;
D3DKMT_VERIFIER_OPTION_MODE Mode;
D3DKMT_ADAPTER_VERIFIER_OPTION_DATA Data;
} D3DKMT_ADAPTER_VERIFIER_OPTION;
#endif // DXGKDDI_INTERFACE_VERSION_WDDM2_0
typedef enum _D3DKMT_DEVICEESCAPE_TYPE
{
D3DKMT_DEVICEESCAPE_VIDPNFROMALLOCATION = 0,
D3DKMT_DEVICEESCAPE_RESTOREGAMMA = 1,
} D3DKMT_DEVICEESCAPE_TYPE;
typedef struct _D3DKMT_DEVICE_ESCAPE
{
D3DKMT_DEVICEESCAPE_TYPE Type;
union
{
struct
{
D3DKMT_HANDLE hPrimaryAllocation; // in: Primary allocation handle
D3DDDI_VIDEO_PRESENT_SOURCE_ID VidPnSourceId; // out: VidPnSoureId of primary allocation
} VidPnFromAllocation;
};
} D3DKMT_DEVICE_ESCAPE;
typedef struct _D3DKMT_DEBUG_SNAPSHOT_ESCAPE
{
ULONG Length; // out: Actual length of the snapshot written in Buffer
BYTE Buffer[1]; // out: Buffer to place snapshot
} D3DKMT_DEBUG_SNAPSHOT_ESCAPE;
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WIN8)
#ifndef DXGK_DIAG_PROCESS_NAME_LENGTH
#define DXGK_DIAG_PROCESS_NAME_LENGTH 16
#endif
typedef enum _OUTPUTDUPL_CONTEXT_DEBUG_STATUS
{
OUTPUTDUPL_CONTEXT_DEBUG_STATUS_INACTIVE = 0,
OUTPUTDUPL_CONTEXT_DEBUG_STATUS_ACTIVE = 1,
OUTPUTDUPL_CONTEXT_DEBUG_STATUS_PENDING_DESTROY = 2,
OUTPUTDUPL_CONTEXT_DEBUG_STATUS_FORCE_UINT32 = 0xffffffff
}OUTPUTDUPL_CONTEXT_DEBUG_STATUS;
typedef struct _OUTPUTDUPL_CONTEXT_DEBUG_INFO
{
OUTPUTDUPL_CONTEXT_DEBUG_STATUS Status;
D3DKMT_PTR(HANDLE, ProcessID);
UINT32 AccumulatedPresents;
D3DKMT_ALIGN64 LARGE_INTEGER LastPresentTime;
D3DKMT_ALIGN64 LARGE_INTEGER LastMouseTime;
CHAR ProcessName[DXGK_DIAG_PROCESS_NAME_LENGTH];
} OUTPUTDUPL_CONTEXT_DEBUG_INFO;
#define GET_OUTPUT_DUPL_DEBUG_INFO_FROM_SNAPSHOT(pSnapshot, VidPnSource, OutputDuplContextIndex) \
(pSnapshot->OutputDuplDebugInfos[(VidPnSource * pSnapshot->NumOutputDuplContexts) + OutputDuplContextIndex])
typedef struct _D3DKMT_OUTPUTDUPL_SNAPSHOT
{
UINT Size; // _In_/out: Size of entire structure
UINT SessionProcessCount; // _Out_: Number of processes currently duplicating output in this session (max possible will be equal to NumOutputDuplContexts)
UINT SessionActiveConnectionsCount; // _Out_: Total number of active contexts in this session, may be more than number active in 2D array because that is per adapter
UINT NumVidPnSources; // _Out_: Max of first array index
UINT NumOutputDuplContexts; // _Out_: Max of second array index
UINT Padding;
// This field is in reality a two dimensional array, use GET_OUTPUT_DUPL_DEBUG_INFO_FROM_SNAPSHOT macro to get a specific one
_Field_size_bytes_(Size - sizeof(_D3DKMT_OUTPUTDUPL_SNAPSHOT)) OUTPUTDUPL_CONTEXT_DEBUG_INFO OutputDuplDebugInfos[0];
} D3DKMT_OUTPUTDUPL_SNAPSHOT;
#endif
typedef enum _D3DKMT_ACTIVATE_SPECIFIC_DIAG_TYPE
{
D3DKMT_ACTIVATE_SPECIFIC_DIAG_TYPE_EXTRA_CCD_DATABASE_INFO = 0,
D3DKMT_ACTIVATE_SPECIFIC_DIAG_TYPE_MODES_PRUNED = 15,
}D3DKMT_ACTIVATE_SPECIFIC_DIAG_TYPE;
typedef struct _D3DKMT_ACTIVATE_SPECIFIC_DIAG_ESCAPE
{
D3DKMT_ACTIVATE_SPECIFIC_DIAG_TYPE Type; // The escape type that needs to be (de)activated
BOOL Activate; // FALSE means deactivate
} D3DKMT_ACTIVATE_SPECIFIC_DIAG_ESCAPE;
typedef struct _D3DKMT_ESCAPE
{
D3DKMT_HANDLE hAdapter; // in: adapter handle
D3DKMT_HANDLE hDevice; // in: device handle [Optional]
D3DKMT_ESCAPETYPE Type; // in: escape type.
D3DDDI_ESCAPEFLAGS Flags; // in: flags
D3DKMT_PTR(VOID*, pPrivateDriverData); // in/out: escape data
UINT PrivateDriverDataSize; // in: size of escape data
D3DKMT_HANDLE hContext; // in: context handle [Optional]
} D3DKMT_ESCAPE;
//
// begin D3DKMT_QUERYSTATISTICS
//
typedef enum _D3DKMT_QUERYRESULT_PREEMPTION_ATTEMPT_RESULT
{
D3DKMT_PreemptionAttempt = 0,
D3DKMT_PreemptionAttemptSuccess = 1,
D3DKMT_PreemptionAttemptMissNoCommand = 2,
D3DKMT_PreemptionAttemptMissNotEnabled = 3,
D3DKMT_PreemptionAttemptMissNextFence = 4,
D3DKMT_PreemptionAttemptMissPagingCommand = 5,
D3DKMT_PreemptionAttemptMissSplittedCommand = 6,
D3DKMT_PreemptionAttemptMissFenceCommand = 7,
D3DKMT_PreemptionAttemptMissRenderPendingFlip = 8,
D3DKMT_PreemptionAttemptMissNotMakingProgress = 9,
D3DKMT_PreemptionAttemptMissLessPriority = 10,
D3DKMT_PreemptionAttemptMissRemainingQuantum = 11,
D3DKMT_PreemptionAttemptMissRemainingPreemptionQuantum = 12,
D3DKMT_PreemptionAttemptMissAlreadyPreempting = 13,
D3DKMT_PreemptionAttemptMissGlobalBlock = 14,
D3DKMT_PreemptionAttemptMissAlreadyRunning = 15,
D3DKMT_PreemptionAttemptStatisticsMax = 16,
} D3DKMT_QUERYRESULT_PREEMPTION_ATTEMPT_RESULT;
//
// WOW will not allow enum member as array length, so define it as a constant
//
#define D3DKMT_QUERYRESULT_PREEMPTION_ATTEMPT_RESULT_MAX 16
C_ASSERT(D3DKMT_QUERYRESULT_PREEMPTION_ATTEMPT_RESULT_MAX == D3DKMT_PreemptionAttemptStatisticsMax);
//
// Command packet type
//
typedef enum _D3DKMT_QUERYSTATISTICS_DMA_PACKET_TYPE {
D3DKMT_ClientRenderBuffer = 0, // (Dma packet) should be 0 base.
D3DKMT_ClientPagingBuffer = 1, // (Dma packet)
D3DKMT_SystemPagingBuffer = 2, // (Dma packet)
D3DKMT_SystemPreemptionBuffer = 3, // (Dma packet)
D3DKMT_DmaPacketTypeMax = 4
} D3DKMT_QUERYSTATISTICS_DMA_PACKET_TYPE;
//
// WOW will not allow enum member as array length, so define it as a constant
//
#define D3DKMT_QUERYSTATISTICS_DMA_PACKET_TYPE_MAX 4
C_ASSERT(D3DKMT_QUERYSTATISTICS_DMA_PACKET_TYPE_MAX == D3DKMT_DmaPacketTypeMax);
typedef enum _D3DKMT_QUERYSTATISTICS_QUEUE_PACKET_TYPE {
D3DKMT_RenderCommandBuffer = 0, // (Queue Packet) should be 0 base.
D3DKMT_DeferredCommandBuffer = 1, // (Queue Packet)
D3DKMT_SystemCommandBuffer = 2, // (Queue Packet)
D3DKMT_MmIoFlipCommandBuffer = 3, // (Queue Packet)
D3DKMT_WaitCommandBuffer = 4, // (Queue Packet)
D3DKMT_SignalCommandBuffer = 5, // (Queue Packet)
D3DKMT_DeviceCommandBuffer = 6, // (Queue Packet)
D3DKMT_SoftwareCommandBuffer = 7, // (Queue Packet)
D3DKMT_QueuePacketTypeMax = 8
} D3DKMT_QUERYSTATISTICS_QUEUE_PACKET_TYPE;
//
// WOW will not allow enum member as array length, so define it as a constant
//
#define D3DKMT_QUERYSTATISTICS_QUEUE_PACKET_TYPE_MAX 8
C_ASSERT(D3DKMT_QUERYSTATISTICS_QUEUE_PACKET_TYPE_MAX == D3DKMT_QueuePacketTypeMax);
typedef enum _D3DKMT_QUERYSTATISTICS_ALLOCATION_PRIORITY_CLASS
{
D3DKMT_AllocationPriorityClassMinimum = 0,
D3DKMT_AllocationPriorityClassLow = 1,
D3DKMT_AllocationPriorityClassNormal = 2,
D3DKMT_AllocationPriorityClassHigh = 3,
D3DKMT_AllocationPriorityClassMaximum = 4,
D3DKMT_MaxAllocationPriorityClass = 5
} D3DKMT_QUERYSTATISTICS_ALLOCATION_PRIORITY_CLASS;
//
// WOW will not allow enum member as array length, so define it as a constant
//
#define D3DKMT_QUERYSTATISTICS_ALLOCATION_PRIORITY_CLASS_MAX 5
C_ASSERT(D3DKMT_QUERYSTATISTICS_ALLOCATION_PRIORITY_CLASS_MAX == D3DKMT_MaxAllocationPriorityClass);
//
// Allocation segment preference set can contain 5 preferences
//
#define D3DKMT_QUERYSTATISTICS_SEGMENT_PREFERENCE_MAX 5
typedef struct _D3DKMT_QUERYSTATISTICS_COUNTER
{
ULONG Count;
ULONGLONG Bytes;
} D3DKMT_QUERYSTATISTICS_COUNTER;
typedef struct _D3DKMT_QUERYSTATISTICS_DMA_PACKET_TYPE_INFORMATION {
ULONG PacketSubmited;
ULONG PacketCompleted;
ULONG PacketPreempted;
ULONG PacketFaulted;
} D3DKMT_QUERYSTATISTICS_DMA_PACKET_TYPE_INFORMATION;
typedef struct _D3DKMT_QUERYSTATISTICS_QUEUE_PACKET_TYPE_INFORMATION {
ULONG PacketSubmited;
ULONG PacketCompleted;
} D3DKMT_QUERYSTATISTICS_QUEUE_PACKET_TYPE_INFORMATION;
typedef struct _D3DKMT_QUERYSTATISTICS_PACKET_INFORMATION {
D3DKMT_QUERYSTATISTICS_QUEUE_PACKET_TYPE_INFORMATION QueuePacket[D3DKMT_QUERYSTATISTICS_QUEUE_PACKET_TYPE_MAX]; //Size = D3DKMT_QueuePacketTypeMax
D3DKMT_QUERYSTATISTICS_DMA_PACKET_TYPE_INFORMATION DmaPacket[D3DKMT_QUERYSTATISTICS_DMA_PACKET_TYPE_MAX]; //Size = D3DKMT_DmaPacketTypeMax
} D3DKMT_QUERYSTATISTICS_PACKET_INFORMATION;
typedef struct _D3DKMT_QUERYSTATISTICS_PREEMPTION_INFORMATION {
ULONG PreemptionCounter[D3DKMT_QUERYRESULT_PREEMPTION_ATTEMPT_RESULT_MAX];
} D3DKMT_QUERYSTATISTICS_PREEMPTION_INFORMATION;
typedef struct _D3DKMT_QUERYSTATISTICS_PROCESS_NODE_INFORMATION {
D3DKMT_ALIGN64 LARGE_INTEGER RunningTime; // Running time in micro-second.
ULONG ContextSwitch;
D3DKMT_QUERYSTATISTICS_PREEMPTION_INFORMATION PreemptionStatistics;
D3DKMT_QUERYSTATISTICS_PACKET_INFORMATION PacketStatistics;
D3DKMT_ALIGN64 UINT64 Reserved[8];
} D3DKMT_QUERYSTATISTICS_PROCESS_NODE_INFORMATION;
typedef struct _D3DKMT_QUERYSTATISTICS_NODE_INFORMATION {
D3DKMT_QUERYSTATISTICS_PROCESS_NODE_INFORMATION GlobalInformation; //Global statistics
D3DKMT_QUERYSTATISTICS_PROCESS_NODE_INFORMATION SystemInformation; //Statistics for system thread
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_4)
D3DKMT_NODE_PERFDATA NodePerfData;
UINT32 Reserved[3];
#else
D3DKMT_ALIGN64 UINT64 Reserved[8];
#endif
} D3DKMT_QUERYSTATISTICS_NODE_INFORMATION;
typedef struct _D3DKMT_QUERYSTATISTICS_PROCESS_VIDPNSOURCE_INFORMATION {
ULONG Frame; // both by Blt and Flip.
ULONG CancelledFrame; // by restart (flip only).
ULONG QueuedPresent; // queued present.
UINT Padding;
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_7)
D3DKMT_ALIGN64 UINT64 IsVSyncEnabled;
D3DKMT_ALIGN64 UINT64 VSyncOnTotalTimeMs;
D3DKMT_ALIGN64 UINT64 VSyncOffKeepPhaseTotalTimeMs;
D3DKMT_ALIGN64 UINT64 VSyncOffNoPhaseTotalTimeMs;
D3DKMT_ALIGN64 UINT64 Reserved[4];
#else
D3DKMT_ALIGN64 UINT64 Reserved[8];
#endif
} D3DKMT_QUERYSTATISTICS_PROCESS_VIDPNSOURCE_INFORMATION;
typedef struct _D3DKMT_QUERYSTATISTICS_VIDPNSOURCE_INFORMATION {
D3DKMT_QUERYSTATISTICS_PROCESS_VIDPNSOURCE_INFORMATION GlobalInformation; //Global statistics
D3DKMT_QUERYSTATISTICS_PROCESS_VIDPNSOURCE_INFORMATION SystemInformation; //Statistics for system thread
D3DKMT_ALIGN64 UINT64 Reserved[8];
} D3DKMT_QUERYSTATISTICS_VIDPNSOURCE_INFORMATION;
typedef struct _D3DKMT_QUERYSTATSTICS_REFERENCE_DMA_BUFFER
{
ULONG NbCall;
ULONG NbAllocationsReferenced;
ULONG MaxNbAllocationsReferenced;
ULONG NbNULLReference;
ULONG NbWriteReference;
ULONG NbRenamedAllocationsReferenced;
ULONG NbIterationSearchingRenamedAllocation;
ULONG NbLockedAllocationReferenced;
ULONG NbAllocationWithValidPrepatchingInfoReferenced;
ULONG NbAllocationWithInvalidPrepatchingInfoReferenced;
ULONG NbDMABufferSuccessfullyPrePatched;
ULONG NbPrimariesReferencesOverflow;
ULONG NbAllocationWithNonPreferredResources;
ULONG NbAllocationInsertedInMigrationTable;
} D3DKMT_QUERYSTATSTICS_REFERENCE_DMA_BUFFER;
typedef struct _D3DKMT_QUERYSTATSTICS_RENAMING
{
ULONG NbAllocationsRenamed;
ULONG NbAllocationsShrinked;
ULONG NbRenamedBuffer;
ULONG MaxRenamingListLength;
ULONG NbFailuresDueToRenamingLimit;
ULONG NbFailuresDueToCreateAllocation;
ULONG NbFailuresDueToOpenAllocation;
ULONG NbFailuresDueToLowResource;
ULONG NbFailuresDueToNonRetiredLimit;
} D3DKMT_QUERYSTATSTICS_RENAMING;
typedef struct _D3DKMT_QUERYSTATSTICS_PREPRATION
{
ULONG BroadcastStall;
ULONG NbDMAPrepared;
ULONG NbDMAPreparedLongPath;
ULONG ImmediateHighestPreparationPass;
D3DKMT_QUERYSTATISTICS_COUNTER AllocationsTrimmed;
} D3DKMT_QUERYSTATSTICS_PREPRATION;
typedef struct _D3DKMT_QUERYSTATSTICS_PAGING_FAULT
{
D3DKMT_QUERYSTATISTICS_COUNTER Faults;
D3DKMT_QUERYSTATISTICS_COUNTER FaultsFirstTimeAccess;
D3DKMT_QUERYSTATISTICS_COUNTER FaultsReclaimed;
D3DKMT_QUERYSTATISTICS_COUNTER FaultsMigration;
D3DKMT_QUERYSTATISTICS_COUNTER FaultsIncorrectResource;
D3DKMT_QUERYSTATISTICS_COUNTER FaultsLostContent;
D3DKMT_QUERYSTATISTICS_COUNTER FaultsEvicted;
D3DKMT_QUERYSTATISTICS_COUNTER AllocationsMEM_RESET;
D3DKMT_QUERYSTATISTICS_COUNTER AllocationsUnresetSuccess;
D3DKMT_QUERYSTATISTICS_COUNTER AllocationsUnresetFail;
ULONG AllocationsUnresetSuccessRead;
ULONG AllocationsUnresetFailRead;
D3DKMT_QUERYSTATISTICS_COUNTER Evictions;
D3DKMT_QUERYSTATISTICS_COUNTER EvictionsDueToPreparation;
D3DKMT_QUERYSTATISTICS_COUNTER EvictionsDueToLock;
D3DKMT_QUERYSTATISTICS_COUNTER EvictionsDueToClose;
D3DKMT_QUERYSTATISTICS_COUNTER EvictionsDueToPurge;
D3DKMT_QUERYSTATISTICS_COUNTER EvictionsDueToSuspendCPUAccess;
} D3DKMT_QUERYSTATSTICS_PAGING_FAULT;
typedef struct _D3DKMT_QUERYSTATSTICS_PAGING_TRANSFER
{
D3DKMT_ALIGN64 ULONGLONG BytesFilled;
D3DKMT_ALIGN64 ULONGLONG BytesDiscarded;
D3DKMT_ALIGN64 ULONGLONG BytesMappedIntoAperture;
D3DKMT_ALIGN64 ULONGLONG BytesUnmappedFromAperture;
D3DKMT_ALIGN64 ULONGLONG BytesTransferredFromMdlToMemory;
D3DKMT_ALIGN64 ULONGLONG BytesTransferredFromMemoryToMdl;
D3DKMT_ALIGN64 ULONGLONG BytesTransferredFromApertureToMemory;
D3DKMT_ALIGN64 ULONGLONG BytesTransferredFromMemoryToAperture;
} D3DKMT_QUERYSTATSTICS_PAGING_TRANSFER;
typedef struct _D3DKMT_QUERYSTATSTICS_SWIZZLING_RANGE
{
ULONG NbRangesAcquired;
ULONG NbRangesReleased;
} D3DKMT_QUERYSTATSTICS_SWIZZLING_RANGE;
typedef struct _D3DKMT_QUERYSTATSTICS_LOCKS
{
ULONG NbLocks;
ULONG NbLocksWaitFlag;
ULONG NbLocksDiscardFlag;
ULONG NbLocksNoOverwrite;
ULONG NbLocksNoReadSync;
ULONG NbLocksLinearization;
ULONG NbComplexLocks;
} D3DKMT_QUERYSTATSTICS_LOCKS;
typedef struct _D3DKMT_QUERYSTATSTICS_ALLOCATIONS
{
D3DKMT_QUERYSTATISTICS_COUNTER Created;
D3DKMT_QUERYSTATISTICS_COUNTER Destroyed;
D3DKMT_QUERYSTATISTICS_COUNTER Opened;
D3DKMT_QUERYSTATISTICS_COUNTER Closed;
D3DKMT_QUERYSTATISTICS_COUNTER MigratedSuccess;
D3DKMT_QUERYSTATISTICS_COUNTER MigratedFail;
D3DKMT_QUERYSTATISTICS_COUNTER MigratedAbandoned;
} D3DKMT_QUERYSTATSTICS_ALLOCATIONS;
typedef struct _D3DKMT_QUERYSTATSTICS_TERMINATIONS
{
//
// We separate shared / nonshared because for nonshared we know that every alloc
// terminated will lead cause a global alloc destroyed, but not for nonshared.
//
D3DKMT_QUERYSTATISTICS_COUNTER TerminatedShared;
D3DKMT_QUERYSTATISTICS_COUNTER TerminatedNonShared;
D3DKMT_QUERYSTATISTICS_COUNTER DestroyedShared;
D3DKMT_QUERYSTATISTICS_COUNTER DestroyedNonShared;
} D3DKMT_QUERYSTATSTICS_TERMINATIONS;
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_1)
typedef struct _D3DKMT_QUERYSTATISTICS_ADAPTER_INFORMATION_FLAGS
{
union
{
struct
{
UINT64 NumberOfMemoryGroups : 2;
UINT64 SupportsDemotion : 1;
UINT64 Reserved :61;
};
D3DKMT_ALIGN64 UINT64 Value;
};
} D3DKMT_QUERYSTATISTICS_ADAPTER_INFORMATION_FLAGS;
#endif
typedef struct _D3DKMT_QUERYSTATISTICS_ADAPTER_INFORMATION
{
ULONG NbSegments;
ULONG NodeCount;
ULONG VidPnSourceCount;
ULONG VSyncEnabled;
ULONG TdrDetectedCount;
D3DKMT_ALIGN64 LONGLONG ZeroLengthDmaBuffers;
D3DKMT_ALIGN64 ULONGLONG RestartedPeriod;
D3DKMT_QUERYSTATSTICS_REFERENCE_DMA_BUFFER ReferenceDmaBuffer;
D3DKMT_QUERYSTATSTICS_RENAMING Renaming;
D3DKMT_QUERYSTATSTICS_PREPRATION Preparation;
D3DKMT_QUERYSTATSTICS_PAGING_FAULT PagingFault;
D3DKMT_QUERYSTATSTICS_PAGING_TRANSFER PagingTransfer;
D3DKMT_QUERYSTATSTICS_SWIZZLING_RANGE SwizzlingRange;
D3DKMT_QUERYSTATSTICS_LOCKS Locks;
D3DKMT_QUERYSTATSTICS_ALLOCATIONS Allocations;
D3DKMT_QUERYSTATSTICS_TERMINATIONS Terminations;
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_2)
D3DKMT_QUERYSTATISTICS_ADAPTER_INFORMATION_FLAGS Flags;
D3DKMT_ALIGN64 UINT64 Reserved[7];
#else
D3DKMT_ALIGN64 UINT64 Reserved[8];
#endif
} D3DKMT_QUERYSTATISTICS_ADAPTER_INFORMATION;
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_4)
typedef struct _D3DKMT_QUERYSTATISTICS_PHYSICAL_ADAPTER_INFORMATION
{
D3DKMT_ADAPTER_PERFDATA AdapterPerfData;
D3DKMT_ADAPTER_PERFDATACAPS AdapterPerfDataCaps;
D3DKMT_GPUVERSION GpuVersion;
} D3DKMT_QUERYSTATISTICS_PHYSICAL_ADAPTER_INFORMATION;
#endif
typedef struct _D3DKMT_QUERYSTATISTICS_SYSTEM_MEMORY
{
D3DKMT_ALIGN64 ULONGLONG BytesAllocated;
D3DKMT_ALIGN64 ULONGLONG BytesReserved;
ULONG SmallAllocationBlocks;
ULONG LargeAllocationBlocks;
D3DKMT_ALIGN64 ULONGLONG WriteCombinedBytesAllocated;
D3DKMT_ALIGN64 ULONGLONG WriteCombinedBytesReserved;
D3DKMT_ALIGN64 ULONGLONG CachedBytesAllocated;
D3DKMT_ALIGN64 ULONGLONG CachedBytesReserved;
D3DKMT_ALIGN64 ULONGLONG SectionBytesAllocated;
D3DKMT_ALIGN64 ULONGLONG SectionBytesReserved;
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_4)
D3DKMT_ALIGN64 ULONGLONG BytesZeroed;
#else
D3DKMT_ALIGN64 ULONGLONG Reserved;
#endif
} D3DKMT_QUERYSTATISTICS_SYSTEM_MEMORY;
typedef struct _D3DKMT_QUERYSTATISTICS_PROCESS_INFORMATION
{
ULONG NodeCount;
ULONG VidPnSourceCount;
D3DKMT_QUERYSTATISTICS_SYSTEM_MEMORY SystemMemory;
D3DKMT_ALIGN64 UINT64 Reserved[7];
} D3DKMT_QUERYSTATISTICS_PROCESS_INFORMATION;
typedef struct _D3DKMT_QUERYSTATISTICS_DMA_BUFFER
{
D3DKMT_QUERYSTATISTICS_COUNTER Size;
ULONG AllocationListBytes;
ULONG PatchLocationListBytes;
} D3DKMT_QUERYSTATISTICS_DMA_BUFFER;
typedef struct _D3DKMT_QUERYSTATISTICS_COMMITMENT_DATA
{
D3DKMT_ALIGN64 UINT64 TotalBytesEvictedFromProcess;
D3DKMT_ALIGN64 UINT64 BytesBySegmentPreference[D3DKMT_QUERYSTATISTICS_SEGMENT_PREFERENCE_MAX];
} D3DKMT_QUERYSTATISTICS_COMMITMENT_DATA;
typedef struct _D3DKMT_QUERYSTATISTICS_POLICY
{
D3DKMT_ALIGN64 ULONGLONG PreferApertureForRead[D3DKMT_QUERYSTATISTICS_ALLOCATION_PRIORITY_CLASS_MAX];
D3DKMT_ALIGN64 ULONGLONG PreferAperture[D3DKMT_QUERYSTATISTICS_ALLOCATION_PRIORITY_CLASS_MAX];
D3DKMT_ALIGN64 ULONGLONG MemResetOnPaging;
D3DKMT_ALIGN64 ULONGLONG RemovePagesFromWorkingSetOnPaging;
D3DKMT_ALIGN64 ULONGLONG MigrationEnabled;
} D3DKMT_QUERYSTATISTICS_POLICY;
// Process interference counters indicate how much this process GPU workload interferes with packets
// attempting to preempt it. 9 buckets will be exposed based on how long preemption took:
// [0] 100 microseconds <= preemption time < 250 microseconds
// [1] 250 microseconds <= preemption time < 500 microseconds
// [2] 500 microseconds <= preemption time < 1 milliseconds
// [3] 1 milliseconds <= preemption time < 2.5 milliseconds
// [4] 2.5 milliseconds <= preemption time < 5 milliseconds
// [5] 5 milliseconds <= preemption time < 10 milliseconds
// [6] 10 milliseconds <= preemption time < 25 milliseconds
// [7] 25 milliseconds <= preemption time < 50 milliseconds
// [8] 50 milliseconds <= preemption time
//
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_1)
#define D3DKMT_QUERYSTATISTICS_PROCESS_INTERFERENCE_BUCKET_COUNT 9
typedef struct _D3DKMT_QUERYSTATISTICS_PROCESS_INTERFERENCE_COUNTERS
{
D3DKMT_ALIGN64 UINT64 InterferenceCount[D3DKMT_QUERYSTATISTICS_PROCESS_INTERFERENCE_BUCKET_COUNT];
} D3DKMT_QUERYSTATISTICS_PROCESS_INTERFERENCE_COUNTERS;
#endif
typedef struct _D3DKMT_QUERYSTATISTICS_PROCESS_ADAPTER_INFORMATION
{
ULONG NbSegments;
ULONG NodeCount;
ULONG VidPnSourceCount;
//
// Virtual address space used by vidmm for this process
//
ULONG VirtualMemoryUsage;
D3DKMT_QUERYSTATISTICS_DMA_BUFFER DmaBuffer;
D3DKMT_QUERYSTATISTICS_COMMITMENT_DATA CommitmentData;
D3DKMT_QUERYSTATISTICS_POLICY _Policy;
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_1)
D3DKMT_QUERYSTATISTICS_PROCESS_INTERFERENCE_COUNTERS ProcessInterferenceCounters;
#else
D3DKMT_ALIGN64 UINT64 Reserved[9];
#endif
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_9)
D3DKMT_CLIENTHINT ClientHint;
#else
UINT Reserve;
#endif
} D3DKMT_QUERYSTATISTICS_PROCESS_ADAPTER_INFORMATION;
typedef struct _D3DKMT_QUERYSTATISTICS_MEMORY
{
D3DKMT_ALIGN64 ULONGLONG TotalBytesEvicted;
ULONG AllocsCommitted;
ULONG AllocsResident;
} D3DKMT_QUERYSTATISTICS_MEMORY;
typedef struct _D3DKMT_QUERYSTATISTICS_SEGMENT_INFORMATION
{
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WIN8)
D3DKMT_ALIGN64 ULONGLONG CommitLimit;
D3DKMT_ALIGN64 ULONGLONG BytesCommitted;
D3DKMT_ALIGN64 ULONGLONG BytesResident;
#else
ULONG CommitLimit;
ULONG BytesCommitted;
ULONG BytesResident;
#endif
D3DKMT_QUERYSTATISTICS_MEMORY Memory;
//
// Boolean, whether this is an aperture segment
//
ULONG Aperture;
//
// Breakdown of bytes evicted by priority class
//
D3DKMT_ALIGN64 ULONGLONG TotalBytesEvictedByPriority[D3DKMT_QUERYSTATISTICS_ALLOCATION_PRIORITY_CLASS_MAX]; //Size = D3DKMT_MaxAllocationPriorityClass
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WIN8)
D3DKMT_ALIGN64 UINT64 SystemMemoryEndAddress;
struct D3DKMT_ALIGN64
{
UINT64 PreservedDuringStandby : 1;
UINT64 PreservedDuringHibernate : 1;
UINT64 PartiallyPreservedDuringHibernate : 1;
UINT64 Reserved : 61;
} PowerFlags;
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_9)
struct D3DKMT_ALIGN64
{
UINT64 SystemMemory : 1;
UINT64 PopulatedByReservedDDRByFirmware : 1;
UINT64 Reserved : 62;
} SegmentProperties;
D3DKMT_ALIGN64 UINT64 Reserved[5];
#else
D3DKMT_ALIGN64 UINT64 Reserved[6];
#endif // (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_9)
#else
D3DKMT_ALIGN64 UINT64 Reserved[8];
#endif // (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WIN8)
} D3DKMT_QUERYSTATISTICS_SEGMENT_INFORMATION;
//
// Video memory statistics.
//
typedef struct _D3DKMT_QUERYSTATISTICS_VIDEO_MEMORY
{
ULONG AllocsCommitted;
D3DKMT_QUERYSTATISTICS_COUNTER AllocsResidentInP[D3DKMT_QUERYSTATISTICS_SEGMENT_PREFERENCE_MAX];
D3DKMT_QUERYSTATISTICS_COUNTER AllocsResidentInNonPreferred;
D3DKMT_ALIGN64 ULONGLONG TotalBytesEvictedDueToPreparation;
} D3DKMT_QUERYSTATISTICS_VIDEO_MEMORY;
//
// VidMM Policies
//
typedef struct _D3DKMT_QUERYSTATISTICS_PROCESS_SEGMENT_POLICY
{
D3DKMT_ALIGN64 ULONGLONG UseMRU;
} D3DKMT_QUERYSTATISTICS_PROCESS_SEGMENT_POLICY;
typedef struct _D3DKMT_QUERYSTATISTICS_PROCESS_SEGMENT_INFORMATION
{
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WIN8)
D3DKMT_ALIGN64 ULONGLONG BytesCommitted;
D3DKMT_ALIGN64 ULONGLONG MaximumWorkingSet;
D3DKMT_ALIGN64 ULONGLONG MinimumWorkingSet;
ULONG NbReferencedAllocationEvictedInPeriod;
UINT Padding;
#else
ULONG BytesCommitted;
ULONG NbReferencedAllocationEvictedInPeriod;
ULONG MaximumWorkingSet;
ULONG MinimumWorkingSet;
#endif
D3DKMT_QUERYSTATISTICS_VIDEO_MEMORY VideoMemory;
D3DKMT_QUERYSTATISTICS_PROCESS_SEGMENT_POLICY _Policy;
D3DKMT_ALIGN64 UINT64 Reserved[8];
} D3DKMT_QUERYSTATISTICS_PROCESS_SEGMENT_INFORMATION;
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_1)
typedef struct _D3DKMT_QUERYSTATISTICS_PROCESS_SEGMENT_GROUP_INFORMATION
{
D3DKMT_ALIGN64 UINT64 Budget;
D3DKMT_ALIGN64 UINT64 Requested;
D3DKMT_ALIGN64 UINT64 Usage;
D3DKMT_ALIGN64 UINT64 Demoted[D3DKMT_QUERYSTATISTICS_ALLOCATION_PRIORITY_CLASS_MAX];
} D3DKMT_QUERYSTATISTICS_PROCESS_SEGMENT_GROUP_INFORMATION;
#endif
typedef enum _D3DKMT_QUERYSTATISTICS_TYPE
{
D3DKMT_QUERYSTATISTICS_ADAPTER = 0,
D3DKMT_QUERYSTATISTICS_PROCESS = 1,
D3DKMT_QUERYSTATISTICS_PROCESS_ADAPTER = 2,
D3DKMT_QUERYSTATISTICS_SEGMENT = 3,
D3DKMT_QUERYSTATISTICS_PROCESS_SEGMENT = 4,
D3DKMT_QUERYSTATISTICS_NODE = 5,
D3DKMT_QUERYSTATISTICS_PROCESS_NODE = 6,
D3DKMT_QUERYSTATISTICS_VIDPNSOURCE = 7,
D3DKMT_QUERYSTATISTICS_PROCESS_VIDPNSOURCE = 8,
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_1)
D3DKMT_QUERYSTATISTICS_PROCESS_SEGMENT_GROUP = 9,
#endif
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_4)
D3DKMT_QUERYSTATISTICS_PHYSICAL_ADAPTER = 10,
#endif
} D3DKMT_QUERYSTATISTICS_TYPE;
typedef struct _D3DKMT_QUERYSTATISTICS_QUERY_SEGMENT
{
ULONG SegmentId; // in: id of node to get statistics for
} D3DKMT_QUERYSTATISTICS_QUERY_SEGMENT;
typedef struct _D3DKMT_QUERYSTATISTICS_QUERY_NODE
{
ULONG NodeId;
} D3DKMT_QUERYSTATISTICS_QUERY_NODE;
typedef struct _D3DKMT_QUERYSTATISTICS_QUERY_VIDPNSOURCE
{
ULONG VidPnSourceId; // in: id of segment to get statistics for
} D3DKMT_QUERYSTATISTICS_QUERY_VIDPNSOURCE;
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_4)
typedef struct _D3DKMT_QUERYSTATISTICS_QUERY_PHYSICAL_ADAPTER
{
ULONG PhysicalAdapterIndex;
} D3DKMT_QUERYSTATISTICS_QUERY_PHYSICAL_ADAPTER;
#endif
typedef union _D3DKMT_QUERYSTATISTICS_RESULT
{
D3DKMT_QUERYSTATISTICS_ADAPTER_INFORMATION AdapterInformation; // out: result of D3DKMT_QUERYSTATISTICS_ADAPTER query
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_4)
D3DKMT_QUERYSTATISTICS_PHYSICAL_ADAPTER_INFORMATION PhysAdapterInformation; // out: result of D3DKMT_QUERYSTATISTICS_PHYSICAL_ADAPTER query
#endif
D3DKMT_QUERYSTATISTICS_SEGMENT_INFORMATION SegmentInformation; // out: result of D3DKMT_QUERYSTATISTICS_SEGMENT query
D3DKMT_QUERYSTATISTICS_NODE_INFORMATION NodeInformation; // out: result of D3DKMT_QUERYSTATISTICS_NODE query
D3DKMT_QUERYSTATISTICS_VIDPNSOURCE_INFORMATION VidPnSourceInformation; // out: result of D3DKMT_QUERYSTATISTICS_VIDPNSOURCE query
D3DKMT_QUERYSTATISTICS_PROCESS_INFORMATION ProcessInformation; // out: result of D3DKMT_QUERYSTATISTICS_PROCESS query
D3DKMT_QUERYSTATISTICS_PROCESS_ADAPTER_INFORMATION ProcessAdapterInformation; // out: result of D3DKMT_QUERYSTATISTICS_PROCESS_ADAPTER query
D3DKMT_QUERYSTATISTICS_PROCESS_SEGMENT_INFORMATION ProcessSegmentInformation; // out: result of D3DKMT_QUERYSTATISTICS_PROCESS_SEGMENT query
D3DKMT_QUERYSTATISTICS_PROCESS_NODE_INFORMATION ProcessNodeInformation; // out: result of D3DKMT_QUERYSTATISTICS_PROCESS_NODE query
D3DKMT_QUERYSTATISTICS_PROCESS_VIDPNSOURCE_INFORMATION ProcessVidPnSourceInformation; // out: result of D3DKMT_QUERYSTATISTICS_PROCESS_VIDPNSOURCE query
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_1)
D3DKMT_QUERYSTATISTICS_PROCESS_SEGMENT_GROUP_INFORMATION ProcessSegmentGroupInformation;// out: result of D3DKMT_QUERYSTATISTICS_PROCESS_SEGMENT_GROUP query
#endif
} D3DKMT_QUERYSTATISTICS_RESULT;
typedef struct _D3DKMT_QUERYSTATISTICS
{
D3DKMT_QUERYSTATISTICS_TYPE Type; // in: type of data requested
LUID AdapterLuid; // in: adapter to get export / statistics from
D3DKMT_PTR(HANDLE, hProcess); // in: process to get statistics for, if required for this query type
D3DKMT_QUERYSTATISTICS_RESULT QueryResult; // out: requested data
union
{
D3DKMT_QUERYSTATISTICS_QUERY_SEGMENT QuerySegment; // in: id of segment to get statistics for
D3DKMT_QUERYSTATISTICS_QUERY_SEGMENT QueryProcessSegment; // in: id of segment to get statistics for
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_1)
D3DKMT_MEMORY_SEGMENT_GROUP QueryProcessSegmentGroup; // in: id of segment group to get statistics for
#endif
D3DKMT_QUERYSTATISTICS_QUERY_NODE QueryNode; // in: id of node to get statistics for
D3DKMT_QUERYSTATISTICS_QUERY_NODE QueryProcessNode; // in: id of node to get statistics for
D3DKMT_QUERYSTATISTICS_QUERY_VIDPNSOURCE QueryVidPnSource; // in: id of vidpnsource to get statistics for
D3DKMT_QUERYSTATISTICS_QUERY_VIDPNSOURCE QueryProcessVidPnSource; // in: id of vidpnsource to get statistics for
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_4)
D3DKMT_QUERYSTATISTICS_QUERY_PHYSICAL_ADAPTER QueryPhysAdapter; // in: id of physical adapter to get statistics for
#endif
};
} D3DKMT_QUERYSTATISTICS;
#if defined(_AMD64_)
C_ASSERT(sizeof(D3DKMT_QUERYSTATISTICS) == 0x328);
#endif
//
// end D3DKMT_QUERYSTATISTICS
//
typedef struct _D3DKMT_PRESENT_STATS_DWM2
{
ULONG cbSize; // in: size of struct for versioning
UINT PresentCount;
UINT PresentRefreshCount;
D3DKMT_ALIGN64 LARGE_INTEGER PresentQPCTime;
UINT SyncRefreshCount;
D3DKMT_ALIGN64 LARGE_INTEGER SyncQPCTime;
UINT CustomPresentDuration;
UINT VirtualSyncRefreshCount;
D3DKMT_ALIGN64 LARGE_INTEGER VirtualSyncQPCTime;
} D3DKMT_PRESENT_STATS_DWM2;
typedef enum _D3DKMT_VIDPNSOURCEOWNER_TYPE
{
D3DKMT_VIDPNSOURCEOWNER_UNOWNED = 0, //Has no owner or GDI is the owner
D3DKMT_VIDPNSOURCEOWNER_SHARED = 1, //Has shared owner, that is owner can yield to any exclusive owner, not available to legacy devices
D3DKMT_VIDPNSOURCEOWNER_EXCLUSIVE = 2, //Has exclusive owner without shared gdi primary,
D3DKMT_VIDPNSOURCEOWNER_EXCLUSIVEGDI = 3, //Has exclusive owner with shared gdi primary and must be exclusive owner of all VidPn sources, only available to legacy devices
D3DKMT_VIDPNSOURCEOWNER_EMULATED = 4, //Does not have real primary ownership, but allows the device to set gamma on its owned sources
} D3DKMT_VIDPNSOURCEOWNER_TYPE;
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WIN8)
typedef struct _D3DKMT_VIDPNSOURCEOWNER_FLAGS
{
union
{
struct
{
UINT AllowOutputDuplication : 1;
UINT DisableDWMVirtualMode : 1;
UINT UseNtHandles : 1;
UINT Reserved : 29;
};
UINT Value;
};
} D3DKMT_VIDPNSOURCEOWNER_FLAGS;
#endif
typedef struct _D3DKMT_SETVIDPNSOURCEOWNER
{
D3DKMT_HANDLE hDevice; // in: Device handle
D3DKMT_PTR(CONST D3DKMT_VIDPNSOURCEOWNER_TYPE*, pType); // in: OwnerType array
D3DKMT_PTR(CONST D3DDDI_VIDEO_PRESENT_SOURCE_ID*, pVidPnSourceId); // in: VidPn source ID array
UINT VidPnSourceCount; // in: Number of valid entries in above array
} D3DKMT_SETVIDPNSOURCEOWNER;
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WIN8)
typedef struct _D3DKMT_SETVIDPNSOURCEOWNER1
{
D3DKMT_SETVIDPNSOURCEOWNER Version0;
D3DKMT_VIDPNSOURCEOWNER_FLAGS Flags;
} D3DKMT_SETVIDPNSOURCEOWNER1;
#endif
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_3)
typedef struct _D3DKMT_SETVIDPNSOURCEOWNER2
{
D3DKMT_SETVIDPNSOURCEOWNER1 Version1;
D3DKMT_PTR(CONST D3DKMT_PTR_TYPE*, pVidPnSourceNtHandles); // in: VidPn source owner DispMgr NT handles
} D3DKMT_SETVIDPNSOURCEOWNER2;
#endif
typedef struct _D3DKMT_CHECKVIDPNEXCLUSIVEOWNERSHIP
{
D3DKMT_HANDLE hAdapter; // in: Adapter handle
D3DDDI_VIDEO_PRESENT_SOURCE_ID VidPnSourceId; // in: VidPn source ID array
} D3DKMT_CHECKVIDPNEXCLUSIVEOWNERSHIP;
#define D3DKMT_GETPRESENTHISTORY_MAXTOKENS 2048
typedef struct _D3DKMT_GETPRESENTHISTORY
{
D3DKMT_HANDLE hAdapter; // in: Handle to adapter
UINT ProvidedSize; // in: Size of provided buffer
UINT WrittenSize; // out: Copied token size or required size for first token
D3DKMT_PTR(_Field_size_bytes_(ProvidedSize) D3DKMT_PRESENTHISTORYTOKEN*, pTokens); // in: Pointer to buffer.
UINT NumTokens; // out: Number of copied token
} D3DKMT_GETPRESENTHISTORY;
typedef struct _D3DKMT_CREATEOVERLAY
{
D3DDDI_VIDEO_PRESENT_SOURCE_ID VidPnSourceId; // in
D3DKMT_HANDLE hDevice; // in: Indentifies the device
D3DDDI_KERNELOVERLAYINFO OverlayInfo; // in
D3DKMT_HANDLE hOverlay; // out: Kernel overlay handle
} D3DKMT_CREATEOVERLAY;
typedef struct _D3DKMT_UPDATEOVERLAY
{
D3DKMT_HANDLE hDevice; // in: Indentifies the device
D3DKMT_HANDLE hOverlay; // in: Kernel overlay handle
D3DDDI_KERNELOVERLAYINFO OverlayInfo; // in
} D3DKMT_UPDATEOVERLAY;
typedef struct _D3DKMT_FLIPOVERLAY
{
D3DKMT_HANDLE hDevice; // in: Indentifies the device
D3DKMT_HANDLE hOverlay; // in: Kernel overlay handle
D3DKMT_HANDLE hSource; // in: Allocation currently displayed
D3DKMT_PTR(VOID*, pPrivateDriverData); // in: Private driver data
UINT PrivateDriverDataSize; // in: Size of private driver data
} D3DKMT_FLIPOVERLAY;
typedef struct _D3DKMT_GETOVERLAYSTATE
{
D3DKMT_HANDLE hDevice; // in: Indentifies the device
D3DKMT_HANDLE hOverlay; // in: Kernel overlay handle
BOOLEAN OverlayEnabled;
} D3DKMT_GETOVERLAYSTATE;
typedef struct _D3DKMT_DESTROYOVERLAY
{
D3DKMT_HANDLE hDevice; // in: Indentifies the device
D3DKMT_HANDLE hOverlay; // in: Kernel overlay handle
} D3DKMT_DESTROYOVERLAY;
typedef struct _D3DKMT_WAITFORVERTICALBLANKEVENT
{
D3DKMT_HANDLE hAdapter; // in: adapter handle
D3DKMT_HANDLE hDevice; // in: device handle [Optional]
D3DDDI_VIDEO_PRESENT_SOURCE_ID VidPnSourceId; // in: adapter's VidPN Source ID
} D3DKMT_WAITFORVERTICALBLANKEVENT;
#define D3DKMT_MAX_WAITFORVERTICALBLANK_OBJECTS 8
typedef struct _D3DKMT_WAITFORVERTICALBLANKEVENT2
{
D3DKMT_HANDLE hAdapter; // in: adapter handle
D3DKMT_HANDLE hDevice; // in: device handle [Optional]
D3DDDI_VIDEO_PRESENT_SOURCE_ID VidPnSourceId; // in: adapter's VidPN Source ID
UINT NumObjects;
D3DKMT_PTR_TYPE ObjectHandleArray[D3DKMT_MAX_WAITFORVERTICALBLANK_OBJECTS]; // in: Specifies the objects to wait on.
} D3DKMT_WAITFORVERTICALBLANKEVENT2;
typedef struct _D3DKMT_GETVERTICALBLANKEVENT
{
D3DKMT_HANDLE hAdapter; // in: adapter handle
D3DKMT_HANDLE hDevice; // in: device handle [Optional]
D3DDDI_VIDEO_PRESENT_SOURCE_ID VidPnSourceId; // in: adapter's VidPN Source ID
D3DKMT_PTR(D3DKMT_PTR_TYPE*, phEvent);
} D3DKMT_GETVERTICALBLANKEVENT;
typedef struct _D3DKMT_SETSYNCREFRESHCOUNTWAITTARGET
{
D3DKMT_HANDLE hAdapter; // in: adapter handle
D3DKMT_HANDLE hDevice; // in: device handle [Optional]
D3DDDI_VIDEO_PRESENT_SOURCE_ID VidPnSourceId; // in: adapter's VidPN Source ID
UINT TargetSyncRefreshCount;
} D3DKMT_SETSYNCREFRESHCOUNTWAITTARGET;
typedef struct _D3DKMT_SETGAMMARAMP
{
D3DKMT_HANDLE hDevice; // in: device handle
D3DDDI_VIDEO_PRESENT_SOURCE_ID VidPnSourceId; // in: adapter's VidPN Source ID
D3DDDI_GAMMARAMP_TYPE Type; // in: Gamma ramp type
union
{
D3DDDI_GAMMA_RAMP_RGB256x3x16* pGammaRampRgb256x3x16;
D3DDDI_GAMMA_RAMP_DXGI_1* pGammaRampDXGI1;
D3DKMT_PTR_HELPER( AlignUnionTo64)
};
UINT Size;
} D3DKMT_SETGAMMARAMP;
typedef struct _D3DKMT_ADJUSTFULLSCREENGAMMA
{
D3DKMT_HANDLE hAdapter; // in: adapter handle
D3DDDI_VIDEO_PRESENT_SOURCE_ID VidPnSourceId; // in: adapter's VidPN Source ID
D3DDDI_DXGI_RGB Scale;
D3DDDI_DXGI_RGB Offset;
} D3DKMT_ADJUSTFULLSCREENGAMMA;
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_3)
typedef struct _D3DKMT_SET_COLORSPACE_TRANSFORM
{
_In_ LUID AdapterLuid;
_In_ D3DDDI_VIDEO_PRESENT_TARGET_ID VidPnTargetId;
_In_ D3DDDI_GAMMARAMP_TYPE Type;
_In_ UINT Size;
union
{
_In_reads_bytes_opt_(Size) D3DKMDT_3x4_COLORSPACE_TRANSFORM* pColorSpaceTransform;
D3DKMT_PTR_HELPER( AlignUnionTo64)
};
} D3DKMT_SET_COLORSPACE_TRANSFORM;
#endif // DXGKDDI_INTERFACE_VERSION_WDDM2_3
typedef struct _D3DKMT_SETVIDPNSOURCEHWPROTECTION
{
D3DKMT_HANDLE hAdapter; // in: adapter handle
D3DDDI_VIDEO_PRESENT_SOURCE_ID VidPnSourceId; // in: adapter's VidPN Source ID
BOOL HwProtected; // in: HW protection status
} D3DKMT_SETVIDPNSOURCEHWPROTECTION;
typedef struct _D3DKMT_SETHWPROTECTIONTEARDOWNRECOVERY
{
D3DKMT_HANDLE hAdapter; // in: adapter handle
BOOL Recovered; // in: HW protection teardown recovery
} D3DKMT_SETHWPROTECTIONTEARDOWNRECOVERY;
typedef enum _D3DKMT_DEVICEEXECUTION_STATE
{
D3DKMT_DEVICEEXECUTION_ACTIVE = 1,
D3DKMT_DEVICEEXECUTION_RESET = 2,
D3DKMT_DEVICEEXECUTION_HUNG = 3,
D3DKMT_DEVICEEXECUTION_STOPPED = 4,
D3DKMT_DEVICEEXECUTION_ERROR_OUTOFMEMORY = 5,
D3DKMT_DEVICEEXECUTION_ERROR_DMAFAULT = 6,
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_0)
D3DKMT_DEVICEEXECUTION_ERROR_DMAPAGEFAULT = 7,
#endif // (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_0)
} D3DKMT_DEVICEEXECUTION_STATE;
typedef struct _D3DKMT_DEVICERESET_STATE
{
union
{
struct
{
UINT DesktopSwitched : 1; // 0x00000001
UINT Reserved :31; // 0xFFFFFFFE
};
UINT Value;
};
} D3DKMT_DEVICERESET_STATE;
typedef struct _D3DKMT_PRESENT_STATS
{
UINT PresentCount;
UINT PresentRefreshCount;
UINT SyncRefreshCount;
D3DKMT_ALIGN64 LARGE_INTEGER SyncQPCTime;
D3DKMT_ALIGN64 LARGE_INTEGER SyncGPUTime;
} D3DKMT_PRESENT_STATS;
typedef struct _D3DKMT_DEVICEPRESENT_STATE
{
D3DDDI_VIDEO_PRESENT_SOURCE_ID VidPnSourceId; // in: present source id
D3DKMT_PRESENT_STATS PresentStats; // out: present stats
} D3DKMT_DEVICEPRESENT_STATE;
typedef struct _D3DKMT_PRESENT_STATS_DWM
{
UINT PresentCount;
UINT PresentRefreshCount;
D3DKMT_ALIGN64 LARGE_INTEGER PresentQPCTime;
UINT SyncRefreshCount;
D3DKMT_ALIGN64 LARGE_INTEGER SyncQPCTime;
UINT CustomPresentDuration;
} D3DKMT_PRESENT_STATS_DWM;
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_0)
typedef struct _D3DKMT_DEVICEPAGEFAULT_STATE
{
D3DKMT_ALIGN64 UINT64 FaultedPrimitiveAPISequenceNumber; // when per draw fence write is enabled, identifies the draw that caused the page fault, or DXGK_PRIMITIVE_API_SEQUENCE_NUMBER_UNKNOWN if such information is not available.
DXGK_RENDER_PIPELINE_STAGE FaultedPipelineStage; // render pipeline stage during which the fault was generated, or DXGK_RENDER_PIPELINE_STAGE_UNKNOWN if such information is not available.
UINT FaultedBindTableEntry; // a bind table index of a resource being accessed at the time of the fault, or DXGK_BIND_TABLE_ENTRY_UNKNOWN if such information is not available.
DXGK_PAGE_FAULT_FLAGS PageFaultFlags; // flags specifying the nature of the fault
DXGK_FAULT_ERROR_CODE FaultErrorCode; // Structure that contains error code describing the fault.
D3DKMT_ALIGN64 D3DGPU_VIRTUAL_ADDRESS FaultedVirtualAddress; // virtual address of faulting resource, or D3DGPU_NULL if such information is not available.
} D3DKMT_DEVICEPAGEFAULT_STATE;
#endif // (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_0)
typedef struct _D3DKMT_DEVICEPRESENT_STATE_DWM
{
D3DDDI_VIDEO_PRESENT_SOURCE_ID VidPnSourceId; // in: present source id
D3DKMT_PRESENT_STATS_DWM PresentStatsDWM; // out: present stats rev 2
} D3DKMT_DEVICEPRESENT_STATE_DWM;
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_1)
typedef struct _D3DKMT_DEVICEPRESENT_QUEUE_STATE
{
D3DDDI_VIDEO_PRESENT_SOURCE_ID VidPnSourceId; // in: present source id
BOOLEAN bQueuedPresentLimitReached; // out: whether the queued present limit has been reached
} D3DKMT_DEVICEPRESENT_QUEUE_STATE;
#endif // (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_1)
typedef enum _D3DKMT_DEVICESTATE_TYPE
{
D3DKMT_DEVICESTATE_EXECUTION = 1,
D3DKMT_DEVICESTATE_PRESENT = 2,
D3DKMT_DEVICESTATE_RESET = 3,
D3DKMT_DEVICESTATE_PRESENT_DWM = 4,
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_0)
D3DKMT_DEVICESTATE_PAGE_FAULT = 5,
#endif // (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_0)
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_1)
D3DKMT_DEVICESTATE_PRESENT_QUEUE = 6,
#endif // DXGKDDI_INTERFACE_VERSION_WDDM2_1
} D3DKMT_DEVICESTATE_TYPE;
typedef struct _D3DKMT_GETDEVICESTATE
{
D3DKMT_HANDLE hDevice; // in: device handle
D3DKMT_DEVICESTATE_TYPE StateType; // in: device state type
union
{
D3DKMT_DEVICEEXECUTION_STATE ExecutionState; // out: device state
D3DKMT_DEVICEPRESENT_STATE PresentState; // in/out: present state
D3DKMT_DEVICERESET_STATE ResetState; // out: reset state
D3DKMT_DEVICEPRESENT_STATE_DWM PresentStateDWM; // in/out: present state
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_0)
D3DKMT_DEVICEPAGEFAULT_STATE PageFaultState; // out: page fault state
#endif // (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_0)
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_1)
D3DKMT_DEVICEPRESENT_QUEUE_STATE PresentQueueState; // in/out: present queue state
#endif // DXGKDDI_INTERFACE_VERSION_WDDM2_1
};
} D3DKMT_GETDEVICESTATE;
typedef struct _D3DKMT_CREATEDCFROMMEMORY
{
D3DKMT_PTR(VOID*, pMemory); // in: memory for DC
D3DDDIFORMAT Format; // in: Memory pixel format
UINT Width; // in: Memory Width
UINT Height; // in: Memory Height
UINT Pitch; // in: Memory pitch
D3DKMT_PTR(HDC, hDeviceDc); // in: DC describing the device
D3DKMT_PTR(PALETTEENTRY*, pColorTable); // in: Palette
D3DKMT_PTR(HDC, hDc); // out: HDC
D3DKMT_PTR(HANDLE, hBitmap); // out: Handle to bitmap
} D3DKMT_CREATEDCFROMMEMORY;
typedef struct _D3DKMT_DESTROYDCFROMMEMORY
{
D3DKMT_PTR(HDC, hDc); // in:
D3DKMT_PTR(HANDLE, hBitmap); // in:
} D3DKMT_DESTROYDCFROMMEMORY;
#define D3DKMT_SETCONTEXTSCHEDULINGPRIORITY_ABSOLUTE 0x40000000
typedef struct _D3DKMT_SETCONTEXTSCHEDULINGPRIORITY
{
D3DKMT_HANDLE hContext; // in: context handle
INT Priority; // in: context priority
} D3DKMT_SETCONTEXTSCHEDULINGPRIORITY;
typedef struct _D3DKMT_SETCONTEXTINPROCESSSCHEDULINGPRIORITY
{
D3DKMT_HANDLE hContext; // in: context handle
INT Priority; // in: context priority
} D3DKMT_SETCONTEXTINPROCESSSCHEDULINGPRIORITY;
typedef struct _D3DKMT_CHANGESURFACEPOINTER
{
D3DKMT_PTR(HDC, hDC); // in: dc handle
D3DKMT_PTR(HANDLE, hBitmap); // in: bitmap handle
D3DKMT_PTR(LPVOID, pSurfacePointer);// in: new surface pointer
UINT Width; // in: Memory Width
UINT Height; // in: Memory Height
UINT Pitch; // in: Memory pitch
} D3DKMT_CHANGESURFACEPOINTER;
typedef struct _D3DKMT_GETCONTEXTSCHEDULINGPRIORITY
{
D3DKMT_HANDLE hContext; // in: context handle
INT Priority; // out: context priority
} D3DKMT_GETCONTEXTSCHEDULINGPRIORITY;
typedef struct _D3DKMT_GETCONTEXTINPROCESSSCHEDULINGPRIORITY
{
D3DKMT_HANDLE hContext; // in: context handle
INT Priority; // out: context priority
} D3DKMT_GETCONTEXTINPROCESSSCHEDULINGPRIORITY;
typedef enum _D3DKMT_SCHEDULINGPRIORITYCLASS
{
D3DKMT_SCHEDULINGPRIORITYCLASS_IDLE = 0,
D3DKMT_SCHEDULINGPRIORITYCLASS_BELOW_NORMAL = 1,
D3DKMT_SCHEDULINGPRIORITYCLASS_NORMAL = 2,
D3DKMT_SCHEDULINGPRIORITYCLASS_ABOVE_NORMAL = 3,
D3DKMT_SCHEDULINGPRIORITYCLASS_HIGH = 4,
D3DKMT_SCHEDULINGPRIORITYCLASS_REALTIME = 5,
} D3DKMT_SCHEDULINGPRIORITYCLASS;
typedef struct _D3DKMT_GETSCANLINE
{
D3DKMT_HANDLE hAdapter; // in: Adapter handle
D3DDDI_VIDEO_PRESENT_SOURCE_ID VidPnSourceId; // in: Adapter's VidPN Source ID
BOOLEAN InVerticalBlank; // out: Within vertical blank
UINT ScanLine; // out: Current scan line
} D3DKMT_GETSCANLINE;
typedef enum _D3DKMT_QUEUEDLIMIT_TYPE
{
D3DKMT_SET_QUEUEDLIMIT_PRESENT = 1,
D3DKMT_GET_QUEUEDLIMIT_PRESENT = 2,
} D3DKMT_QUEUEDLIMIT_TYPE;
typedef struct _D3DKMT_SETQUEUEDLIMIT
{
D3DKMT_HANDLE hDevice; // in: device handle
D3DKMT_QUEUEDLIMIT_TYPE Type; // in: limit type
union
{
UINT QueuedPresentLimit; // in (or out): queued present limit
struct
{
D3DDDI_VIDEO_PRESENT_SOURCE_ID VidPnSourceId; // in: adapter's VidPN source ID
UINT QueuedPendingFlipLimit; // in (or out): flip pending limit
};
};
} D3DKMT_SETQUEUEDLIMIT;
typedef struct _D3DKMT_POLLDISPLAYCHILDREN
{
D3DKMT_HANDLE hAdapter; // in: Adapter handle
UINT NonDestructiveOnly : 1; // in: 0x00000001 Destructive or not
UINT SynchronousPolling : 1; // in: 0x00000002 Synchronous polling or not
UINT DisableModeReset : 1; // in: 0x00000004 Disable DMM mode reset on monitor event
UINT PollAllAdapters : 1; // in: 0x00000008 Poll all adapters
UINT PollInterruptible : 1; // in: 0x00000010 Poll interruptible targets as well.
UINT Reserved : 27; // in: 0xffffffc0
} D3DKMT_POLLDISPLAYCHILDREN;
typedef struct _D3DKMT_INVALIDATEACTIVEVIDPN
{
D3DKMT_HANDLE hAdapter; // in: Adapter handle
D3DKMT_PTR(VOID*, pPrivateDriverData); // in: Private driver data
UINT PrivateDriverDataSize; // in: Size of private driver data
} D3DKMT_INVALIDATEACTIVEVIDPN;
typedef struct _D3DKMT_CHECKOCCLUSION
{
D3DKMT_PTR(HWND, hWindow); // in: Destination window handle
} D3DKMT_CHECKOCCLUSION;
typedef struct _D3DKMT_WAITFORIDLE
{
D3DKMT_HANDLE hDevice; // in: Device to wait for idle
} D3DKMT_WAITFORIDLE;
typedef struct _D3DKMT_CHECKMONITORPOWERSTATE
{
D3DKMT_HANDLE hAdapter; // in: Adapter to check on
D3DDDI_VIDEO_PRESENT_SOURCE_ID VidPnSourceId; // in: Adapter's VidPN Source ID
} D3DKMT_CHECKMONITORPOWERSTATE;
typedef struct _D3DKMT_SETDISPLAYPRIVATEDRIVERFORMAT
{
D3DKMT_HANDLE hDevice; // in: Identifies the device
D3DDDI_VIDEO_PRESENT_SOURCE_ID VidPnSourceId; // in: Identifies which VidPn we are changing the private driver format attribute for
UINT PrivateDriverFormatAttribute; // In: Requested private format attribute for VidPn specified
} D3DKMT_SETDISPLAYPRIVATEDRIVERFORMAT;
typedef struct _D3DKMT_CREATEKEYEDMUTEX
{
D3DKMT_ALIGN64 UINT64 InitialValue; // in: Initial value to release to
D3DKMT_HANDLE hSharedHandle; // out: Global handle to keyed mutex
D3DKMT_HANDLE hKeyedMutex; // out: Handle to the keyed mutex in this process
} D3DKMT_CREATEKEYEDMUTEX;
typedef struct _D3DKMT_OPENKEYEDMUTEX
{
D3DKMT_HANDLE hSharedHandle; // in: Global handle to keyed mutex
D3DKMT_HANDLE hKeyedMutex; // out: Handle to the keyed mutex in this process
} D3DKMT_OPENKEYEDMUTEX;
typedef struct _D3DKMT_DESTROYKEYEDMUTEX
{
D3DKMT_HANDLE hKeyedMutex; // in: Identifies the keyed mutex being destroyed.
} D3DKMT_DESTROYKEYEDMUTEX;
typedef struct _D3DKMT_ACQUIREKEYEDMUTEX
{
D3DKMT_HANDLE hKeyedMutex; // in: Handle to the keyed mutex
D3DKMT_ALIGN64 UINT64 Key; // in: Key value to Acquire
D3DKMT_PTR(PLARGE_INTEGER, pTimeout); // in: NT-style timeout value
D3DKMT_ALIGN64 UINT64 FenceValue; // out: Current fence value of the GPU sync object
} D3DKMT_ACQUIREKEYEDMUTEX;
typedef struct _D3DKMT_RELEASEKEYEDMUTEX
{
D3DKMT_HANDLE hKeyedMutex; // in: Handle to the keyed mutex
D3DKMT_ALIGN64 UINT64 Key; // in: Key value to Release to
D3DKMT_ALIGN64 UINT64 FenceValue; // in: New fence value to use for GPU sync object
} D3DKMT_RELEASEKEYEDMUTEX;
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WIN8)
typedef struct _D3DKMT_CREATEKEYEDMUTEX2_FLAGS
{
union
{
struct
{
UINT NtSecuritySharing : 1; // If set, the keyed mutex will be shared using DxgkShareObjects instead of D3DKMT_CREATEKEYEDMUTEX2::hSharedHandle
UINT Reserved : 31;
};
UINT Value;
};
} D3DKMT_CREATEKEYEDMUTEX2_FLAGS;
typedef struct _D3DKMT_CREATEKEYEDMUTEX2
{
D3DKMT_ALIGN64 UINT64 InitialValue; // in: Initial value to release to
D3DKMT_HANDLE hSharedHandle; // out: Global handle to keyed mutex, NULL if NtSecuritySharing is set.
D3DKMT_HANDLE hKeyedMutex; // out: Handle to the keyed mutex in this process
D3DKMT_PTR(_In_reads_bytes_opt_(PrivateRuntimeDataSize)
VOID*, pPrivateRuntimeData); // in: Buffer containing initial private data.
// If NULL then PrivateRuntimeDataSize must be 0.
UINT PrivateRuntimeDataSize; // in: Size in bytes of pPrivateRuntimeData.
D3DKMT_CREATEKEYEDMUTEX2_FLAGS Flags; // in: Creation flags.
} D3DKMT_CREATEKEYEDMUTEX2;
typedef struct _D3DKMT_OPENKEYEDMUTEX2
{
D3DKMT_HANDLE hSharedHandle; // in: Global handle to keyed mutex
D3DKMT_HANDLE hKeyedMutex; // out: Handle to the keyed mutex in this process
D3DKMT_PTR(_In_reads_bytes_opt_(PrivateRuntimeDataSize)
VOID*, pPrivateRuntimeData); // in: Buffer containing initial private data.
// If NULL then PrivateRuntimeDataSize must be 0.
// It will only be copied if the keyed mutex does not already have private data.
UINT PrivateRuntimeDataSize; // in: Size in bytes of pPrivateRuntimeData.
} D3DKMT_OPENKEYEDMUTEX2;
typedef struct _D3DKMT_OPENKEYEDMUTEXFROMNTHANDLE
{
D3DKMT_PTR(HANDLE, hNtHandle); // in: NT handle to keyed mutex
D3DKMT_HANDLE hKeyedMutex; // out: Handle to the keyed mutex in this process
D3DKMT_PTR(_In_reads_bytes_opt_(PrivateRuntimeDataSize)
VOID*, pPrivateRuntimeData); // in: Buffer containing initial private data.
// If NULL then PrivateRuntimeDataSize must be 0.
// It will only be copied if the keyed mutex does not already have private data.
UINT PrivateRuntimeDataSize; // in: Size in bytes of pPrivateRuntimeData.
} D3DKMT_OPENKEYEDMUTEXFROMNTHANDLE;
typedef struct _D3DKMT_ACQUIREKEYEDMUTEX2
{
D3DKMT_HANDLE hKeyedMutex; // in: Handle to the keyed mutex
D3DKMT_ALIGN64 UINT64 Key; // in: Key value to Acquire
D3DKMT_PTR(PLARGE_INTEGER, pTimeout); // in: NT-style timeout value
D3DKMT_ALIGN64 UINT64 FenceValue; // out: Current fence value of the GPU sync object
D3DKMT_PTR(_Out_writes_bytes_all_opt_(PrivateRuntimeDataSize)
VOID*, pPrivateRuntimeData); // out: Buffer to copy private data to.
// If NULL then PrivateRuntimeDataSize must be 0.
UINT PrivateRuntimeDataSize; // in: Size in bytes of pPrivateRuntimeData.
} D3DKMT_ACQUIREKEYEDMUTEX2;
typedef struct _D3DKMT_RELEASEKEYEDMUTEX2
{
D3DKMT_HANDLE hKeyedMutex; // in: Handle to the keyed mutex
D3DKMT_ALIGN64 UINT64 Key; // in: Key value to Release to
D3DKMT_ALIGN64 UINT64 FenceValue; // in: New fence value to use for GPU sync object
D3DKMT_PTR(_In_reads_bytes_opt_(PrivateRuntimeDataSize)
VOID*, pPrivateRuntimeData); // in: Buffer containing new private data.
// If NULL then PrivateRuntimeDataSize must be 0.
UINT PrivateRuntimeDataSize; // in: Size in bytes of pPrivateRuntimeData.
} D3DKMT_RELEASEKEYEDMUTEX2;
#endif
typedef struct _D3DKMT_CONFIGURESHAREDRESOURCE
{
D3DKMT_HANDLE hDevice; // in: Device that created the resource
D3DKMT_HANDLE hResource; // in: Handle for shared resource
BOOLEAN IsDwm; // in: TRUE when the process is DWM
D3DKMT_PTR(HANDLE, hProcess); // in: Process handle for the non-DWM case
BOOLEAN AllowAccess; // in: Indicates whereh the process is allowed access
} D3DKMT_CONFIGURESHAREDRESOURCE;
typedef struct _D3DKMT_CHECKSHAREDRESOURCEACCESS
{
D3DKMT_HANDLE hResource; // in: Handle for the resource
UINT ClientPid; // in: Client process PID
} D3DKMT_CHECKSHAREDRESOURCEACCESS;
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WIN8)
typedef enum _D3DKMT_OFFER_PRIORITY
{
D3DKMT_OFFER_PRIORITY_LOW=1, // Content is not useful
D3DKMT_OFFER_PRIORITY_NORMAL, // Content is useful but easy to regenerate
D3DKMT_OFFER_PRIORITY_HIGH, // Content is useful and difficult to regenerate
D3DKMT_OFFER_PRIORITY_AUTO, // Let VidMm decide offer priority based on eviction priority
} D3DKMT_OFFER_PRIORITY;
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_0)
typedef struct _D3DKMT_OFFER_FLAGS
{
union
{
struct
{
UINT OfferImmediately : 1; // 0x00000001
UINT AllowDecommit : 1; // 0x00000002
UINT Reserved : 30; // 0xFFFFFFFC
};
UINT Value;
};
} D3DKMT_OFFER_FLAGS;
#endif // DXGKDDI_INTERFACE_VERSION
typedef struct _D3DKMT_OFFERALLOCATIONS
{
D3DKMT_HANDLE hDevice; // in: Device that created the allocations
D3DKMT_PTR(D3DKMT_HANDLE*, pResources); // in: array of D3D runtime resource handles.
D3DKMT_PTR(CONST D3DKMT_HANDLE*, HandleList); // in: array of allocation handles. If non-NULL, pResources must be NULL.
UINT NumAllocations; // in: number of items in whichever of pResources or HandleList is non-NULL.
D3DKMT_OFFER_PRIORITY Priority; // in: priority with which to offer the allocations
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_0)
D3DKMT_OFFER_FLAGS Flags; // in: various flags for determining offer behavior
#endif // DXGKDDI_INTERFACE_VERSION
} D3DKMT_OFFERALLOCATIONS;
typedef struct _D3DKMT_RECLAIMALLOCATIONS
{
D3DKMT_HANDLE hDevice; // in: Device that created the allocations
D3DKMT_PTR(D3DKMT_HANDLE*, pResources); // in: array of D3D runtime resource handles.
D3DKMT_PTR(CONST D3DKMT_HANDLE*, HandleList); // in: array of allocation handles. If non-NULL, pResources must be NULL.
D3DKMT_PTR(BOOL*, pDiscarded); // out: optional array of booleans specifying whether each resource or allocation was discarded.
UINT NumAllocations; // in: number of items in pDiscarded and whichever of pResources or HandleList is non-NULL.
} D3DKMT_RECLAIMALLOCATIONS;
typedef struct _D3DKMT_RECLAIMALLOCATIONS2
{
D3DKMT_HANDLE hPagingQueue; // in: Device that created the allocations
UINT NumAllocations; // in: number of items in pDiscarded and whichever of pResources or HandleList is non-NULL.
D3DKMT_PTR(D3DKMT_HANDLE*, pResources); // in: array of D3D runtime resource handles.
D3DKMT_PTR(CONST D3DKMT_HANDLE*, HandleList); // in: array of allocation handles. If non-NULL, pResources must be NULL.
#if(DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_1 || \
D3D_UMD_INTERFACE_VERSION >= D3D_UMD_INTERFACE_VERSION_WDDM2_1)
union
{
BOOL* pDiscarded; // out: optional array of booleans specifying whether each resource or allocation was discarded.
D3DDDI_RECLAIM_RESULT* pResults; // out: array of results specifying whether each resource or allocation is OK, discarded, or has no commitment.
D3DKMT_PTR_HELPER(AlignUnionTo64)
};
#else
D3DKMT_PTR(BOOL*, pDiscarded); // out: optional array of booleans specifying whether each resource or allocation was discarded.
#endif // (DXGKDDI_INTERFACE_VERSION || D3D_UMD_INTERFACE_VERSION)
D3DKMT_ALIGN64 UINT64 PagingFenceValue; // out: The paging fence to synchronize against before submitting work to the GPU which
// references any of the resources or allocations in the provided arrays
} D3DKMT_RECLAIMALLOCATIONS2;
typedef struct _D3DKMT_OUTPUTDUPLCREATIONFLAGS
{
union
{
struct
{
UINT CompositionUiCaptureOnly : 1;
UINT Reserved : 31;
};
UINT Value;
};
} D3DKMT_OUTPUTDUPLCREATIONFLAGS;
typedef struct _D3DKMT_OUTPUTDUPL_KEYEDMUTEX
{
D3DKMT_PTR(HANDLE, hSharedSurfaceNt);
}D3DKMT_OUTPUTDUPL_KEYEDMUTEX;
#define OUTPUTDUPL_CREATE_MAX_KEYEDMUTXES 3
typedef struct _D3DKMT_CREATE_OUTPUTDUPL
{
D3DKMT_HANDLE hAdapter;
D3DDDI_VIDEO_PRESENT_SOURCE_ID VidPnSourceId;
UINT KeyedMutexCount; // in : If zero then means is this the pre-create check
UINT RequiredKeyedMutexCount; // out: The number of keyed mutexs needed
D3DKMT_OUTPUTDUPL_KEYEDMUTEX KeyedMutexs[OUTPUTDUPL_CREATE_MAX_KEYEDMUTXES];
D3DKMT_OUTPUTDUPLCREATIONFLAGS Flags;
} D3DKMT_CREATE_OUTPUTDUPL;
typedef struct _D3DKMT_DESTROY_OUTPUTDUPL
{
D3DKMT_HANDLE hAdapter;
D3DDDI_VIDEO_PRESENT_SOURCE_ID VidPnSourceId;
BOOL bDestroyAllContexts;
} D3DKMT_DESTROY_OUTPUTDUPL;
typedef struct _D3DKMT_OUTPUTDUPL_POINTER_POSITION
{
POINT Position;
BOOL Visible;
} D3DKMT_OUTPUTDUPL_POINTER_POSITION;
typedef struct _D3DKMT_OUTPUTDUPL_FRAMEINFO
{
D3DKMT_ALIGN64 LARGE_INTEGER LastPresentTime;
D3DKMT_ALIGN64 LARGE_INTEGER LastMouseUpdateTime;
UINT AccumulatedFrames;
BOOL RectsCoalesced;
BOOL ProtectedContentMaskedOut;
D3DKMT_OUTPUTDUPL_POINTER_POSITION PointerPosition;
UINT TotalMetadataBufferSize;
UINT PointerShapeBufferSize;
} D3DKMT_OUTPUTDUPL_FRAMEINFO;
typedef struct _D3DKMT_OUTPUTDUPL_GET_FRAMEINFO
{
D3DKMT_HANDLE hAdapter;
D3DDDI_VIDEO_PRESENT_SOURCE_ID VidPnSourceId;
D3DKMT_OUTPUTDUPL_FRAMEINFO FrameInfo;
} D3DKMT_OUTPUTDUPL_GET_FRAMEINFO;
typedef enum _D3DKMT_OUTPUTDUPL_METADATATYPE
{
D3DKMT_OUTPUTDUPL_METADATATYPE_DIRTY_RECTS = 0,
D3DKMT_OUTPUTDUPL_METADATATYPE_MOVE_RECTS = 1
} D3DKMT_OUTPUTDUPL_METADATATYPE;
typedef struct _D3DKMT_OUTPUTDUPL_METADATA
{
D3DKMT_HANDLE hAdapter;
D3DDDI_VIDEO_PRESENT_SOURCE_ID VidPnSourceId;
D3DKMT_OUTPUTDUPL_METADATATYPE Type;
UINT BufferSizeSupplied;
D3DKMT_PTR(_Field_size_bytes_part_(BufferSizeSupplied, BufferSizeRequired) PVOID, pBuffer);
UINT BufferSizeRequired;
} D3DKMT_OUTPUTDUPL_METADATA;
typedef enum _D3DKMT_OUTDUPL_POINTER_SHAPE_TYPE
{
D3DKMT_OUTDUPL_POINTER_SHAPE_TYPE_MONOCHROME = 0x00000001,
D3DKMT_OUTDUPL_POINTER_SHAPE_TYPE_COLOR = 0x00000002,
D3DKMT_OUTDUPL_POINTER_SHAPE_TYPE_MASKED_COLOR = 0x00000004
} D3DKMT_OUTDUPL_POINTER_SHAPE_TYPE;
typedef struct _D3DKMT_OUTDUPL_POINTER_SHAPE_INFO
{
D3DKMT_OUTDUPL_POINTER_SHAPE_TYPE Type;
UINT Width;
UINT Height;
UINT Pitch;
POINT HotSpot;
} D3DKMT_OUTDUPL_POINTER_SHAPE_INFO;
typedef struct _D3DKMT_OUTPUTDUPL_GET_POINTER_SHAPE_DATA
{
D3DKMT_HANDLE hAdapter;
D3DDDI_VIDEO_PRESENT_SOURCE_ID VidPnSourceId;
UINT BufferSizeSupplied;
D3DKMT_PTR(_Field_size_bytes_part_(BufferSizeSupplied, BufferSizeRequired) PVOID, pShapeBuffer);
UINT BufferSizeRequired;
D3DKMT_OUTDUPL_POINTER_SHAPE_INFO ShapeInfo;
} D3DKMT_OUTPUTDUPL_GET_POINTER_SHAPE_DATA;
typedef struct _D3DKMT_OUTPUTDUPL_RELEASE_FRAME
{
D3DKMT_HANDLE hAdapter;
D3DDDI_VIDEO_PRESENT_SOURCE_ID VidPnSourceId;
UINT NextKeyMutexIdx; // out : index of the next keyed mutex to use
} D3DKMT_OUTPUTDUPL_RELEASE_FRAME;
#define D3DKMT_MAX_OBJECTS_PER_HANDLE 3
#define D3DKMT_MAX_BUNDLE_OBJECTS_PER_HANDLE 16
#define D3DKMT_GDI_STYLE_HANDLE_DECORATION 0x2
typedef struct _D3DKMT_GETSHAREDRESOURCEADAPTERLUID
{
D3DKMT_HANDLE hGlobalShare; // in : Shared resource handle
D3DKMT_PTR(HANDLE, hNtHandle); // in : Process's NT handle
LUID AdapterLuid; // out: adapter LUID
} D3DKMT_GETSHAREDRESOURCEADAPTERLUID;
typedef enum _D3DKMT_GPU_PREFERENCE_QUERY_STATE
{
D3DKMT_GPU_PREFERENCE_STATE_UNINITIALIZED,
D3DKMT_GPU_PREFERENCE_STATE_HIGH_PERFORMANCE,
D3DKMT_GPU_PREFERENCE_STATE_MINIMUM_POWER,
D3DKMT_GPU_PREFERENCE_STATE_UNSPECIFIED,
D3DKMT_GPU_PREFERENCE_STATE_NOT_FOUND,
D3DKMT_GPU_PREFERENCE_STATE_USER_SPECIFIED_GPU
} D3DKMT_GPU_PREFERENCE_QUERY_STATE;
typedef enum _D3DKMT_GPU_PREFERENCE_QUERY_TYPE
{
D3DKMT_GPU_PREFERENCE_TYPE_IHV_DLIST,
D3DKMT_GPU_PREFERENCE_TYPE_DX_DATABASE,
D3DKMT_GPU_PREFERENCE_TYPE_USER_PREFERENCE
} D3DKMT_GPU_PREFERENCE_QUERY_TYPE;
typedef struct _D3DKMT_HYBRID_LIST
{
D3DKMT_GPU_PREFERENCE_QUERY_STATE State; // Gpu preference query state
LUID AdapterLuid; // in,opt: Adapter luid to per-adapter DList state. Optional if QueryType == D3DKMT_GPU_PREFERENCE_TYPE_IHV_DLIST
BOOL bUserPreferenceQuery; // Whether referring to user gpu preference, or per-adapter DList query
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_6)
D3DKMT_GPU_PREFERENCE_QUERY_TYPE QueryType; // Replaced bUserPreferenceQuery, for referring to which D3DKMT_GPU_PREFERENCE_QUERY_TYPE
#endif
} D3DKMT_HYBRID_LIST;
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM1_3)
typedef struct
{
DXGK_MIRACAST_CHUNK_INFO ChunkInfo;
UINT PrivateDriverDataSize; // Size of private data
BYTE PrivateDriverData[1]; // Private data buffer
} D3DKMT_MIRACAST_CHUNK_DATA;
typedef enum
{
MiracastStopped = 0,
MiracastStartPending = 1,
MiracastStarted = 2,
MiracastStopPending = 3,
} D3DKMT_MIRACAST_DISPLAY_DEVICE_STATE;
typedef enum
{
D3DKMT_MIRACAST_DEVICE_STATUS_SUCCESS = 0,
D3DKMT_MIRACAST_DEVICE_STATUS_SUCCESS_NO_MONITOR = 1,
D3DKMT_MIRACAST_DEVICE_STATUS_PENDING = 2,
D3DKMT_MIRACAST_DEVICE_STATUS_UNKOWN_ERROR = 0x80000001,
D3DKMT_MIRACAST_DEVICE_STATUS_GPU_RESOURCE_IN_USE = 0x80000002,
D3DKMT_MIRACAST_DEVICE_STATUS_DEVICE_ERROR = 0x80000003,
D3DKMT_MIRACAST_DEVICE_STATUS_UNKOWN_PAIRING = 0x80000004,
D3DKMT_MIRACAST_DEVICE_STATUS_REMOTE_SESSION = 0x80000005,
D3DKMT_MIRACAST_DEVICE_STATUS_DEVICE_NOT_FOUND = 0x80000006,
D3DKMT_MIRACAST_DEVICE_STATUS_DEVICE_NOT_STARTED = 0x80000007,
D3DKMT_MIRACAST_DEVICE_STATUS_INVALID_PARAMETER = 0x80000008,
D3DKMT_MIRACAST_DEVICE_STATUS_INSUFFICIENT_BANDWIDTH = 0x80000009,
D3DKMT_MIRACAST_DEVICE_STATUS_INSUFFICIENT_MEMORY = 0x8000000A,
D3DKMT_MIRACAST_DEVICE_STATUS_CANCELLED = 0x8000000B,
} D3DKMT_MIRACAST_DEVICE_STATUS;
typedef struct _D3DKMT_MIRACAST_DISPLAY_DEVICE_STATUS
{
//
// Miracast display device state.
//
D3DKMT_MIRACAST_DISPLAY_DEVICE_STATE State;
} D3DKMT_MIRACAST_DISPLAY_DEVICE_STATUS, *PD3DKMT_MIRACAST_DISPLAY_DEVICE_STATUS;
typedef struct _D3DKMT_MIRACAST_DISPLAY_DEVICE_CAPS
{
BOOLEAN HdcpSupported;
ULONG DefaultControlPort;
BOOLEAN UsesIhvSolution;
} D3DKMT_MIRACAST_DISPLAY_DEVICE_CAPS, *PD3DKMT_MIRACAST_DISPLAY_DEVICE_CAPS;
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_0)
typedef struct _D3DKMT_MIRACAST_DISPLAY_STOP_SESSIONS
{
LUID AdapterLuid;
D3DDDI_VIDEO_PRESENT_TARGET_ID TargetId;
UINT StopReason;
} D3DKMT_MIRACAST_DISPLAY_STOP_SESSIONS, *PD3DKMT_MIRACAST_DISPLAY_STOP_SESSIONS;
#endif // (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_0)
#endif // (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM1_3)
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_0)
typedef struct _D3DKMT_WAITFORSYNCHRONIZATIONOBJECTFROMCPU
{
D3DKMT_HANDLE hDevice; // in: Handle to the device.
UINT ObjectCount; // in: Number of objects to wait on.
D3DKMT_PTR(_Field_size_(ObjectCount)
const D3DKMT_HANDLE*, ObjectHandleArray); // in: Handle to monitored fence synchronization objects to wait on.
D3DKMT_PTR(_Field_size_(ObjectCount)
const UINT64*, FenceValueArray); // in: Fence values to be waited on.
D3DKMT_PTR(HANDLE, hAsyncEvent); // in: Event to be signaled when the wait condition is satisfied.
// When set to NULL, the call will not return until the wait condition is satisfied.
D3DDDI_WAITFORSYNCHRONIZATIONOBJECTFROMCPU_FLAGS Flags; // in: Flags that specify the wait mode.
} D3DKMT_WAITFORSYNCHRONIZATIONOBJECTFROMCPU;
typedef struct _D3DKMT_SIGNALSYNCHRONIZATIONOBJECTFROMCPU
{
D3DKMT_HANDLE hDevice; // in: Handle to the device.
UINT ObjectCount; // in: Number of objects to signal.
D3DKMT_PTR(_Field_size_(ObjectCount)
const D3DKMT_HANDLE*, ObjectHandleArray); // in: Handle to monitored fence synchronization objects to signal.
D3DKMT_PTR(_Field_size_(ObjectCount)
const UINT64*, FenceValueArray); // in: Fence values to be signaled.
D3DDDICB_SIGNALFLAGS Flags; // in: Specifies signal behavior.
} D3DKMT_SIGNALSYNCHRONIZATIONOBJECTFROMCPU;
typedef struct _D3DKMT_WAITFORSYNCHRONIZATIONOBJECTFROMGPU
{
D3DKMT_HANDLE hContext; // in: Specify the context that should be waiting.
UINT ObjectCount; // in: Number of object to wait on.
D3DKMT_PTR(_Field_size_(ObjectCount)
const D3DKMT_HANDLE*, ObjectHandleArray); // in: Handles to synchronization objects to wait on.
union
{
_Field_size_(ObjectCount)
const UINT64* MonitoredFenceValueArray; // in: monitored fence values to be waited.
D3DKMT_ALIGN64 UINT64 FenceValue; // in: fence value to be waited.
D3DKMT_ALIGN64 UINT64 Reserved[8];
};
} D3DKMT_WAITFORSYNCHRONIZATIONOBJECTFROMGPU;
typedef struct _D3DKMT_SIGNALSYNCHRONIZATIONOBJECTFROMGPU
{
D3DKMT_HANDLE hContext; // in: Identifies the context that the signal is being submitted to.
UINT ObjectCount; // in: Specifies the number of objects to signal.
D3DKMT_PTR(_Field_size_(ObjectCount)
const D3DKMT_HANDLE*, ObjectHandleArray); // in: Specifies the objects to signal.
union
{
_Field_size_(ObjectCount)
const UINT64* MonitoredFenceValueArray; // in: monitored fence values to be signaled
D3DKMT_ALIGN64 UINT64 Reserved[8];
};
} D3DKMT_SIGNALSYNCHRONIZATIONOBJECTFROMGPU;
typedef struct _D3DKMT_SIGNALSYNCHRONIZATIONOBJECTFROMGPU2
{
UINT ObjectCount; // in: Specifies the number of objects to signal.
D3DKMT_PTR(_Field_size_(ObjectCount)
const D3DKMT_HANDLE*, ObjectHandleArray); // in: Specifies the objects to signal.
D3DDDICB_SIGNALFLAGS Flags; // in: Specifies signal behavior.
ULONG BroadcastContextCount; // in: Specifies the number of contexts to broadcast this signal to.
D3DKMT_PTR(_Field_size_(BroadcastContextCount)
const D3DKMT_HANDLE*, BroadcastContextArray); // in: Specifies context handles to broadcast to.
union
{
D3DKMT_ALIGN64 UINT64 FenceValue; // in: fence value to be signaled;
HANDLE CpuEventHandle; // in: handle of a CPU event to be signaled if Flags.EnqueueCpuEvent flag is set.
_Field_size_(ObjectCount)
const UINT64* MonitoredFenceValueArray; // in: monitored fence values to be signaled
D3DKMT_ALIGN64 UINT64 Reserved[8];
};
} D3DKMT_SIGNALSYNCHRONIZATIONOBJECTFROMGPU2;
typedef struct _D3DKMT_CREATEPAGINGQUEUE
{
D3DKMT_HANDLE hDevice; // in: Handle to the device.
D3DDDI_PAGINGQUEUE_PRIORITY Priority; // in: scheduling priority relative to other paging queues on this device
D3DKMT_HANDLE hPagingQueue; // out: handle to the paging queue used to synchronize paging operations for this device.
D3DKMT_HANDLE hSyncObject; // out: handle to the monitored fence object used to synchronize paging operations for this paging queue.
D3DKMT_PTR(VOID*, FenceValueCPUVirtualAddress); // out: Read-only mapping of the fence value for the CPU
UINT PhysicalAdapterIndex; // in: Physical adapter index (engine ordinal)
} D3DKMT_CREATEPAGINGQUEUE;
typedef struct _D3DKMT_EVICT
{
D3DKMT_HANDLE hDevice; // in: Device that created the allocations
UINT NumAllocations; // in: number of allocation handles
D3DKMT_PTR(CONST D3DKMT_HANDLE*, AllocationList); // in: an array of NumAllocations allocation handles
D3DDDI_EVICT_FLAGS Flags; // in: eviction flags
D3DKMT_ALIGN64 UINT64 NumBytesToTrim; // out: This value indicates how much to trim in order to satisfy the new budget.
} D3DKMT_EVICT;
typedef struct _D3DKMT_LOCK2
{
D3DKMT_HANDLE hDevice; // in: Handle to the device.
D3DKMT_HANDLE hAllocation; // in: allocation to lock
D3DDDICB_LOCK2FLAGS Flags; // in: Bit field defined by D3DDDI_LOCK2FLAGS
D3DKMT_PTR(PVOID, pData); // out: Virtual address of the locked allocation
} D3DKMT_LOCK2;
typedef struct _D3DKMT_UNLOCK2
{
D3DKMT_HANDLE hDevice; // in: Handle to the device.
D3DKMT_HANDLE hAllocation; // in: allocation to unlock
} D3DKMT_UNLOCK2;
typedef struct _D3DKMT_INVALIDATECACHE
{
D3DKMT_HANDLE hDevice;
D3DKMT_HANDLE hAllocation;
D3DKMT_ALIGN64 D3DKMT_SIZE_T Offset;
D3DKMT_ALIGN64 D3DKMT_SIZE_T Length;
} D3DKMT_INVALIDATECACHE;
typedef struct _D3DKMT_FREEGPUVIRTUALADDRESS
{
D3DKMT_HANDLE hAdapter; // in: Handle to an adapter.
D3DKMT_ALIGN64 D3DGPU_VIRTUAL_ADDRESS BaseAddress; // in: Start of a virtual address range in bytes
D3DKMT_ALIGN64 D3DGPU_SIZE_T Size; // in: Size of the virtual address range in bytes
} D3DKMT_FREEGPUVIRTUALADDRESS;
typedef struct _D3DKMT_UPDATEGPUVIRTUALADDRESS
{
D3DKMT_HANDLE hDevice;
D3DKMT_HANDLE hContext;
D3DKMT_HANDLE hFenceObject;
UINT NumOperations;
D3DKMT_PTR(D3DDDI_UPDATEGPUVIRTUALADDRESS_OPERATION*, Operations);
D3DKMT_ALIGN64 D3DKMT_SIZE_T Reserved0;
D3DKMT_ALIGN64 UINT64 Reserved1;
D3DKMT_ALIGN64 UINT64 FenceValue;
union
{
struct
{
UINT DoNotWait : 1;
UINT Reserved : 31;
};
UINT Value;
} Flags;
} D3DKMT_UPDATEGPUVIRTUALADDRESS;
typedef struct _D3DKMT_CREATECONTEXTVIRTUAL
{
D3DKMT_HANDLE hDevice; // in:
UINT NodeOrdinal; // in:
UINT EngineAffinity; // in:
D3DDDI_CREATECONTEXTFLAGS Flags; // in:
D3DKMT_PTR(VOID*, pPrivateDriverData); // in:
UINT PrivateDriverDataSize; // in:
D3DKMT_CLIENTHINT ClientHint; // in: Hints which client is creating the context
D3DKMT_HANDLE hContext; // out:
} D3DKMT_CREATECONTEXTVIRTUAL;
typedef struct _D3DKMT_SUBMITCOMMANDFLAGS
{
UINT NullRendering : 1; // 0x00000001
UINT PresentRedirected : 1; // 0x00000002
UINT NoKmdAccess : 1; // 0x00000004
UINT Reserved : 29; // 0xFFFFFFF8
} D3DKMT_SUBMITCOMMANDFLAGS;
typedef struct _D3DKMT_SUBMITCOMMAND
{
D3DKMT_ALIGN64 D3DGPU_VIRTUAL_ADDRESS Commands;
UINT CommandLength;
D3DKMT_SUBMITCOMMANDFLAGS Flags;
D3DKMT_ALIGN64 ULONGLONG PresentHistoryToken; // in: Present history token for redirected present calls
UINT BroadcastContextCount;
D3DKMT_HANDLE BroadcastContext[D3DDDI_MAX_BROADCAST_CONTEXT];
D3DKMT_PTR(VOID*, pPrivateDriverData);
UINT PrivateDriverDataSize;
UINT NumPrimaries;
D3DKMT_HANDLE WrittenPrimaries[D3DDDI_MAX_WRITTEN_PRIMARIES];
UINT NumHistoryBuffers;
D3DKMT_PTR(D3DKMT_HANDLE*, HistoryBufferArray);
} D3DKMT_SUBMITCOMMAND;
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_2)
typedef struct _D3DKMT_SUBMITCOMMANDTOHWQUEUE
{
D3DKMT_HANDLE hHwQueue; // in: Context queue to submit the command to.
D3DKMT_ALIGN64 UINT64 HwQueueProgressFenceId; // in: Hardware queue progress fence value that will be signaled once the command is finished.
D3DKMT_ALIGN64 D3DGPU_VIRTUAL_ADDRESS CommandBuffer;// in: GPU VA of the command buffer to be executed on the GPU.
UINT CommandLength; // in: Length in bytes of the command buffer.
UINT PrivateDriverDataSize; // in: Size of private driver data in bytes.
D3DKMT_PTR(_Field_size_bytes_(PrivateDriverDataSize)
VOID*, pPrivateDriverData); // in: Pointer to the private driver data.
UINT NumPrimaries; // in: The number of primaries written by this command buffer.
D3DKMT_PTR(_Field_size_ (NumPrimaries)
D3DKMT_HANDLE CONST*, WrittenPrimaries); // in: The array of primaries written by this command buffer.
} D3DKMT_SUBMITCOMMANDTOHWQUEUE;
typedef struct _D3DKMT_SUBMITWAITFORSYNCOBJECTSTOHWQUEUE
{
D3DKMT_HANDLE hHwQueue; // in: Context queue to submit the command to.
UINT ObjectCount; // in: Number of objects to wait on.
D3DKMT_PTR(_Field_size_(ObjectCount)
const D3DKMT_HANDLE*, ObjectHandleArray); // in: Handles to monitored fence synchronization objects to wait on.
D3DKMT_PTR(_Field_size_(ObjectCount)
const UINT64*, FenceValueArray); // in: monitored fence values to be waited.
} D3DKMT_SUBMITWAITFORSYNCOBJECTSTOHWQUEUE;
typedef struct _D3DKMT_SUBMITSIGNALSYNCOBJECTSTOHWQUEUE
{
D3DDDICB_SIGNALFLAGS Flags; // in: Specifies signal behavior.
ULONG BroadcastHwQueueCount; // in: Specifies the number of hardware queues to broadcast this signal to.
D3DKMT_PTR(_Field_size_(BroadcastHwQueueCount)
const D3DKMT_HANDLE*, BroadcastHwQueueArray); // in: Specifies hardware queue handles to broadcast to.
UINT ObjectCount; // in: Number of objects to signal.
D3DKMT_PTR(_Field_size_(ObjectCount)
const D3DKMT_HANDLE*, ObjectHandleArray); // in: Handles to monitored fence synchronization objects to signal.
D3DKMT_PTR(_Field_size_(ObjectCount)
const UINT64*, FenceValueArray); // in: monitored fence values to signal.
} D3DKMT_SUBMITSIGNALSYNCOBJECTSTOHWQUEUE;
#endif // (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_2)
typedef struct _D3DKMT_QUERYVIDEOMEMORYINFO
{
D3DKMT_PTR(HANDLE, hProcess); // in,opt: A handle to a process. If NULL, the current process is used.
// The process handle must be opened with PROCESS_QUERY_INFORMATION privileges
D3DKMT_HANDLE hAdapter; // in : The adapter to query for this process
D3DKMT_MEMORY_SEGMENT_GROUP MemorySegmentGroup; // in : The memory segment group to query.
D3DKMT_ALIGN64 UINT64 Budget; // out: Total memory the application may use
D3DKMT_ALIGN64 UINT64 CurrentUsage; // out: Current memory usage of the device
D3DKMT_ALIGN64 UINT64 CurrentReservation; // out: Current reservation of the device
D3DKMT_ALIGN64 UINT64 AvailableForReservation; // out: Total that the device may reserve
UINT PhysicalAdapterIndex; // in : Zero based physical adapter index in the LDA configuration.
} D3DKMT_QUERYVIDEOMEMORYINFO;
typedef struct _D3DKMT_CHANGEVIDEOMMEMORYRESERVATION
{
D3DKMT_PTR(HANDLE, hProcess); // in,opt: A handle to a process. If NULL, the current process is used.
// The process handle must be opened with PROCESS_SET_INFORMATION privileges
D3DKMT_HANDLE hAdapter; // in : The adapter to change reservation for.
D3DKMT_MEMORY_SEGMENT_GROUP MemorySegmentGroup; // in : The memory segment group to change reservation for.
D3DKMT_ALIGN64 UINT64 Reservation; // in : Desired reservation in the range between 0 and AvailableForReservation returned by QueryVideoMemoryInfo.
UINT PhysicalAdapterIndex; // in : Zero based physical adapter index in the LDA configuration.
} D3DKMT_CHANGEVIDEOMEMORYRESERVATION;
typedef struct _D3DKMT_SETSTABLEPOWERSTATE
{
D3DKMT_HANDLE hAdapter; // in: The adapter to enable or disable stable power for
BOOL Enabled; // in: Whether or not stable power is being requested on or off.
} D3DKMT_SETSTABLEPOWERSTATE;
// Used by Linux ioctl
typedef struct _D3DKMT_SHAREOBJECTS {
UINT ObjectCount; // in
D3DKMT_PTR(_Field_size_(ObjectCount)
CONST D3DKMT_HANDLE*, ObjectHandleArray); // in
D3DKMT_PTR(PVOID, pObjectAttributes); // in
DWORD DesiredAccess; // in
D3DKMT_PTR(HANDLE*, pSharedNtHandle); // out
} D3DKMT_SHAREOBJECTS;
typedef struct _D3DKMT_SHAREOBJECTWITHHOST
{
D3DKMT_HANDLE hDevice; // in
D3DKMT_HANDLE hObject; // in
D3DKMT_ALIGN64 UINT64 Reserved; // in Must be zero. Reserved for future use
D3DKMT_ALIGN64 UINT64 hVailProcessNtHandle; // out
} D3DKMT_SHAREOBJECTWITHHOST;
//
// This API is used to support sync_file in Android.
// A sync_file is a wrapper around the given monitored fence and the fence value.
// When a sync_file is created, a wait for sync object on CPU is issued
// and a file descriptor (FD) it returned to the app. The app can wait on the FD,
// which will be unblocked when the sync object with this fence value is signaled.
//
typedef struct _D3DKMT_CREATESYNCFILE
{
D3DKMT_HANDLE hDevice; // in: Device owner of the monitored fence.
D3DKMT_HANDLE hMonitoredFence; // in: Monitored fence object
D3DKMT_ALIGN64 UINT64 FenceValue; // in: Fence value to wait for
D3DKMT_ALIGN64 UINT64 hSyncFile; // out: File descriptor on Android or a NT handle on Windows (when implemented)
} D3DKMT_CREATESYNCFILE;
typedef struct _D3DKMT_TRIMNOTIFICATION
{
D3DKMT_PTR(VOID*, Context); // In: context at Register
D3DDDI_TRIMRESIDENCYSET_FLAGS Flags; // In: trim flags
D3DKMT_ALIGN64 UINT64 NumBytesToTrim; // In: When TrimToBudget flag is set, this value indicates how much VidMm
// requests the app to trim to fit in the new budget.
} D3DKMT_TRIMNOTIFICATION;
typedef VOID (APIENTRY *PFND3DKMT_TRIMNOTIFICATIONCALLBACK)(_Inout_ D3DKMT_TRIMNOTIFICATION*);
typedef struct _D3DKMT_REGISTERTRIMNOTIFICATION
{
LUID AdapterLuid;
D3DKMT_HANDLE hDevice;
PFND3DKMT_TRIMNOTIFICATIONCALLBACK Callback;
D3DKMT_PTR(VOID*, Context); // In: callback context
D3DKMT_PTR(VOID*, Handle); // Out: for Unregister
} D3DKMT_REGISTERTRIMNOTIFICATION;
typedef struct _D3DKMT_UNREGISTERTRIMNOTIFICATION
{
D3DKMT_PTR(VOID*, Handle); // In: Handle returned from RegisterTrimNotification,
// or NULL to unregister all Callback instances.
D3DKMT_PTR(PFND3DKMT_TRIMNOTIFICATIONCALLBACK, Callback); // In: When Handle is NULL, this parameter specifies that all registered instances of Callback
// should be unregistered. This unregistration method should only be used
// in DLL unload scenarios when the DLL being unloaded cannot guarantee that
// all trim callbacks are unregistered through their handles.
} D3DKMT_UNREGISTERTRIMNOTIFICATION;
typedef struct _D3DKMT_BUDGETCHANGENOTIFICATION
{
D3DKMT_PTR(VOID*, Context); // In: context at Register
D3DKMT_ALIGN64 UINT64 Budget; // In: new budget
} D3DKMT_BUDGETCHANGENOTIFICATION;
typedef VOID (APIENTRY *PFND3DKMT_BUDGETCHANGENOTIFICATIONCALLBACK)(_In_ D3DKMT_BUDGETCHANGENOTIFICATION*);
typedef struct _D3DKMT_REGISTERBUDGETCHANGENOTIFICATION
{
D3DKMT_HANDLE hDevice;
D3DKMT_PTR(PFND3DKMT_BUDGETCHANGENOTIFICATIONCALLBACK, Callback);
D3DKMT_PTR(VOID*, Context); // In: callback context
D3DKMT_PTR(VOID*, Handle); // Out: for Unregister
} D3DKMT_REGISTERBUDGETCHANGENOTIFICATION;
typedef struct _D3DKMT_UNREGISTERBUDGETCHANGENOTIFICATION
{
D3DKMT_PTR(VOID*, Handle); // In: from register
} D3DKMT_UNREGISTERBUDGETCHANGENOTIFICATION;
typedef struct _D3DKMT_QUERYVIDPNEXCLUSIVEOWNERSHIP
{
D3DKMT_PTR(HANDLE, hProcess); // In: Process handle
D3DKMT_PTR(HWND, hWindow); // In: Window handle
D3DDDI_VIDEO_PRESENT_SOURCE_ID VidPnSourceId; // Out: VidPn source ID
LUID AdapterLuid; // Out: Adapter LUID
D3DKMT_VIDPNSOURCEOWNER_TYPE OwnerType; // Out: Owner Type
} D3DKMT_QUERYVIDPNEXCLUSIVEOWNERSHIP;
typedef enum _D3DKMT_DEVICE_ERROR_REASON {
D3DKMT_DEVICE_ERROR_REASON_GENERIC = 0x80000000,
D3DKMT_DEVICE_ERROR_REASON_DRIVER_ERROR = 0x80000006,
} D3DKMT_DEVICE_ERROR_REASON;
typedef struct _D3DKMT_MARKDEVICEASERROR
{
D3DKMT_HANDLE hDevice; // in: Device handle
D3DKMT_DEVICE_ERROR_REASON Reason; // in: Status code
} D3DKMT_MARKDEVICEASERROR;
typedef struct _D3DKMT_FLUSHHEAPTRANSITIONS
{
D3DKMT_HANDLE hAdapter;
} D3DKMT_FLUSHHEAPTRANSITIONS;
typedef struct _D3DKMT_QUERYPROCESSOFFERINFO
{
_In_ ULONG cbSize;
D3DKMT_PTR(_In_ HANDLE, hProcess);
_Out_ D3DKMT_ALIGN64 UINT64 DecommitUniqueness;
_Out_ D3DKMT_ALIGN64 UINT64 DecommittableBytes;
} D3DKMT_QUERYPROCESSOFFERINFO;
typedef union _D3DKMT_TRIMPROCESSCOMMITMENT_FLAGS
{
struct
{
UINT Lazy : 1;
UINT OnlyRepurposed : 1;
UINT Reserved : 30;
};
UINT Value;
} D3DKMT_TRIMPROCESSCOMMITMENT_FLAGS;
typedef struct _D3DKMT_TRIMPROCESSCOMMITMENT
{
_In_ ULONG cbSize;
D3DKMT_PTR(_In_ HANDLE, hProcess);
_In_ D3DKMT_TRIMPROCESSCOMMITMENT_FLAGS Flags;
_In_ D3DKMT_ALIGN64 UINT64 DecommitRequested;
_Out_ D3DKMT_ALIGN64 UINT64 NumBytesDecommitted;
} D3DKMT_TRIMPROCESSCOMMITMENT;
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_2)
typedef struct _D3DKMT_CREATEHWCONTEXT
{
D3DKMT_HANDLE hDevice; // in: Handle to the device owning this context.
UINT NodeOrdinal; // in: Identifier for the node targetted by this context.
UINT EngineAffinity; // in: Engine affinity within the specified node.
D3DDDI_CREATEHWCONTEXTFLAGS Flags; // in: Context creation flags.
UINT PrivateDriverDataSize; // in: Size of private driver data
D3DKMT_PTR(_Inout_
_Field_size_bytes_ (PrivateDriverDataSize)
VOID*, pPrivateDriverData); // in/out: Private driver data
D3DKMT_HANDLE hHwContext; // out: Handle of the created context.
} D3DKMT_CREATEHWCONTEXT;
typedef struct _D3DKMT_DESTROYHWCONTEXT
{
D3DKMT_HANDLE hHwContext; // in: Identifies the context being destroyed.
} D3DKMT_DESTROYHWCONTEXT;
typedef struct _D3DKMT_CREATEHWQUEUE
{
D3DKMT_HANDLE hHwContext; // in: Handle to the hardware context the queue is associated with.
D3DDDI_CREATEHWQUEUEFLAGS Flags; // in: Hardware queue creation flags.
UINT PrivateDriverDataSize; // in: Size of private driver data
D3DKMT_PTR(_Inout_
_Field_size_bytes_ (PrivateDriverDataSize)
VOID*, pPrivateDriverData); // in/out: Private driver data
D3DKMT_HANDLE hHwQueue; // out: handle to the hardware queue object to submit work to.
D3DKMT_HANDLE hHwQueueProgressFence; // out: handle to the monitored fence object used to monitor the queue progress.
D3DKMT_PTR(VOID*, HwQueueProgressFenceCPUVirtualAddress); // out: Read-only mapping of the queue progress fence value for the CPU
D3DKMT_ALIGN64 D3DGPU_VIRTUAL_ADDRESS HwQueueProgressFenceGPUVirtualAddress; // out: Read/write mapping of the queue progress fence value for the GPU
} D3DKMT_CREATEHWQUEUE;
typedef struct _D3DKMT_DESTROYHWQUEUE
{
D3DKMT_HANDLE hHwQueue; // in: handle to the hardware queue to be destroyed.
} D3DKMT_DESTROYHWQUEUE;
typedef struct _D3DKMT_GETALLOCATIONPRIORITY
{
D3DKMT_HANDLE hDevice; // in: Indentifies the device
D3DKMT_HANDLE hResource; // in: Specify the resource to get priority of.
D3DKMT_PTR(CONST D3DKMT_HANDLE*, phAllocationList); // in: pointer to an array allocation to get priorities of.
UINT AllocationCount; // in: Number of allocations in phAllocationList
D3DKMT_PTR(UINT*, pPriorities); // out: Priority for each of the allocation in the array.
} D3DKMT_GETALLOCATIONPRIORITY;
#endif // (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_2)
#endif // (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_0)
#endif // (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WIN8)
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_1)
typedef union _D3DKMT_SETFSEBLOCKFLAGS
{
struct
{
UINT Block : 1;
UINT Reserved : 31;
};
UINT Value;
} D3DKMT_SETFSEBLOCKFLAGS;
typedef struct _D3DKMT_SETFSEBLOCK
{
LUID AdapterLuid;
D3DKMT_HANDLE hAdapter;
D3DDDI_VIDEO_PRESENT_SOURCE_ID VidPnSourceId;
D3DKMT_SETFSEBLOCKFLAGS Flags;
} D3DKMT_SETFSEBLOCK;
typedef union _D3DKMT_QUERYFSEFLAGS
{
struct
{
UINT Blocked : 1;
UINT Reserved : 31;
};
UINT Value;
} D3DKMT_QUERYFSEBLOCKFLAGS;
typedef struct _D3DKMT_QUERYFSEBLOCK
{
LUID AdapterLuid;
D3DKMT_HANDLE hAdapter;
D3DDDI_VIDEO_PRESENT_SOURCE_ID VidPnSourceId;
D3DKMT_QUERYFSEBLOCKFLAGS Flags;
} D3DKMT_QUERYFSEBLOCK;
#endif // (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_1)
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_2)
#endif // (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_2)
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_3)
typedef struct _D3DKMT_CREATEPROTECTEDSESSION
{
D3DKMT_HANDLE hDevice; // in: device handle
D3DKMT_HANDLE hSyncObject; // in: monitored fence handle associated to this session (kernel handle)
D3DKMT_PTR(_Field_size_bytes_(PrivateDriverDataSize)
CONST VOID*, pPrivateDriverData); // in: Private driver data
UINT PrivateDriverDataSize; // in: Size of private runtime data
D3DKMT_PTR(_Field_size_bytes_(PrivateRuntimeDataSize)
CONST VOID*, pPrivateRuntimeData); // in: Private runtime data
UINT PrivateRuntimeDataSize; // in: Size of private runtime data
D3DKMT_HANDLE hHandle; // out: protected session handle (kernel handle)
} D3DKMT_CREATEPROTECTEDSESSION;
typedef struct _D3DKMT_DESTROYPROTECTEDSESSION
{
D3DKMT_HANDLE hHandle; // in: protected session handle (kernel handle)
} D3DKMT_DESTROYPROTECTEDSESSION;
typedef enum _D3DKMT_PROTECTED_SESSION_STATUS
{
D3DKMT_PROTECTED_SESSION_STATUS_OK = 0,
D3DKMT_PROTECTED_SESSION_STATUS_INVALID = 1,
} D3DKMT_PROTECTED_SESSION_STATUS;
typedef struct _D3DKMT_QUERYPROTECTEDSESSIONSTATUS
{
D3DKMT_HANDLE hHandle; // in: protected session handle (kernel handle)
D3DKMT_PROTECTED_SESSION_STATUS Status; // out: protected session status
} D3DKMT_QUERYPROTECTEDSESSIONSTATUS;
typedef struct _D3DKMT_QUERYPROTECTEDSESSIONINFOFROMNTHANDLE
{
D3DKMT_PTR(HANDLE, hNtHandle); // in: protected session handle (NT handle)
D3DKMT_PTR(_Field_size_bytes_(PrivateDriverDataSize)
CONST VOID*, pPrivateDriverData); // in: Private driver data
UINT PrivateDriverDataSize; // in/out: Size of private runtime data
D3DKMT_PTR(_Field_size_bytes_(PrivateRuntimeDataSize)
CONST VOID*, pPrivateRuntimeData); // in: Private runtime data
UINT PrivateRuntimeDataSize; // in/out: Size of private runtime data
} D3DKMT_QUERYPROTECTEDSESSIONINFOFROMNTHANDLE;
typedef struct _D3DKMT_OPENPROTECTEDSESSIONFROMNTHANDLE
{
D3DKMT_PTR(HANDLE, hNtHandle);// in: protected session handle (NT handle)
D3DKMT_HANDLE hHandle; // out: protected session handle (kernel handle)
} D3DKMT_OPENPROTECTEDSESSIONFROMNTHANDLE;
typedef struct _D3DKMT_GETPROCESSDEVICEREMOVALSUPPORT
{
D3DKMT_PTR(HANDLE, hProcess); // in: Process handle
LUID AdapterLuid; // in: Luid of Adapter that is potentially being detached
BOOLEAN Support; // out: Whether or not the process using the adapter can recover from graphics device removal
} D3DKMT_GETPROCESSDEVICEREMOVALSUPPORT;
#endif // (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_3)
// All tracked workload functionality is accessible just by the D3D11 and D3D12 runtimes
typedef enum _D3DKMT_TRACKEDWORKLOADPOLICY
{
D3DKMT_TRACKEDWORKLOADPOLICY_NORMAL = 0,
D3DKMT_TRACKEDWORKLOADPOLICY_ENERGY_EFFICIENT = 1,
D3DKMT_TRACKEDWORKLOADPOLICY_HIGH_SPEED = 2
} D3DKMT_TRACKEDWORKLOADPOLICY;
typedef enum _D3DKMT_TRACKEDWORKLOADDEADLINETYPE
{
D3DKMT_TRACKEDWORKLOADDEADLINETYPE_ABSOLUTE = 0,
D3DKMT_TRACKEDWORKLOADDEADLINETYPE_VBLANK = 1,
} D3DKMT_TRACKEDWORKLOADDEADLINETYPE;
typedef struct _D3DKMT_TRACKEDWORKLOADDEADLINE {
union {
D3DKMT_ALIGN64 UINT64 VBlankOffsetHundredsNS;
D3DKMT_ALIGN64 UINT64 AbsoluteQPC;
};
} D3DKMT_TRACKEDWORKLOADDEADLINE;
typedef struct _D3DKMT_TRACKEDWORKLOADFLAGS
{
union
{
struct
{
UINT Periodic : 1; // 0x00000001 - workload instances occur at a periodic rate
UINT SimilarLoad : 1; // 0x00000002 - workload instances have a similar load
UINT Reserved : 30;
};
UINT Value;
};
} D3DKMT_TRACKEDWORKLOADFLAGS;
#define D3DKMT_MAX_TRACKED_WORKLOAD_INSTANCE_PAIRS 32
typedef struct _D3DKMT_CREATETRACKEDWORKLOAD
{
ULONG cbSize; // in: size of structure for versioning
ULONG ContextCount; // in: Specifies the number of contexts to create the workload
D3DKMT_PTR(_Field_size_(ContextCount)
const D3DKMT_HANDLE*, ContextArray); // in: Specifies context handles in which to create the workload
D3DKMT_TRACKEDWORKLOADDEADLINETYPE DeadlineType; // in: Specifies the deadline type of the tracked workload
UINT32 VidPnTargetId; // in: Specifies the target ID. Needed for VBLANK DEADLINETYPE
D3DKMT_TRACKEDWORKLOADFLAGS Flags; // in: Flags to create the workload with
D3DKMT_TRACKEDWORKLOADPOLICY Policy; // in: Which policy to use
UINT MaxInstances; // in: maximum number of instances this workload can have
UINT MaxInstancePairs; // in: maximum number of instance pairs this workload can have (includes suspend/resume)
D3DKMT_HANDLE hResourceQueryTimestamps; // in: buffer which will contain the resolved query timestamps for the tracked workloads
D3DKMT_HANDLE hTrackedWorkload; // out: the tracked workload handle
} D3DKMT_CREATETRACKEDWORKLOAD;
typedef struct _D3DKMT_DESTROYTRACKEDWORKLOAD
{
ULONG cbSize; // in: size of structure for versioning
D3DKMT_HANDLE hTrackedWorkload; // in: tracked workload handle
} D3DKMT_DESTROYTRACKEDWORKLOAD;
typedef struct _D3DKMT_UPDATETRACKEDWORKLOAD
{
ULONG cbSize; // in: size of structure for versioning
D3DKMT_HANDLE hTrackedWorkload; // in: tracked workload handle
D3DKMT_TRACKEDWORKLOADDEADLINE FinishDeadline; // in: specifies the deadline by which this workload should be finished
UINT BeginTrackedWorkloadIndex;// in: slot for the timestamp for the start of this workload pair (index in buffer pointed to by hResourceQueryTimestamps)
UINT EndTrackedWorkloadIndex; // in: slot for the timestamp for the end of this workload pair (index in buffer pointed to by hResourceQueryTimestamps)
BOOL Resume; // in: TRUE if the start of this workload pair is a Resume instead of a Begin
BOOL Suspend; // in: TRUE if the end of this workload pair is a Suspend instead of an End
D3DKMT_ALIGN64 UINT64 PairID; // in: identifier for the Begin/End tracked workload pair (should include any suspend/resume in the pair)
D3DKMT_ALIGN64 UINT64 FenceSubmissionValue; // in: fence value for the submission of this workload
D3DKMT_ALIGN64 UINT64 FenceCompletedValue; // in: fence value for the completed workloads
D3DKMT_ALIGN64 UINT64 GPUTimestampFrequency; // in: GPU timestamp frequency for resolving query timestamps
D3DKMT_ALIGN64 UINT64 GPUCalibrationTimestamp; // in: value of the GPU calibration timestamp counter
D3DKMT_ALIGN64 UINT64 CPUCalibrationTimestamp; // in: value of the CPU calibration timestamp counter
D3DKMT_ALIGN64 UINT64 TimestampArray[D3DKMT_MAX_TRACKED_WORKLOAD_INSTANCE_PAIRS * 2]; // in: specifies the already read timestamp data (D3D11 only)
BOOL TimestampArrayProcessed; // out: TRUE if the timestamp array entries were processed (D3D11 only)
} D3DKMT_UPDATETRACKEDWORKLOAD;
typedef struct _D3DKMT_GETAVAILABLETRACKEDWORKLOADINDEX
{
ULONG cbSize; // in: size of structure for versioning
D3DKMT_HANDLE hTrackedWorkload; // in: tracked workload handle
D3DKMT_ALIGN64 UINT64 FenceCompletedValue; // in: fence value for the completed workloads
D3DKMT_ALIGN64 UINT64 TimestampArray[D3DKMT_MAX_TRACKED_WORKLOAD_INSTANCE_PAIRS * 2]; // in: specifies the already read timestamp data (D3D11 only)
UINT AvailableTrackedWorkloadIndex; // out: first available tracked workload slot
BOOL TimestampArrayProcessed; // out: TRUE if the timestamp array entries were processed (D3D11 only)
} D3DKMT_GETAVAILABLETRACKEDWORKLOADINDEX;
typedef struct _D3DKMT_TRACKEDWORKLOADSTATEFLAGS
{
union
{
struct
{
UINT Saturated : 1; // 0x00000001 - in the current state of execution, tracked workload cannot meet its deadline.
UINT NotEnoughSamples: 1; // 0x00000002 - we don't have enough samples to produce stats yet
UINT Reserved : 30;
};
UINT Value;
};
} D3DKMT_TRACKEDWORKLOADSTATEFLAGS;
typedef struct _D3DKMT_TRACKEDWORKLOAD_STATISTICS
{
D3DKMT_ALIGN64 INT64 Mean;
D3DKMT_ALIGN64 INT64 Minimum;
D3DKMT_ALIGN64 INT64 Maximum;
D3DKMT_ALIGN64 INT64 Variance;
D3DKMT_ALIGN64 UINT64 Count;
} D3DKMT_TRACKEDWORKLOAD_STATISTICS;
typedef struct _D3DKMT_GETTRACKEDWORKLOADSTATISTICS
{
ULONG cbSize; // in: size of structure for versioning
D3DKMT_HANDLE hTrackedWorkload; // in: tracked workload handle
D3DKMT_ALIGN64 UINT64 FenceCompletedValue; // in: fence value for the completed workloads
D3DKMT_ALIGN64 UINT64 TimestampArray[D3DKMT_MAX_TRACKED_WORKLOAD_INSTANCE_PAIRS * 2]; // in: specifies the already read timestamp data (D3D11 only)
BOOL TimestampArrayProcessed; // out: TRUE if the timestamp array entries were processed (D3D11 only)
D3DKMT_TRACKEDWORKLOAD_STATISTICS DeadlineOffsetHundredsNS; // out: statistics for the offset of the deadline achieved of the tracked workload in hundreds of nanosecs
D3DKMT_ALIGN64 UINT64 MissedDeadlines; // out: count of missed deadlines
D3DKMT_TRACKEDWORKLOADSTATEFLAGS Flags; // out: current state flags
} D3DKMT_GETTRACKEDWORKLOADSTATISTICS;
typedef struct _D3DKMT_RESETTRACKEDWORKLOADSTATISTICS
{
ULONG cbSize; // in: size of structure for versioning
D3DKMT_HANDLE hTrackedWorkload; // in: tracked workload handle
} D3DKMT_RESETTRACKEDWORKLOADSTATISTICS;
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_7)
#endif // DXGKDDI_INTERFACE_VERSION_WDDM2_7
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_CREATEALLOCATION)(_Inout_ D3DKMT_CREATEALLOCATION*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_CREATEALLOCATION2)(_Inout_ D3DKMT_CREATEALLOCATION*); // _ADVSCH_
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_QUERYRESOURCEINFO)(_Inout_ D3DKMT_QUERYRESOURCEINFO*);
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WIN8)
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_QUERYRESOURCEINFOFROMNTHANDLE)(_Inout_ D3DKMT_QUERYRESOURCEINFOFROMNTHANDLE*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_SHAREOBJECTS)(
_In_range_(1, D3DKMT_MAX_OBJECTS_PER_HANDLE) UINT cObjects,
_In_reads_(cObjects) CONST D3DKMT_HANDLE * hObjects,
_In_ POBJECT_ATTRIBUTES pObjectAttributes,
_In_ DWORD dwDesiredAccess,
_Out_ HANDLE * phSharedNtHandle
);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_OPENNTHANDLEFROMNAME)(_Inout_ D3DKMT_OPENNTHANDLEFROMNAME*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_OPENRESOURCEFROMNTHANDLE)(_Inout_ D3DKMT_OPENRESOURCEFROMNTHANDLE*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_OPENSYNCOBJECTFROMNTHANDLE)(_Inout_ D3DKMT_OPENSYNCOBJECTFROMNTHANDLE*);
#endif
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_OPENRESOURCE)(_Inout_ D3DKMT_OPENRESOURCE*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_OPENRESOURCE2)(_Inout_ D3DKMT_OPENRESOURCE*); // _ADVSCH_
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_DESTROYALLOCATION)(_In_ CONST D3DKMT_DESTROYALLOCATION*);
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_0)
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_DESTROYALLOCATION2)(_In_ CONST D3DKMT_DESTROYALLOCATION2*);
#endif // DXGKDDI_INTERFACE_VERSION_WDDM2_0
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_SETALLOCATIONPRIORITY)(_In_ CONST D3DKMT_SETALLOCATIONPRIORITY*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_QUERYALLOCATIONRESIDENCY)(_In_ CONST D3DKMT_QUERYALLOCATIONRESIDENCY*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_CREATEDEVICE)(_Inout_ D3DKMT_CREATEDEVICE*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_DESTROYDEVICE)(_In_ CONST D3DKMT_DESTROYDEVICE*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_CREATECONTEXT)(_Inout_ D3DKMT_CREATECONTEXT*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_DESTROYCONTEXT)(_In_ CONST D3DKMT_DESTROYCONTEXT*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_CREATESYNCHRONIZATIONOBJECT)(_Inout_ D3DKMT_CREATESYNCHRONIZATIONOBJECT*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_CREATESYNCHRONIZATIONOBJECT2)(_Inout_ D3DKMT_CREATESYNCHRONIZATIONOBJECT2*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_OPENSYNCHRONIZATIONOBJECT)(_Inout_ D3DKMT_OPENSYNCHRONIZATIONOBJECT*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_DESTROYSYNCHRONIZATIONOBJECT)(_In_ CONST D3DKMT_DESTROYSYNCHRONIZATIONOBJECT*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_WAITFORSYNCHRONIZATIONOBJECT)(_In_ CONST D3DKMT_WAITFORSYNCHRONIZATIONOBJECT*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_WAITFORSYNCHRONIZATIONOBJECT2)(_In_ CONST D3DKMT_WAITFORSYNCHRONIZATIONOBJECT2*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_SIGNALSYNCHRONIZATIONOBJECT)(_In_ CONST D3DKMT_SIGNALSYNCHRONIZATIONOBJECT*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_SIGNALSYNCHRONIZATIONOBJECT2)(_In_ CONST D3DKMT_SIGNALSYNCHRONIZATIONOBJECT2*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_LOCK)(_Inout_ D3DKMT_LOCK*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_UNLOCK)(_In_ CONST D3DKMT_UNLOCK*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_GETDISPLAYMODELIST)(_Inout_ D3DKMT_GETDISPLAYMODELIST*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_SETDISPLAYMODE)(_Inout_ CONST D3DKMT_SETDISPLAYMODE*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_GETMULTISAMPLEMETHODLIST)(_Inout_ D3DKMT_GETMULTISAMPLEMETHODLIST*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_PRESENT)(_Inout_ D3DKMT_PRESENT*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_RENDER)(_Inout_ D3DKMT_RENDER*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_GETRUNTIMEDATA)(_Inout_ CONST D3DKMT_GETRUNTIMEDATA*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_QUERYADAPTERINFO)(_Inout_ CONST D3DKMT_QUERYADAPTERINFO*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_OPENADAPTERFROMHDC)(_Inout_ D3DKMT_OPENADAPTERFROMHDC*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_OPENADAPTERFROMGDIDISPLAYNAME)(_Inout_ D3DKMT_OPENADAPTERFROMGDIDISPLAYNAME*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_OPENADAPTERFROMDEVICENAME)(_Inout_ D3DKMT_OPENADAPTERFROMDEVICENAME*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_CLOSEADAPTER)(_In_ CONST D3DKMT_CLOSEADAPTER*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_GETSHAREDPRIMARYHANDLE)(_Inout_ D3DKMT_GETSHAREDPRIMARYHANDLE*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_ESCAPE)(_In_ CONST D3DKMT_ESCAPE*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_QUERYSTATISTICS)(_In_ CONST D3DKMT_QUERYSTATISTICS*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_SETVIDPNSOURCEOWNER)(_In_ CONST D3DKMT_SETVIDPNSOURCEOWNER*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_GETPRESENTHISTORY)(_Inout_ D3DKMT_GETPRESENTHISTORY*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_CREATEOVERLAY)(_Inout_ D3DKMT_CREATEOVERLAY*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_UPDATEOVERLAY)(_In_ CONST D3DKMT_UPDATEOVERLAY*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_FLIPOVERLAY)(_In_ CONST D3DKMT_FLIPOVERLAY*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_DESTROYOVERLAY)(_In_ CONST D3DKMT_DESTROYOVERLAY*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_WAITFORVERTICALBLANKEVENT)(_In_ CONST D3DKMT_WAITFORVERTICALBLANKEVENT*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_SETGAMMARAMP)(_In_ CONST D3DKMT_SETGAMMARAMP*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_GETDEVICESTATE)(_Inout_ D3DKMT_GETDEVICESTATE*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_CREATEDCFROMMEMORY)(_Inout_ D3DKMT_CREATEDCFROMMEMORY*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_DESTROYDCFROMMEMORY)(_In_ CONST D3DKMT_DESTROYDCFROMMEMORY*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_SETCONTEXTSCHEDULINGPRIORITY)(_In_ CONST D3DKMT_SETCONTEXTSCHEDULINGPRIORITY*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_GETCONTEXTSCHEDULINGPRIORITY)(_Inout_ D3DKMT_GETCONTEXTSCHEDULINGPRIORITY*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_SETPROCESSSCHEDULINGPRIORITYCLASS)(_In_ HANDLE, _In_ D3DKMT_SCHEDULINGPRIORITYCLASS);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_GETPROCESSSCHEDULINGPRIORITYCLASS)(_In_ HANDLE, _Out_ D3DKMT_SCHEDULINGPRIORITYCLASS*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_RELEASEPROCESSVIDPNSOURCEOWNERS)(_In_ HANDLE);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_GETSCANLINE)(_Inout_ D3DKMT_GETSCANLINE*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_CHANGESURFACEPOINTER)(_In_ CONST D3DKMT_CHANGESURFACEPOINTER*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_SETQUEUEDLIMIT)(_In_ CONST D3DKMT_SETQUEUEDLIMIT*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_POLLDISPLAYCHILDREN)(_In_ CONST D3DKMT_POLLDISPLAYCHILDREN*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_INVALIDATEACTIVEVIDPN)(_In_ CONST D3DKMT_INVALIDATEACTIVEVIDPN*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_CHECKOCCLUSION)(_In_ CONST D3DKMT_CHECKOCCLUSION*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_WAITFORIDLE)(_In_ CONST D3DKMT_WAITFORIDLE*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_CHECKMONITORPOWERSTATE)(_In_ CONST D3DKMT_CHECKMONITORPOWERSTATE*);
typedef _Check_return_ BOOLEAN (APIENTRY *PFND3DKMT_CHECKEXCLUSIVEOWNERSHIP)();
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_CHECKVIDPNEXCLUSIVEOWNERSHIP)(_In_ CONST D3DKMT_CHECKVIDPNEXCLUSIVEOWNERSHIP*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_SETDISPLAYPRIVATEDRIVERFORMAT)(_In_ CONST D3DKMT_SETDISPLAYPRIVATEDRIVERFORMAT*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_SHAREDPRIMARYLOCKNOTIFICATION)(_In_ CONST D3DKMT_SHAREDPRIMARYLOCKNOTIFICATION*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_SHAREDPRIMARYUNLOCKNOTIFICATION)(_In_ CONST D3DKMT_SHAREDPRIMARYUNLOCKNOTIFICATION*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_CREATEKEYEDMUTEX)(_Inout_ D3DKMT_CREATEKEYEDMUTEX*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_OPENKEYEDMUTEX)(_Inout_ D3DKMT_OPENKEYEDMUTEX*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_DESTROYKEYEDMUTEX)(_In_ CONST D3DKMT_DESTROYKEYEDMUTEX*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_ACQUIREKEYEDMUTEX)(_Inout_ D3DKMT_ACQUIREKEYEDMUTEX*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_RELEASEKEYEDMUTEX)(_Inout_ D3DKMT_RELEASEKEYEDMUTEX*);
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WIN8)
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_CREATEKEYEDMUTEX2)(_Inout_ D3DKMT_CREATEKEYEDMUTEX2*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_OPENKEYEDMUTEX2)(_Inout_ D3DKMT_OPENKEYEDMUTEX2*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_ACQUIREKEYEDMUTEX2)(_Inout_ D3DKMT_ACQUIREKEYEDMUTEX2*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_RELEASEKEYEDMUTEX2)(_Inout_ D3DKMT_RELEASEKEYEDMUTEX2*);
#endif
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_CONFIGURESHAREDRESOURCE)(_In_ CONST D3DKMT_CONFIGURESHAREDRESOURCE*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_GETOVERLAYSTATE)(_Inout_ D3DKMT_GETOVERLAYSTATE*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_CHECKSHAREDRESOURCEACCESS)(_In_ CONST D3DKMT_CHECKSHAREDRESOURCEACCESS*);
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WIN8)
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_OFFERALLOCATIONS)(_In_ CONST D3DKMT_OFFERALLOCATIONS*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_RECLAIMALLOCATIONS)(_Inout_ CONST D3DKMT_RECLAIMALLOCATIONS*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_CREATEOUTPUTDUPL)(_In_ CONST D3DKMT_CREATE_OUTPUTDUPL*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_DESTROYOUTPUTDUPL)(_In_ CONST D3DKMT_DESTROY_OUTPUTDUPL*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_OUTPUTDUPLGETFRAMEINFO)(_Inout_ D3DKMT_OUTPUTDUPL_GET_FRAMEINFO*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_OUTPUTDUPLGETMETADATA)(_Inout_ D3DKMT_OUTPUTDUPL_METADATA*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_OUTPUTDUPLGETPOINTERSHAPEDATA)(_Inout_ D3DKMT_OUTPUTDUPL_GET_POINTER_SHAPE_DATA*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_OUTPUTDUPLRELEASEFRAME)(_In_ D3DKMT_OUTPUTDUPL_RELEASE_FRAME*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_OUTPUTDUPLPRESENT)(_In_ CONST D3DKMT_OUTPUTDUPLPRESENT*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_ENUMADAPTERS)(_Inout_ CONST D3DKMT_ENUMADAPTERS*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_ENUMADAPTERS2)(_Inout_ CONST D3DKMT_ENUMADAPTERS2*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_OPENADAPTERFROMLUID)(_Inout_ D3DKMT_OPENADAPTERFROMLUID*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_QUERYREMOTEVIDPNSOURCEFROMGDIDISPLAYNAME)(_Inout_ D3DKMT_QUERYREMOTEVIDPNSOURCEFROMGDIDISPLAYNAME*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_SETVIDPNSOURCEOWNER1)(_In_ CONST D3DKMT_SETVIDPNSOURCEOWNER1*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_PINDIRECTFLIPRESOURCES)(_In_ CONST D3DKMT_PINDIRECTFLIPRESOURCES*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_UNPINDIRECTFLIPRESOURCES)(_In_ CONST D3DKMT_UNPINDIRECTFLIPRESOURCES*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_WAITFORVERTICALBLANKEVENT2)(_In_ CONST D3DKMT_WAITFORVERTICALBLANKEVENT2*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_GETDWMVERTICALBLANKEVENT)(_In_ CONST D3DKMT_GETVERTICALBLANKEVENT*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_SETSYNCREFRESHCOUNTWAITTARGET)(_In_ CONST D3DKMT_SETSYNCREFRESHCOUNTWAITTARGET*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_SETCONTEXTINPROCESSSCHEDULINGPRIORITY)(_In_ CONST D3DKMT_SETCONTEXTINPROCESSSCHEDULINGPRIORITY*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_GETCONTEXTINPROCESSSCHEDULINGPRIORITY)(_Inout_ D3DKMT_GETCONTEXTINPROCESSSCHEDULINGPRIORITY*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_PRESENTMULTIPLANEOVERLAY)(_In_ CONST D3DKMT_PRESENT_MULTIPLANE_OVERLAY*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_GETSHAREDRESOURCEADAPTERLUID)(_Inout_ D3DKMT_GETSHAREDRESOURCEADAPTERLUID*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_SETSTEREOENABLED)(_In_ BOOL);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_QUERYHYBRIDLISTVALUE)(_Inout_ D3DKMT_HYBRID_LIST*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_SETHYBRIDLISTVVALUE)(_Inout_ D3DKMT_HYBRID_LIST*);
#endif
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM1_3)
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_CHECKMULTIPLANEOVERLAYSUPPORT)(_Inout_ D3DKMT_CHECKMULTIPLANEOVERLAYSUPPORT*);
#endif
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_0)
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_MAKERESIDENT)(_Inout_ D3DDDI_MAKERESIDENT*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_EVICT)(_Inout_ D3DKMT_EVICT*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_WAITFORSYNCHRONIZATIONOBJECTFROMCPU)(_In_ CONST D3DKMT_WAITFORSYNCHRONIZATIONOBJECTFROMCPU*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_SIGNALSYNCHRONIZATIONOBJECTFROMCPU)(_In_ CONST D3DKMT_SIGNALSYNCHRONIZATIONOBJECTFROMCPU*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_WAITFORSYNCHRONIZATIONOBJECTFROMGPU)(_In_ CONST D3DKMT_WAITFORSYNCHRONIZATIONOBJECTFROMGPU*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_SIGNALSYNCHRONIZATIONOBJECTFROMGPU)(_In_ CONST D3DKMT_SIGNALSYNCHRONIZATIONOBJECTFROMGPU*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_SIGNALSYNCHRONIZATIONOBJECTFROMGPU2)(_In_ CONST D3DKMT_SIGNALSYNCHRONIZATIONOBJECTFROMGPU2*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_CREATEPAGINGQUEUE)(_Inout_ D3DKMT_CREATEPAGINGQUEUE*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_DESTROYPAGINGQUEUE)(_Inout_ D3DDDI_DESTROYPAGINGQUEUE*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_LOCK2)(_Inout_ D3DKMT_LOCK2*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_UNLOCK2)(_In_ CONST D3DKMT_UNLOCK2*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_INVALIDATECACHE)(_In_ const D3DKMT_INVALIDATECACHE*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_RESERVEGPUVIRTUALADDRESS)(_Inout_ D3DDDI_RESERVEGPUVIRTUALADDRESS*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_MAPGPUVIRTUALADDRESS)(_Inout_ D3DDDI_MAPGPUVIRTUALADDRESS*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_FREEGPUVIRTUALADDRESS)(_In_ CONST D3DKMT_FREEGPUVIRTUALADDRESS*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_UPDATEGPUVIRTUALADDRESS)(_In_ CONST D3DKMT_UPDATEGPUVIRTUALADDRESS*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_GETRESOURCEPRESENTPRIVATEDRIVERDATA)(_Inout_ D3DDDI_GETRESOURCEPRESENTPRIVATEDRIVERDATA*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_CREATECONTEXTVIRTUAL)(_Inout_ D3DKMT_CREATECONTEXTVIRTUAL*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_SUBMITCOMMAND)(_In_ CONST D3DKMT_SUBMITCOMMAND*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_OPENSYNCOBJECTFROMNTHANDLE2)(_Inout_ D3DKMT_OPENSYNCOBJECTFROMNTHANDLE2*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_OPENSYNCOBJECTNTHANDLEFROMNAME)(_Inout_ D3DKMT_OPENSYNCOBJECTNTHANDLEFROMNAME*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_QUERYVIDEOMEMORYINFO)(_Inout_ D3DKMT_QUERYVIDEOMEMORYINFO*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_CHANGEVIDEOMEMORYRESERVATION)(_In_ CONST D3DKMT_CHANGEVIDEOMEMORYRESERVATION*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_REGISTERTRIMNOTIFICATION)(_Inout_ D3DKMT_REGISTERTRIMNOTIFICATION*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_UNREGISTERTRIMNOTIFICATION)(_Inout_ D3DKMT_UNREGISTERTRIMNOTIFICATION*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_REGISTERBUDGETCHANGENOTIFICATION)(_Inout_ D3DKMT_REGISTERBUDGETCHANGENOTIFICATION*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_UNREGISTERBUDGETCHANGENOTIFICATION)(_Inout_ D3DKMT_UNREGISTERBUDGETCHANGENOTIFICATION*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_CHECKMULTIPLANEOVERLAYSUPPORT2)(_Inout_ D3DKMT_CHECKMULTIPLANEOVERLAYSUPPORT2*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_PRESENTMULTIPLANEOVERLAY2)(_In_ CONST D3DKMT_PRESENT_MULTIPLANE_OVERLAY2*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_RECLAIMALLOCATIONS2)(_Inout_ D3DKMT_RECLAIMALLOCATIONS2*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_SETSTABLEPOWERSTATE)(_In_ CONST D3DKMT_SETSTABLEPOWERSTATE*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_QUERYCLOCKCALIBRATION)(_Inout_ D3DKMT_QUERYCLOCKCALIBRATION*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_QUERYVIDPNEXCLUSIVEOWNERSHIP)(_Inout_ D3DKMT_QUERYVIDPNEXCLUSIVEOWNERSHIP*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_ADJUSTFULLSCREENGAMMA)(_In_ D3DKMT_ADJUSTFULLSCREENGAMMA*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_SETVIDPNSOURCEHWPROTECTION)(_In_ D3DKMT_SETVIDPNSOURCEHWPROTECTION*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_MARKDEVICEASERROR)(_In_ D3DKMT_MARKDEVICEASERROR*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_FLUSHHEAPTRANSITIONS)(_In_ D3DKMT_FLUSHHEAPTRANSITIONS*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_SETHWPROTECTIONTEARDOWNRECOVERY)(_In_ D3DKMT_SETHWPROTECTIONTEARDOWNRECOVERY*);
#endif
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_1)
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_QUERYPROCESSOFFERINFO)(_Inout_ D3DKMT_QUERYPROCESSOFFERINFO*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_TRIMPROCESSCOMMITMENT)(_Inout_ D3DKMT_TRIMPROCESSCOMMITMENT*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_UPDATEALLOCATIONPROPERTY)(_Inout_ D3DDDI_UPDATEALLOCPROPERTY*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_CHECKMULTIPLANEOVERLAYSUPPORT3)(_Inout_ D3DKMT_CHECKMULTIPLANEOVERLAYSUPPORT3*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_PRESENTMULTIPLANEOVERLAY3)(_In_ CONST D3DKMT_PRESENT_MULTIPLANE_OVERLAY3*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_SETFSEBLOCK)(_In_ CONST D3DKMT_SETFSEBLOCK*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_QUERYFSEBLOCK)(_Inout_ D3DKMT_QUERYFSEBLOCK*);
#endif
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_2)
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_GETALLOCATIONPRIORITY)(_In_ CONST D3DKMT_GETALLOCATIONPRIORITY*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_GETMULTIPLANEOVERLAYCAPS)(_Inout_ D3DKMT_GET_MULTIPLANE_OVERLAY_CAPS*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_GETPOSTCOMPOSITIONCAPS)(_Inout_ D3DKMT_GET_POST_COMPOSITION_CAPS*);
#endif
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_3)
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_SETVIDPNSOURCEOWNER2)(_In_ CONST D3DKMT_SETVIDPNSOURCEOWNER2*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_GETPROCESSDEVICEREMOVALSUPPORT)(_Inout_ D3DKMT_GETPROCESSDEVICEREMOVALSUPPORT*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_CREATEPROTECTEDSESSION)(_Inout_ D3DKMT_CREATEPROTECTEDSESSION*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_DESTROYPROTECTEDSESSION)(_Inout_ D3DKMT_DESTROYPROTECTEDSESSION*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_QUERYPROTECTEDSESSIONSTATUS)(_Inout_ D3DKMT_QUERYPROTECTEDSESSIONSTATUS*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_QUERYPROTECTEDSESSIONINFOFROMNTHANDLE)(_Inout_ D3DKMT_QUERYPROTECTEDSESSIONINFOFROMNTHANDLE*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_OPENPROTECTEDSESSIONFROMNTHANDLE)(_Inout_ D3DKMT_OPENPROTECTEDSESSIONFROMNTHANDLE*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_OPENKEYEDMUTEXFROMNTHANDLE)(_Inout_ D3DKMT_OPENKEYEDMUTEXFROMNTHANDLE*);
#endif
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_4)
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_CREATEHWQUEUE)(_Inout_ D3DKMT_CREATEHWQUEUE*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_DESTROYHWQUEUE)(_In_ CONST D3DKMT_DESTROYHWQUEUE*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_SUBMITCOMMANDTOHWQUEUE)(_In_ CONST D3DKMT_SUBMITCOMMANDTOHWQUEUE*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_SUBMITWAITFORSYNCOBJECTSTOHWQUEUE)(_In_ CONST D3DKMT_SUBMITWAITFORSYNCOBJECTSTOHWQUEUE*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_SUBMITSIGNALSYNCOBJECTSTOHWQUEUE)(_In_ CONST D3DKMT_SUBMITSIGNALSYNCOBJECTSTOHWQUEUE*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_SUBMITPRESENTBLTTOHWQUEUE)(_In_ CONST D3DKMT_SUBMITPRESENTBLTTOHWQUEUE*);
#endif
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_5)
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_SUBMITPRESENTTOHWQUEUE)(_Inout_ D3DKMT_SUBMITPRESENTTOHWQUEUE*);
#endif // DXGKDDI_INTERFACE_VERSION_WDDM2_5
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_6)
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_OUTPUTDUPLPRESENTTOHWQUEUE)(_In_ CONST D3DKMT_OUTPUTDUPLPRESENTTOHWQUEUE*);
#endif // DXGKDDI_INTERFACE_VERSION_WDDM2_6
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_7)
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_ENUMADAPTERS3)(_Inout_ D3DKMT_ENUMADAPTERS3*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_PINRESOURCES)(_Inout_ D3DKMT_PINRESOURCES*);
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_UNPINRESOURCES)(_In_ CONST D3DKMT_UNPINRESOURCES*);
#ifdef _WIN32
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_DISPLAYPORT_OPERATION)(_Inout_ D3DKMT_DISPLAYPORT_OPERATION_HEADER*);
#endif // _WIN32
#endif
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_9)
#endif
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM3_0)
typedef _Check_return_ NTSTATUS (APIENTRY *PFND3DKMT_CANCELPRESENTS)(_In_ D3DKMT_CANCEL_PRESENTS*);
#endif
#ifdef __REACTOS__
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_2)
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTShareObjectWithHost(_Inout_ D3DKMT_SHAREOBJECTWITHHOST*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTCreateSyncFile(_Inout_ D3DKMT_CREATESYNCFILE*);
// Used in WSL to close the internal file descriptor to /dev/dxg
EXTERN_C VOID APIENTRY D3DKMTCloseDxCoreDevice();
#endif // DXGKDDI_INTERFACE_VERSION_WDDM3_0
#endif // __REACTOS__
#if !defined(D3DKMDT_SPECIAL_MULTIPLATFORM_TOOL)
#ifdef __cplusplus
extern "C"
{
#endif
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTCreateAllocation(_Inout_ D3DKMT_CREATEALLOCATION*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTCreateAllocation2(_Inout_ D3DKMT_CREATEALLOCATION*); // _ADVSCH_
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTQueryResourceInfo(_Inout_ D3DKMT_QUERYRESOURCEINFO*);
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WIN8)
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTQueryResourceInfoFromNtHandle(_Inout_ D3DKMT_QUERYRESOURCEINFOFROMNTHANDLE*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTShareObjects(
_In_range_(1, D3DKMT_MAX_OBJECTS_PER_HANDLE) UINT cObjects,
_In_reads_(cObjects) CONST D3DKMT_HANDLE * hObjects,
_In_ POBJECT_ATTRIBUTES pObjectAttributes,
_In_ DWORD dwDesiredAccess,
_Out_ HANDLE * phSharedNtHandle
);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTOpenNtHandleFromName(_Inout_ D3DKMT_OPENNTHANDLEFROMNAME*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTOpenResourceFromNtHandle(_Inout_ D3DKMT_OPENRESOURCEFROMNTHANDLE*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTOpenSyncObjectFromNtHandle(_Inout_ D3DKMT_OPENSYNCOBJECTFROMNTHANDLE*);
#endif
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTOpenResource(_Inout_ D3DKMT_OPENRESOURCE*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTOpenResource2(_Inout_ D3DKMT_OPENRESOURCE*); // _ADVSCH_
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTDestroyAllocation(_In_ CONST D3DKMT_DESTROYALLOCATION*);
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_0)
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTDestroyAllocation2(_In_ CONST D3DKMT_DESTROYALLOCATION2*);
#endif // DXGKDDI_INTERFACE_VERSION_WDDM2_0
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTSetAllocationPriority(_In_ CONST D3DKMT_SETALLOCATIONPRIORITY*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTQueryAllocationResidency(_In_ CONST D3DKMT_QUERYALLOCATIONRESIDENCY*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTCreateDevice(_Inout_ D3DKMT_CREATEDEVICE*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTDestroyDevice(_In_ CONST D3DKMT_DESTROYDEVICE*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTCreateContext(_Inout_ D3DKMT_CREATECONTEXT*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTDestroyContext(_In_ CONST D3DKMT_DESTROYCONTEXT*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTCreateSynchronizationObject(_Inout_ D3DKMT_CREATESYNCHRONIZATIONOBJECT*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTCreateSynchronizationObject2(_Inout_ D3DKMT_CREATESYNCHRONIZATIONOBJECT2*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTOpenSynchronizationObject(_Inout_ D3DKMT_OPENSYNCHRONIZATIONOBJECT*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTDestroySynchronizationObject(_In_ CONST D3DKMT_DESTROYSYNCHRONIZATIONOBJECT*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTWaitForSynchronizationObject(_In_ CONST D3DKMT_WAITFORSYNCHRONIZATIONOBJECT*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTWaitForSynchronizationObject2(_In_ CONST D3DKMT_WAITFORSYNCHRONIZATIONOBJECT2*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTSignalSynchronizationObject(_In_ CONST D3DKMT_SIGNALSYNCHRONIZATIONOBJECT*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTSignalSynchronizationObject2(_In_ CONST D3DKMT_SIGNALSYNCHRONIZATIONOBJECT2*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTLock(_Inout_ D3DKMT_LOCK*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTUnlock(_In_ CONST D3DKMT_UNLOCK*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTGetDisplayModeList(_Inout_ D3DKMT_GETDISPLAYMODELIST*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTSetDisplayMode(_Inout_ CONST D3DKMT_SETDISPLAYMODE*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTGetMultisampleMethodList(_Inout_ D3DKMT_GETMULTISAMPLEMETHODLIST*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTPresent(_Inout_ D3DKMT_PRESENT*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTRender(_Inout_ D3DKMT_RENDER*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTGetRuntimeData(_Inout_ CONST D3DKMT_GETRUNTIMEDATA*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTQueryAdapterInfo(_Inout_ CONST D3DKMT_QUERYADAPTERINFO*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTOpenAdapterFromHdc(_Inout_ D3DKMT_OPENADAPTERFROMHDC*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTOpenAdapterFromGdiDisplayName(_Inout_ D3DKMT_OPENADAPTERFROMGDIDISPLAYNAME*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTOpenAdapterFromDeviceName(_Inout_ D3DKMT_OPENADAPTERFROMDEVICENAME*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTCloseAdapter(_In_ CONST D3DKMT_CLOSEADAPTER*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTGetSharedPrimaryHandle(_Inout_ D3DKMT_GETSHAREDPRIMARYHANDLE*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTEscape(_In_ CONST D3DKMT_ESCAPE*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTQueryStatistics(_In_ CONST D3DKMT_QUERYSTATISTICS*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTSetVidPnSourceOwner(_In_ CONST D3DKMT_SETVIDPNSOURCEOWNER*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTGetPresentHistory(_Inout_ D3DKMT_GETPRESENTHISTORY*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTGetPresentQueueEvent(_In_ D3DKMT_HANDLE hAdapter, _Inout_ HANDLE*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTCreateOverlay(_Inout_ D3DKMT_CREATEOVERLAY*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTUpdateOverlay(_In_ CONST D3DKMT_UPDATEOVERLAY*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTFlipOverlay(_In_ CONST D3DKMT_FLIPOVERLAY*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTDestroyOverlay(_In_ CONST D3DKMT_DESTROYOVERLAY*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTWaitForVerticalBlankEvent(_In_ CONST D3DKMT_WAITFORVERTICALBLANKEVENT*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTSetGammaRamp(_In_ CONST D3DKMT_SETGAMMARAMP*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTGetDeviceState(_Inout_ D3DKMT_GETDEVICESTATE*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTCreateDCFromMemory(_Inout_ D3DKMT_CREATEDCFROMMEMORY*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTDestroyDCFromMemory(_In_ CONST D3DKMT_DESTROYDCFROMMEMORY*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTSetContextSchedulingPriority(_In_ CONST D3DKMT_SETCONTEXTSCHEDULINGPRIORITY*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTGetContextSchedulingPriority(_Inout_ D3DKMT_GETCONTEXTSCHEDULINGPRIORITY*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTSetProcessSchedulingPriorityClass(_In_ HANDLE, _In_ D3DKMT_SCHEDULINGPRIORITYCLASS);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTGetProcessSchedulingPriorityClass(_In_ HANDLE, _Out_ D3DKMT_SCHEDULINGPRIORITYCLASS*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTReleaseProcessVidPnSourceOwners(_In_ HANDLE);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTGetScanLine(_Inout_ D3DKMT_GETSCANLINE*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTChangeSurfacePointer(_In_ CONST D3DKMT_CHANGESURFACEPOINTER*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTSetQueuedLimit(_In_ CONST D3DKMT_SETQUEUEDLIMIT*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTPollDisplayChildren(_In_ CONST D3DKMT_POLLDISPLAYCHILDREN*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTInvalidateActiveVidPn(_In_ CONST D3DKMT_INVALIDATEACTIVEVIDPN*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTCheckOcclusion(_In_ CONST D3DKMT_CHECKOCCLUSION*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTWaitForIdle(IN CONST D3DKMT_WAITFORIDLE*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTCheckMonitorPowerState(_In_ CONST D3DKMT_CHECKMONITORPOWERSTATE*);
EXTERN_C _Check_return_ BOOLEAN APIENTRY D3DKMTCheckExclusiveOwnership(VOID);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTCheckVidPnExclusiveOwnership(_In_ CONST D3DKMT_CHECKVIDPNEXCLUSIVEOWNERSHIP*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTSetDisplayPrivateDriverFormat(_In_ CONST D3DKMT_SETDISPLAYPRIVATEDRIVERFORMAT*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTSharedPrimaryLockNotification(_In_ CONST D3DKMT_SHAREDPRIMARYLOCKNOTIFICATION*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTSharedPrimaryUnLockNotification(_In_ CONST D3DKMT_SHAREDPRIMARYUNLOCKNOTIFICATION*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTCreateKeyedMutex(_Inout_ D3DKMT_CREATEKEYEDMUTEX*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTOpenKeyedMutex(_Inout_ D3DKMT_OPENKEYEDMUTEX*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTDestroyKeyedMutex(_In_ CONST D3DKMT_DESTROYKEYEDMUTEX*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTAcquireKeyedMutex(_Inout_ D3DKMT_ACQUIREKEYEDMUTEX*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTReleaseKeyedMutex(_Inout_ D3DKMT_RELEASEKEYEDMUTEX*);
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WIN8)
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTCreateKeyedMutex2(_Inout_ D3DKMT_CREATEKEYEDMUTEX2*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTOpenKeyedMutex2(_Inout_ D3DKMT_OPENKEYEDMUTEX2*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTAcquireKeyedMutex2(_Inout_ D3DKMT_ACQUIREKEYEDMUTEX2*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTReleaseKeyedMutex2(_Inout_ D3DKMT_RELEASEKEYEDMUTEX2*);
#endif
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTConfigureSharedResource(_In_ CONST D3DKMT_CONFIGURESHAREDRESOURCE*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTGetOverlayState(_Inout_ D3DKMT_GETOVERLAYSTATE*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTCheckSharedResourceAccess(_In_ CONST D3DKMT_CHECKSHAREDRESOURCEACCESS*);
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WIN8)
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTOfferAllocations(_In_ CONST D3DKMT_OFFERALLOCATIONS*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTReclaimAllocations(_Inout_ CONST D3DKMT_RECLAIMALLOCATIONS*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTCreateOutputDupl(_In_ CONST D3DKMT_CREATE_OUTPUTDUPL*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTDestroyOutputDupl(_In_ CONST D3DKMT_DESTROY_OUTPUTDUPL*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTOutputDuplGetFrameInfo(_Inout_ D3DKMT_OUTPUTDUPL_GET_FRAMEINFO*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTOutputDuplGetMetaData(_Inout_ D3DKMT_OUTPUTDUPL_METADATA*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTOutputDuplGetPointerShapeData(_Inout_ D3DKMT_OUTPUTDUPL_GET_POINTER_SHAPE_DATA*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTOutputDuplReleaseFrame(_Inout_ D3DKMT_OUTPUTDUPL_RELEASE_FRAME*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTOutputDuplPresent(_In_ CONST D3DKMT_OUTPUTDUPLPRESENT*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTEnumAdapters(_Inout_ CONST D3DKMT_ENUMADAPTERS*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTEnumAdapters2(_Inout_ CONST D3DKMT_ENUMADAPTERS2*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTOpenAdapterFromLuid(_Inout_ CONST D3DKMT_OPENADAPTERFROMLUID*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTQueryRemoteVidPnSourceFromGdiDisplayName(_Inout_ D3DKMT_QUERYREMOTEVIDPNSOURCEFROMGDIDISPLAYNAME*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTSetVidPnSourceOwner1(_In_ CONST D3DKMT_SETVIDPNSOURCEOWNER1*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTWaitForVerticalBlankEvent2(_In_ CONST D3DKMT_WAITFORVERTICALBLANKEVENT2*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTSetSyncRefreshCountWaitTarget(_In_ CONST D3DKMT_SETSYNCREFRESHCOUNTWAITTARGET*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTGetDWMVerticalBlankEvent(_In_ CONST D3DKMT_GETVERTICALBLANKEVENT*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTPresentMultiPlaneOverlay(_In_ CONST D3DKMT_PRESENT_MULTIPLANE_OVERLAY*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTGetSharedResourceAdapterLuid(_Inout_ D3DKMT_GETSHAREDRESOURCEADAPTERLUID*);
#endif
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM1_3)
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTCheckMultiPlaneOverlaySupport(_Inout_ D3DKMT_CHECKMULTIPLANEOVERLAYSUPPORT*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTSetContextInProcessSchedulingPriority(_In_ CONST D3DKMT_SETCONTEXTINPROCESSSCHEDULINGPRIORITY*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTGetContextInProcessSchedulingPriority(_Inout_ D3DKMT_GETCONTEXTINPROCESSSCHEDULINGPRIORITY*);
#endif
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_0)
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTMakeResident(_Inout_ D3DDDI_MAKERESIDENT*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTEvict(_Inout_ D3DKMT_EVICT*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTWaitForSynchronizationObjectFromCpu(_In_ CONST D3DKMT_WAITFORSYNCHRONIZATIONOBJECTFROMCPU*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTSignalSynchronizationObjectFromCpu(_In_ CONST D3DKMT_SIGNALSYNCHRONIZATIONOBJECTFROMCPU*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTWaitForSynchronizationObjectFromGpu(_In_ CONST D3DKMT_WAITFORSYNCHRONIZATIONOBJECTFROMGPU*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTSignalSynchronizationObjectFromGpu(_In_ CONST D3DKMT_SIGNALSYNCHRONIZATIONOBJECTFROMGPU*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTSignalSynchronizationObjectFromGpu2(_In_ CONST D3DKMT_SIGNALSYNCHRONIZATIONOBJECTFROMGPU2*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTCreatePagingQueue(_Inout_ D3DKMT_CREATEPAGINGQUEUE*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTDestroyPagingQueue(_Inout_ D3DDDI_DESTROYPAGINGQUEUE*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTLock2(_Inout_ D3DKMT_LOCK2*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTUnlock2(_In_ CONST D3DKMT_UNLOCK2*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTInvalidateCache(_In_ CONST D3DKMT_INVALIDATECACHE*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTMapGpuVirtualAddress(_Inout_ D3DDDI_MAPGPUVIRTUALADDRESS*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTReserveGpuVirtualAddress(_Inout_ D3DDDI_RESERVEGPUVIRTUALADDRESS*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTFreeGpuVirtualAddress(_In_ CONST D3DKMT_FREEGPUVIRTUALADDRESS*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTUpdateGpuVirtualAddress(_In_ CONST D3DKMT_UPDATEGPUVIRTUALADDRESS*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTGetResourcePresentPrivateDriverData(_Inout_ D3DDDI_GETRESOURCEPRESENTPRIVATEDRIVERDATA*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTCreateContextVirtual(_In_ D3DKMT_CREATECONTEXTVIRTUAL*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTSubmitCommand(_In_ CONST D3DKMT_SUBMITCOMMAND*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTOpenSyncObjectFromNtHandle2(_Inout_ D3DKMT_OPENSYNCOBJECTFROMNTHANDLE2*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTOpenSyncObjectNtHandleFromName(_Inout_ D3DKMT_OPENSYNCOBJECTNTHANDLEFROMNAME*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTQueryVideoMemoryInfo(_Inout_ D3DKMT_QUERYVIDEOMEMORYINFO*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTChangeVideoMemoryReservation(_In_ CONST D3DKMT_CHANGEVIDEOMEMORYRESERVATION*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTRegisterTrimNotification(_Inout_ D3DKMT_REGISTERTRIMNOTIFICATION*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTUnregisterTrimNotification(_Inout_ D3DKMT_UNREGISTERTRIMNOTIFICATION*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTCheckMultiPlaneOverlaySupport2(_Inout_ D3DKMT_CHECKMULTIPLANEOVERLAYSUPPORT2*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTPresentMultiPlaneOverlay2(_In_ CONST D3DKMT_PRESENT_MULTIPLANE_OVERLAY2*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTReclaimAllocations2(_Inout_ D3DKMT_RECLAIMALLOCATIONS2*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTSetStablePowerState(_In_ CONST D3DKMT_SETSTABLEPOWERSTATE*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTQueryClockCalibration(_Inout_ D3DKMT_QUERYCLOCKCALIBRATION*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTQueryVidPnExclusiveOwnership(_Inout_ D3DKMT_QUERYVIDPNEXCLUSIVEOWNERSHIP*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTAdjustFullscreenGamma(_In_ D3DKMT_ADJUSTFULLSCREENGAMMA*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTSetVidPnSourceHwProtection(_In_ D3DKMT_SETVIDPNSOURCEHWPROTECTION*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTMarkDeviceAsError(_In_ D3DKMT_MARKDEVICEASERROR*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTFlushHeapTransitions(_In_ D3DKMT_FLUSHHEAPTRANSITIONS*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTSetHwProtectionTeardownRecovery(_In_ D3DKMT_SETHWPROTECTIONTEARDOWNRECOVERY*);
#endif
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_1)
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTQueryProcessOfferInfo(_Inout_ D3DKMT_QUERYPROCESSOFFERINFO*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTTrimProcessCommitment(_Inout_ D3DKMT_TRIMPROCESSCOMMITMENT*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTUpdateAllocationProperty(_Inout_ D3DDDI_UPDATEALLOCPROPERTY*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTCheckMultiPlaneOverlaySupport3(_Inout_ D3DKMT_CHECKMULTIPLANEOVERLAYSUPPORT3*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTPresentMultiPlaneOverlay3(_In_ CONST D3DKMT_PRESENT_MULTIPLANE_OVERLAY3*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTSetFSEBlock(_In_ CONST D3DKMT_SETFSEBLOCK*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTQueryFSEBlock(_Inout_ D3DKMT_QUERYFSEBLOCK*);
#endif
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_2)
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTCreateHwContext(_Inout_ D3DKMT_CREATEHWCONTEXT*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTDestroyHwContext(_In_ CONST D3DKMT_DESTROYHWCONTEXT*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTCreateHwQueue(_Inout_ D3DKMT_CREATEHWQUEUE*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTDestroyHwQueue(_In_ CONST D3DKMT_DESTROYHWQUEUE*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTSubmitCommandToHwQueue(_In_ CONST D3DKMT_SUBMITCOMMANDTOHWQUEUE*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTSubmitWaitForSyncObjectsToHwQueue(_In_ CONST D3DKMT_SUBMITWAITFORSYNCOBJECTSTOHWQUEUE*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTSubmitSignalSyncObjectsToHwQueue(_In_ CONST D3DKMT_SUBMITSIGNALSYNCOBJECTSTOHWQUEUE*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTGetAllocationPriority(_In_ CONST D3DKMT_GETALLOCATIONPRIORITY*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTGetMultiPlaneOverlayCaps(_Inout_ D3DKMT_GET_MULTIPLANE_OVERLAY_CAPS*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTGetPostCompositionCaps(_Inout_ D3DKMT_GET_POST_COMPOSITION_CAPS*);
#endif
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_3)
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTPresentRedirected(_In_ D3DKMT_PRESENT_REDIRECTED*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTSetVidPnSourceOwner2(_In_ CONST D3DKMT_SETVIDPNSOURCEOWNER2*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTSetMonitorColorSpaceTransform(_In_ D3DKMT_SET_COLORSPACE_TRANSFORM*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTCreateProtectedSession(_Inout_ D3DKMT_CREATEPROTECTEDSESSION*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTDestroyProtectedSession(_Inout_ D3DKMT_DESTROYPROTECTEDSESSION*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTQueryProtectedSessionStatus(_Inout_ D3DKMT_QUERYPROTECTEDSESSIONSTATUS*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTQueryProtectedSessionInfoFromNtHandle(_Inout_ D3DKMT_QUERYPROTECTEDSESSIONINFOFROMNTHANDLE*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTOpenProtectedSessionFromNtHandle(_Inout_ D3DKMT_OPENPROTECTEDSESSIONFROMNTHANDLE*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTGetProcessDeviceRemovalSupport(_Inout_ D3DKMT_GETPROCESSDEVICEREMOVALSUPPORT*);
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTOpenKeyedMutexFromNtHandle(_Inout_ D3DKMT_OPENKEYEDMUTEXFROMNTHANDLE*);
#endif
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_4)
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTSubmitPresentBltToHwQueue(_In_ CONST D3DKMT_SUBMITPRESENTBLTTOHWQUEUE*);
#endif
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_5)
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTSubmitPresentToHwQueue(_Inout_ D3DKMT_SUBMITPRESENTTOHWQUEUE*);
#endif
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_6)
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTOutputDuplPresentToHwQueue(_In_ CONST D3DKMT_OUTPUTDUPLPRESENTTOHWQUEUE*);
#endif
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_7)
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTEnumAdapters3(_Inout_ D3DKMT_ENUMADAPTERS3*);
#endif
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM2_9)
#endif
#if (DXGKDDI_INTERFACE_VERSION >= DXGKDDI_INTERFACE_VERSION_WDDM3_0)
EXTERN_C _Check_return_ NTSTATUS APIENTRY D3DKMTCancelPresents(_In_ D3DKMT_CANCEL_PRESENTS*);
#endif
//
// Interface used for shared power component management
// {ea5c6870-e93c-4588-bef1-fec42fc9429a}
//
DEFINE_GUID(GUID_DEVINTERFACE_GRAPHICSPOWER, 0xea5c6870, 0xe93c, 0x4588, 0xbe, 0xf1, 0xfe, 0xc4, 0x2f, 0xc9, 0x42, 0x9a);
#define IOCTL_INTERNAL_GRAPHICSPOWER_REGISTER \
CTL_CODE(FILE_DEVICE_VIDEO, 0xa01, METHOD_NEITHER, FILE_ANY_ACCESS)
#define DXGK_GRAPHICSPOWER_VERSION_1_0 0x1000
#define DXGK_GRAPHICSPOWER_VERSION_1_1 0x1001
#define DXGK_GRAPHICSPOWER_VERSION_1_2 0x1002
#define DXGK_GRAPHICSPOWER_VERSION DXGK_GRAPHICSPOWER_VERSION_1_2
typedef
_IRQL_requires_max_(PASSIVE_LEVEL)
VOID
(*PDXGK_POWER_NOTIFICATION)(
PVOID GraphicsDeviceHandle,
DEVICE_POWER_STATE NewGrfxPowerState,
BOOLEAN PreNotification,
PVOID PrivateHandle
);
typedef
_IRQL_requires_max_(PASSIVE_LEVEL)
VOID
(*PDXGK_REMOVAL_NOTIFICATION)(
PVOID GraphicsDeviceHandle,
PVOID PrivateHandle
);
typedef
_IRQL_requires_max_(DISPATCH_LEVEL)
VOID
(*PDXGK_FSTATE_NOTIFICATION)(
PVOID GraphicsDeviceHandle,
ULONG ComponentIndex,
UINT NewFState,
BOOLEAN PreNotification,
PVOID PrivateHandle
);
typedef
_IRQL_requires_(DISPATCH_LEVEL)
VOID
(*PDXGK_INITIAL_COMPONENT_STATE) (
PVOID GraphicsDeviceHandle,
PVOID PrivateHandle,
ULONG ComponentIndex,
BOOLEAN IsBlockingType,
UINT InitialFState,
GUID ComponentGuid,
UINT PowerComponentMappingFlag
);
typedef struct _DXGK_GRAPHICSPOWER_REGISTER_INPUT_V_1_2 {
ULONG Version;
PVOID PrivateHandle;
PDXGK_POWER_NOTIFICATION PowerNotificationCb;
PDXGK_REMOVAL_NOTIFICATION RemovalNotificationCb;
PDXGK_FSTATE_NOTIFICATION FStateNotificationCb;
PDXGK_INITIAL_COMPONENT_STATE InitialComponentStateCb;
} DXGK_GRAPHICSPOWER_REGISTER_INPUT_V_1_2, *PDXGK_GRAPHICSPOWER_REGISTER_INPUT_V_1_2;
typedef DXGK_GRAPHICSPOWER_REGISTER_INPUT_V_1_2 DXGK_GRAPHICSPOWER_REGISTER_INPUT;
typedef DXGK_GRAPHICSPOWER_REGISTER_INPUT *PDXGK_GRAPHICSPOWER_REGISTER_INPUT;
typedef
_Check_return_
_IRQL_requires_max_(APC_LEVEL)
NTSTATUS
(*PDXGK_SET_SHARED_POWER_COMPONENT_STATE)(
PVOID DeviceHandle,
PVOID PrivateHandle,
ULONG ComponentIndex,
BOOLEAN Active
);
typedef
_Check_return_
_IRQL_requires_max_(APC_LEVEL)
NTSTATUS
(*PDXGK_GRAPHICSPOWER_UNREGISTER)(
PVOID DeviceHandle,
PVOID PrivateHandle
);
typedef struct _DXGK_GRAPHICSPOWER_REGISTER_OUTPUT
{
PVOID DeviceHandle;
DEVICE_POWER_STATE InitialGrfxPowerState;
PDXGK_SET_SHARED_POWER_COMPONENT_STATE SetSharedPowerComponentStateCb;
PDXGK_GRAPHICSPOWER_UNREGISTER UnregisterCb;
} DXGK_GRAPHICSPOWER_REGISTER_OUTPUT, *PDXGK_GRAPHICSPOWER_REGISTER_OUTPUT;
typedef enum _DXGKMT_POWER_SHARED_TYPE
{
DXGKMT_POWER_SHARED_TYPE_AUDIO = 0,
} DXGKMT_POWER_SHARED_TYPE;
#ifdef __cplusplus
}
#endif
#endif // !defined(D3DKMDT_SPECIAL_MULTIPLATFORM_TOOL)
#endif // (NTDDI_VERSION >= NTDDI_LONGHORN) || defined(D3DKMDT_SPECIAL_MULTIPLATFORM_TOOL)
#pragma warning(pop)
#endif /* WINAPI_FAMILY_PARTITION(WINAPI_PARTITION_DESKTOP) */
#pragma endregion
#endif /* _D3DKMTHK_H_ */