302 lines
7.5 KiB
C
302 lines
7.5 KiB
C
/*==========================================================================;
|
|
*
|
|
* Copyright (C) Microsoft Corporation. All Rights Reserved.
|
|
*
|
|
* File: ddkernel.h
|
|
* Content: APIs for accessing kernel mode support.
|
|
*
|
|
***************************************************************************/
|
|
|
|
#ifndef __DDKM_INCLUDED__
|
|
#define __DDKM_INCLUDED__
|
|
#if defined( _WIN32 ) && !defined( _NO_COM )
|
|
#define COM_NO_WINDOWS_H
|
|
#include <objbase.h>
|
|
#else
|
|
#define IUnknown void
|
|
#undef CO_E_NOTINITIALIZED
|
|
#define CO_E_NOTINITIALIZED 0x800401F0L
|
|
#endif
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
/*
|
|
* GUIDS used by to get kernel interfaces
|
|
*/
|
|
#if defined( _WIN32 ) && !defined( _NO_COM )
|
|
DEFINE_GUID( IID_IDirectDrawKernel, 0x8D56C120,0x6A08,0x11D0,0x9B,0x06,0x00,0xA0,0xC9,0x03,0xA3,0xB8 );
|
|
DEFINE_GUID( IID_IDirectDrawSurfaceKernel, 0x60755DA0,0x6A40,0x11D0,0x9B,0x06,0x00,0xA0,0xC9,0x03,0xA3,0xB8 );
|
|
|
|
#endif
|
|
|
|
/*============================================================================
|
|
*
|
|
* DirectDraw Structures
|
|
*
|
|
* Various structures used to invoke the kernel API functions.
|
|
*
|
|
*==========================================================================*/
|
|
|
|
typedef struct IDirectDrawKernel FAR *LPDIRECTDRAWKERNEL;
|
|
typedef struct IDirectDrawSurfaceKernel FAR *LPDIRECTDRAWSURFACEKERNEL;
|
|
typedef struct _DDKERNELCAPS FAR *LPDDKERNELCAPS;
|
|
|
|
|
|
/*
|
|
* INTERACES FOLLOW:
|
|
* IDirectDrawKernel
|
|
* IVideoPort
|
|
*/
|
|
|
|
/*
|
|
* IDirectDrawKernel
|
|
*/
|
|
#if defined( _WIN32 ) && !defined( _NO_COM )
|
|
#undef INTERFACE
|
|
#define INTERFACE IDirectDrawKernel
|
|
DECLARE_INTERFACE_( IDirectDrawKernel, IUnknown )
|
|
{
|
|
/*** IUnknown methods ***/
|
|
STDMETHOD(QueryInterface) (THIS_ REFIID riid, LPVOID FAR * ppvObj) PURE;
|
|
STDMETHOD_(ULONG,AddRef) (THIS) PURE;
|
|
STDMETHOD_(ULONG,Release) (THIS) PURE;
|
|
/*** IDirectDraw methods ***/
|
|
STDMETHOD(GetCaps)(THIS_ LPDDKERNELCAPS) PURE;
|
|
STDMETHOD(GetKernelHandle)(THIS_ PULONG_PTR) PURE;
|
|
STDMETHOD(ReleaseKernelHandle)(THIS) PURE;
|
|
};
|
|
|
|
#if !defined(__cplusplus) || defined(CINTERFACE)
|
|
#define IDirectDrawKernel_GetCaps(p, a) (p)->lpVtbl->GetCaps(p, a)
|
|
#define IDirectDrawKernel_GetKernelHandle(p, a) (p)->lpVtbl->GetKernelHandle(p, a)
|
|
#define IDirectDrawKernel_ReleaseKernelHandle(p) (p)->lpVtbl->ReleaseKernelHandle(p)
|
|
#endif
|
|
|
|
#endif
|
|
|
|
/*
|
|
* IDirectDrawSurfaceKernel
|
|
*/
|
|
#if defined( _WIN32 ) && !defined( _NO_COM )
|
|
#undef INTERFACE
|
|
#define INTERFACE IDirectDrawSurfaceKernel
|
|
DECLARE_INTERFACE_( IDirectDrawSurfaceKernel, IUnknown )
|
|
{
|
|
/*** IUnknown methods ***/
|
|
STDMETHOD(QueryInterface) (THIS_ REFIID riid, LPVOID FAR * ppvObj) PURE;
|
|
STDMETHOD_(ULONG,AddRef) (THIS) PURE;
|
|
STDMETHOD_(ULONG,Release) (THIS) PURE;
|
|
/*** IDirectDraw methods ***/
|
|
STDMETHOD(GetKernelHandle)(THIS_ PULONG_PTR) PURE;
|
|
STDMETHOD(ReleaseKernelHandle)(THIS) PURE;
|
|
};
|
|
|
|
#if !defined(__cplusplus) || defined(CINTERFACE)
|
|
#define IDirectDrawSurfaceKernel_GetKernelHandle(p, a) (p)->lpVtbl->GetKernelHandle(p, a)
|
|
#define IDirectDrawSurfaceKernel_ReleaseKernelHandle(p) (p)->lpVtbl->ReleaseKernelHandle(p)
|
|
#endif
|
|
|
|
#endif
|
|
|
|
|
|
/*
|
|
* DDKERNELCAPS
|
|
*/
|
|
typedef struct _DDKERNELCAPS
|
|
{
|
|
DWORD dwSize; // size of the DDKERNELCAPS structure
|
|
DWORD dwCaps; // Contains the DDKERNELCAPS_XXX flags
|
|
DWORD dwIRQCaps; // Contains the DDIRQ_XXX flags
|
|
} DDKERNELCAPS, FAR *LPDDKERNELCAPS;
|
|
|
|
|
|
|
|
/****************************************************************************
|
|
*
|
|
* DDKERNELCAPS CAPS
|
|
*
|
|
****************************************************************************/
|
|
|
|
/*
|
|
* Indicates that the device supports field skipping.
|
|
*/
|
|
#define DDKERNELCAPS_SKIPFIELDS 0x00000001l
|
|
|
|
/*
|
|
* Indicates that the device can support software autoflipping.
|
|
*/
|
|
#define DDKERNELCAPS_AUTOFLIP 0x00000002l
|
|
|
|
/*
|
|
* Indicates that the device can switch between bob and weave.
|
|
*/
|
|
#define DDKERNELCAPS_SETSTATE 0x00000004l
|
|
|
|
/*
|
|
* Indicates that a client can gain direct access to the frame buffer.
|
|
*/
|
|
#define DDKERNELCAPS_LOCK 0x00000008l
|
|
|
|
/*
|
|
* Indicates that a client can manually flip the video port.
|
|
*/
|
|
#define DDKERNELCAPS_FLIPVIDEOPORT 0x00000010l
|
|
|
|
/*
|
|
* Indicates that a client can manually flip the overlay.
|
|
*/
|
|
#define DDKERNELCAPS_FLIPOVERLAY 0x00000020l
|
|
|
|
/*
|
|
* Indicates that the device supports a video port capture interface
|
|
* capable of transfering data to system memory.
|
|
*/
|
|
#define DDKERNELCAPS_CAPTURE_SYSMEM 0x00000040l
|
|
|
|
/*
|
|
* Indicates that the device supports a video port capture interface
|
|
* capable of transfering data to non-local video memory.
|
|
*/
|
|
#define DDKERNELCAPS_CAPTURE_NONLOCALVIDMEM 0x00000080l
|
|
|
|
/*
|
|
* Indicates that the device can report the polarity (even/odd) of
|
|
* the curent video field.
|
|
*/
|
|
#define DDKERNELCAPS_FIELDPOLARITY 0x00000100l
|
|
|
|
/*
|
|
* Indicates that the device supports inverting the DIBs while capturing
|
|
* the data.
|
|
*/
|
|
#define DDKERNELCAPS_CAPTURE_INVERTED 0x00000200l
|
|
|
|
/****************************************************************************
|
|
*
|
|
* DDKERNELCAPS IRQ CAPS
|
|
*
|
|
****************************************************************************/
|
|
|
|
/*
|
|
* The device can generate display VSYNC IRQs
|
|
*/
|
|
#define DDIRQ_DISPLAY_VSYNC 0x00000001l
|
|
|
|
/*
|
|
* Reserved
|
|
*/
|
|
#define DDIRQ_RESERVED1 0x00000002l
|
|
|
|
/*
|
|
* The device can generate video ports VSYNC IRQs using video port 0
|
|
*/
|
|
#define DDIRQ_VPORT0_VSYNC 0x00000004l
|
|
|
|
/*
|
|
* The device can generate video ports line IRQs using video port 0
|
|
*/
|
|
#define DDIRQ_VPORT0_LINE 0x00000008l
|
|
|
|
/*
|
|
* The device can generate video ports VSYNC IRQs using video port 1
|
|
*/
|
|
#define DDIRQ_VPORT1_VSYNC 0x00000010l
|
|
|
|
/*
|
|
* The device can generate video ports line IRQs using video port 1
|
|
*/
|
|
#define DDIRQ_VPORT1_LINE 0x00000020l
|
|
|
|
/*
|
|
* The device can generate video ports VSYNC IRQs using video port 2
|
|
*/
|
|
#define DDIRQ_VPORT2_VSYNC 0x00000040l
|
|
|
|
/*
|
|
* The device can generate video ports line IRQs using video port 2
|
|
*/
|
|
#define DDIRQ_VPORT2_LINE 0x00000080l
|
|
|
|
/*
|
|
* The device can generate video ports VSYNC IRQs using video port 3
|
|
*/
|
|
#define DDIRQ_VPORT3_VSYNC 0x00000100l
|
|
|
|
/*
|
|
* The device can generate video ports line IRQs using video port 3
|
|
*/
|
|
#define DDIRQ_VPORT3_LINE 0x00000200l
|
|
|
|
/*
|
|
* The device can generate video ports VSYNC IRQs using video port 4
|
|
*/
|
|
#define DDIRQ_VPORT4_VSYNC 0x00000400l
|
|
|
|
/*
|
|
* The device can generate video ports line IRQs using video port 4
|
|
*/
|
|
#define DDIRQ_VPORT4_LINE 0x00000800l
|
|
|
|
/*
|
|
* The device can generate video ports VSYNC IRQs using video port 5
|
|
*/
|
|
#define DDIRQ_VPORT5_VSYNC 0x00001000l
|
|
|
|
/*
|
|
* The device can generate video ports line IRQs using video port 5
|
|
*/
|
|
#define DDIRQ_VPORT5_LINE 0x00002000l
|
|
|
|
/*
|
|
* The device can generate video ports VSYNC IRQs using video port 6
|
|
*/
|
|
#define DDIRQ_VPORT6_VSYNC 0x00004000l
|
|
|
|
/*
|
|
* The device can generate video ports line IRQs using video port 6
|
|
*/
|
|
#define DDIRQ_VPORT6_LINE 0x00008000l
|
|
|
|
/*
|
|
* The device can generate video ports VSYNC IRQs using video port 7
|
|
*/
|
|
#define DDIRQ_VPORT7_VSYNC 0x00010000l
|
|
|
|
/*
|
|
* The device can generate video ports line IRQs using video port 7
|
|
*/
|
|
#define DDIRQ_VPORT7_LINE 0x00020000l
|
|
|
|
/*
|
|
* The device can generate video ports VSYNC IRQs using video port 8
|
|
*/
|
|
#define DDIRQ_VPORT8_VSYNC 0x00040000l
|
|
|
|
/*
|
|
* The device can generate video ports line IRQs using video port 8
|
|
*/
|
|
#define DDIRQ_VPORT8_LINE 0x00080000l
|
|
|
|
/*
|
|
* The device can generate video ports VSYNC IRQs using video port 9
|
|
*/
|
|
#define DDIRQ_VPORT9_VSYNC 0x00010000l
|
|
|
|
/*
|
|
* The device can generate video ports line IRQs using video port 9
|
|
*/
|
|
#define DDIRQ_VPORT9_LINE 0x00020000l
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
};
|
|
#endif
|
|
|
|
#endif
|
|
|
|
|
|
|