mirror of
https://github.com/reactos/reactos.git
synced 2024-11-01 12:26:32 +00:00
6041 lines
289 KiB
C
6041 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_ */
|
|
|