/******************************Module*Header*******************************\ * Module Name: mcdrv.h * * Server-side data structure for MCD driver interface. These structures and * values are used by the MCD driver to process calls made to the driver. * * Copyright (c) 1996 Microsoft Corporation * \**************************************************************************/ #ifndef _MCDRV_H #define _MCDRV_H #define MCD_VER_MAJOR 1 #define MCD_VER_MINOR 0 #define MCD_MAX_USER_CLIP_PLANES 6 #define MCDRV_MEM_BUSY 1 #define MCDRV_MEM_NOT_BUSY 2 typedef ENUMRECTS MCDENUMRECTS; typedef HANDLE MCDHANDLE; typedef float MCDFLOAT; typedef double MCDDOUBLE; #define MCDENGDLLNAME "MCDSRV32.DLL" #define MCDFUNCS RXFUNCS #define MCDRV_MEM_DMA 0x0001 #define MCDRV_TEXTURE_RESIDENT 0x0001 typedef struct _MCDRIVERINFO { ULONG verMajor; ULONG verMinor; ULONG verDriver; CHAR idStr[200]; ULONG drvMemFlags; ULONG drvBatchMemSizeMax; } MCDDRIVERINFO; typedef struct _MCDWINDOW { RECTL clientRect; // Rectangle describing current window // client area RECTL clipBoundsRect; // Bounding rectangle for the individual // clipping rectangles MCDENUMRECTS *pClip; // List of rectangles describing the // current clip region intersected // with the current scissors rectangle MCDENUMRECTS *pClipUnscissored; // Unscissored version of above VOID *pvUser; } MCDWINDOW; // Rendering context // MCD context createFlags: // // MCDCONTEXT_SWAPSYNC If set, synchronize MCDrvSwap to VSYNC // for a tearless swap (if possible). // // MCDCONTEXT_IO_PRIORITY If set, allow OpenGL to have a higher priority // on the bus (if possible, let OpenGL "hog" the // bus). // #define MCDCONTEXT_SWAPSYNC 0x00000001 #define MCDCONTEXT_IO_PRIORITY 0x00000002 typedef struct _MCDRC { LONG iPixelFormat; // Pixel format for the RC LONG iLayerPlane; // Layer plane for the RC ULONG createFlags; // Creation flags ULONG userFlags; // User-specified flags VOID *pvUser; // User-specified pointer for expansion } MCDRC; #define MCDRCINFO_NOVIEWPORTADJUST 0x0001 #define MCDRCINFO_Y_LOWER_LEFT 0x0002 #define MCDRCINFO_DEVCOLORSCALE 0x0004 #define MCDRCINFO_DEVZSCALE 0x0008 typedef struct _MCRCINFO { ULONG requestFlags; MCDFLOAT redScale; MCDFLOAT greenScale; MCDFLOAT blueScale; MCDFLOAT alphaScale; MCDDOUBLE zScale; // This is a double to preserve accuracy ULONG depthBufferMax; LONG viewportXAdjust; LONG viewportYAdjust; ULONG reserved[12]; } MCDRCINFO; // MCD pixel format descriptor typedef struct _MCDPIXELFORMAT { WORD nSize; DWORD dwFlags; // Any combination of: // // PFD_DOUBLEBUFFER // PFD_NEED_PALETTE // PFD_NEED_SYSTEM_PALETTE // PFD_SWAP_EXCHANGE // PFD_SWAP_COPY // PFD_SWAP_LAYER_BUFFERS BYTE iPixelType; // One of the following: // // PFD_TYPE_RGBA // PFD_TYPE_COLORINDEX BYTE cColorBits; BYTE cRedBits; BYTE cRedShift; BYTE cGreenBits; BYTE cGreenShift; BYTE cBlueBits; BYTE cBlueShift; BYTE cAlphaBits; BYTE cAlphaShift; BYTE cDepthBits; // Number of significant depth bits BYTE cDepthShift; BYTE cDepthBufferBits; // Element size of depth buffer // (eg, a depth buffer with cDepthBits = 24 // might have a cDepthBufferBits = 32) BYTE cStencilBits; BYTE cOverlayPlanes; // Count of up to 15 overlay planes BYTE cUnderlayPlanes; // Count of up to 15 underlay planes DWORD dwTransparentColor; // If there is an underlay plane, specifies // transparent color or index. } MCDPIXELFORMAT; // MCD layer plane descriptor typedef struct _MCDLAYERPLANE { WORD nSize; WORD nVersion; DWORD dwFlags; // Any combination of: // // LPD_SUPPORT_OPENGL // LPD_SUPPORT_GDI // LPD_DOUBLEBUFFER // LPD_STEREO // LPD_SWAP_EXCHANGE // LPD_SWAP_COPY // LPD_TRANSPARANT // LPD_SHARE_DEPTH // LPD_SHARE_STENCIL // LPD_SHARE_ACCUM BYTE iPixelType; // One of the following: // // LPD_TYPE_RGBA // LPD_TYPE_COLORINDEX BYTE cColorBits; BYTE cRedBits; BYTE cRedShift; BYTE cGreenBits; BYTE cGreenShift; BYTE cBlueBits; BYTE cBlueShift; BYTE cAlphaBits; BYTE cAlphaShift; BYTE cAuxBuffers; BYTE iLayerPlane; COLORREF crTransparent; } MCDLAYERPLANE; // // Basic rendering types: // typedef struct _MCDCOLOR { MCDFLOAT r, g, b, a; } MCDCOLOR; typedef struct _MCDCOORD { MCDFLOAT x, y, z, w; } MCDCOORD; // Texture structures: typedef struct __MCDMIPMAPLEVEL { UCHAR *pTexels; // pointer to client texture data LONG width, height; LONG widthImage, heightImage; // Image dimensions without the border MCDFLOAT widthImagef, heightImagef; // Floatin-point versions of above LONG widthLog2, heightLog2; // Log2 of above LONG border; // Border size LONG requestedFormat; // Requested internal format LONG baseFormat; // Base format LONG internalFormat; // Actual internal format LONG redSize; // Component resolution LONG greenSize; LONG blueSize; LONG alphaSize; LONG luminanceSize; LONG intensitySize; ULONG reserved; } MCDMIPMAPLEVEL; typedef struct __MCDTEXTURESTATE { ULONG sWrapMode; // Wrap modes ULONG tWrapMode; ULONG minFilter; // Min/mag filters ULONG magFilter; MCDCOLOR borderColor; // Border color } MCDTEXTURESTATE; typedef struct __MCDTEXTUREOBJSTATE { ULONG name; // "name" of texture object MCDFLOAT priority; // priority of the texture object } MCDTEXTUREOBJSTATE; typedef struct __MCDTEXTUREDATA { MCDTEXTURESTATE textureState; MCDTEXTUREOBJSTATE textureObjState; MCDMIPMAPLEVEL *level; ULONG textureDimension; // Support for texture palettes: ULONG paletteSize; RGBQUAD *paletteData; ULONG paletteBaseFormat; // Type of palette data ULONG paletteRequestedFormat; } MCDTEXTUREDATA; typedef struct _MCDTEXTURE { MCDTEXTUREDATA *pMCDTextureData; VOID *pSurface; ULONG createFlags; ULONG textureKey; // Must be filled in by the driver ULONG userFlags; VOID *pvUser; } MCDTEXTURE; typedef struct _MCDMEM { ULONG memSize; ULONG createFlags; UCHAR *pMemBase; ULONG userFlags; VOID *pvUser; } MCDMEM; typedef struct _MCDSTATE { ULONG state; ULONG size; ULONG stateValue; } MCDSTATE; #define MCD_RENDER_STATE 0 #define MCD_PIXEL_STATE 1 #define MCD_SCISSOR_RECT_STATE 2 #define MCD_TEXENV_STATE 3 // // MCDSTATE_RENDER is derived from the MCDSTATE structure and is used // to pass all MCD rendering state (MCDALLSTATE) in a single command // via MCDrvState. // // State field names are derived from the GLenum constant names by removing // the GL_ prefix, replacing the "_" separators with case changes, and // adding the "Enable" suffix to state enables. // // For example: // // GL_FOG_COLOR becomes fogColor // GL_POINT_SMOOTH becomes pointSmoothEnable // // In addition, there are few multiple values that are accessed via a single // GLenum. For example, GL_POLYGON_MODE returns both a front and a back // polygon mode, so: // // GL_POLYGON_MODE becomes polygonModeFront *and* polygonModeBack // // Enable flags for enables field in MCDALLSTATE #define MCD_ALPHA_TEST_ENABLE (1 << 0) #define MCD_BLEND_ENABLE (1 << 1) #define MCD_INDEX_LOGIC_OP_ENABLE (1 << 2) #define MCD_DITHER_ENABLE (1 << 3) #define MCD_DEPTH_TEST_ENABLE (1 << 4) #define MCD_FOG_ENABLE (1 << 5) #define MCD_LIGHTING_ENABLE (1 << 6) #define MCD_COLOR_MATERIAL_ENABLE (1 << 7) // Not currently used #define MCD_LINE_STIPPLE_ENABLE (1 << 8) #define MCD_LINE_SMOOTH_ENABLE (1 << 9) #define MCD_POINT_SMOOTH_ENABLE (1 << 10) #define MCD_POLYGON_SMOOTH_ENABLE (1 << 11) #define MCD_CULL_FACE_ENABLE (1 << 12) #define MCD_POLYGON_STIPPLE_ENABLE (1 << 13) #define MCD_SCISSOR_TEST_ENABLE (1 << 14) #define MCD_STENCIL_TEST_ENABLE (1 << 15) #define MCD_TEXTURE_1D_ENABLE (1 << 16) #define MCD_TEXTURE_2D_ENABLE (1 << 17) #define MCD_TEXTURE_GEN_S_ENABLE (1 << 18) // Not currently used #define MCD_TEXTURE_GEN_T_ENABLE (1 << 19) // Not currently used #define MCD_TEXTURE_GEN_R_ENABLE (1 << 20) // Not currently used #define MCD_TEXTURE_GEN_Q_ENABLE (1 << 21) // Not currently used #define MCD_NORMALIZE_ENABLE (1 << 22) // Not currently used #define MCD_AUTO_NORMAL_ENABLE (1 << 23) // Not currently used #define MCD_POLYGON_OFFSET_POINT_ENABLE (1 << 24) #define MCD_POLYGON_OFFSET_LINE_ENABLE (1 << 25) #define MCD_POLYGON_OFFSET_FILL_ENABLE (1 << 26) #define MCD_COLOR_LOGIC_OP_ENABLE (1 << 27) typedef struct _MCDRENDERSTATE { // state enables ULONG enables; // texture state BOOL textureEnabled; // fog state MCDCOLOR fogColor; MCDFLOAT fogIndex; MCDFLOAT fogDensity; MCDFLOAT fogStart; MCDFLOAT fogEnd; ULONG fogMode; // shading model state ULONG shadeModel; // point drawing state MCDFLOAT pointSize; // line drawing state MCDFLOAT lineWidth; USHORT lineStipplePattern; SHORT lineStippleRepeat; // polygon drawing state ULONG cullFaceMode; ULONG frontFace; ULONG polygonModeFront; ULONG polygonModeBack; BYTE polygonStipple[4*32]; MCDFLOAT zOffsetFactor; MCDFLOAT zOffsetUnits; // stencil test state BOOL stencilTestFunc; USHORT stencilMask; USHORT stencilRef; ULONG stencilFail; ULONG stencilDepthFail; ULONG stencilDepthPass; // alpha test state ULONG alphaTestFunc; MCDFLOAT alphaTestRef; // depth test state ULONG depthTestFunc; // blend state ULONG blendSrc; ULONG blendDst; // logic op state ULONG logicOpMode; // frame buffer control state ULONG drawBuffer; ULONG indexWritemask; BOOL colorWritemask[4]; BOOL depthWritemask; //!!!mcd -- called mask, but really a write enable USHORT stencilWritemask; MCDCOLOR colorClearValue; MCDFLOAT indexClearValue; MCDDOUBLE depthClearValue; USHORT stencilClearValue; // lighting BOOL twoSided; // clipping control MCDCOORD userClipPlanes[MCD_MAX_USER_CLIP_PLANES]; // hints ULONG perspectiveCorrectionHint; ULONG pointSmoothHint; ULONG lineSmoothHint; ULONG polygonSmoothHint; ULONG fogHint; } MCDRENDERSTATE; typedef struct _MCDSTATE_RENDER { ULONG state; // must be MCD_RENDER_STATE ULONG size; // must be sizeof(MCDSTATE_RENDER) MCDRENDERSTATE allState; } MCDSTATE_RENDER; // // MCDSTATEPIXEL is a variant of the MCDSTATE structure that is used // to pass all pixel state (MCDPIXELSTATE) in a single command // via MCDrvState. // // Note: for MCDrvDrawPixels, the MCDUNPACK structure can be overridden by // the packed parameter to the function. If set, the source of the data is // a display list and the structure of the data for that call may be assumed // to be: // // swapEndian = FALSE // lsbFirst = FALSE // lineLength = width (from MCDrvDrawPixels parameter list) // skipLines = 0 // skipPixels = 0 // alignment = 1 // typedef struct _MCDPIXELTRANSFER { MCDFLOAT redScale, greenScale, blueScale, alphaScale, depthScale; MCDFLOAT redbias, greenBias, blueBias, aalphaBias, depthBias; MCDFLOAT zoomX; MCDFLOAT zoomY; LONG indexShift; LONG indexOffset; BOOL mapColor; BOOL mapStencil; } MCDPIXELTRANSFER; typedef struct _MCDPIXELPACK { BOOL swapEndian; BOOL lsbFirst; LONG lineLength; LONG skipLines; LONG skipPixels; LONG alignment; } MCDPIXELPACK; typedef struct _MCDPIXELUNPACK { BOOL swapEndian; BOOL lsbFirst; LONG lineLength; LONG skipLines; LONG skipPixels; LONG alignment; } MCDPIXELUNPACK; typedef struct _MCDPIXELSTATE { MCDPIXELTRANSFER pixelTransferModes; MCDPIXELPACK pixelPackModes; MCDPIXELUNPACK pixelUnpackModes; ULONG readBuffer; MCDCOORD rasterPos; } MCDPIXELSTATE; typedef struct _MCDSTATE_PIXEL { ULONG state; // must be MCD_PIXEL_STATE ULONG size; // must be sizeof(MCDSTATE_PIXEL) MCDPIXELSTATE pixelState; } MCDSTATE_PIXEL; // // MCDSTATE_SCISSOR_RECT is a variant of the MCDSTATE structure // that is used to pass the scissor rectangle to the MCD driver // via MCDrvState. // typedef struct _MCDSTATE_SCISSOR_RECT { ULONG state; // must be MCD_SCISSOR_RECT_STATE ULONG size; // must be sizeof(MCDSTATE_SCISSOR_RECT) RECTL scissorRect; } MCDSTATE_SCISSOR_RECT; // // MCDSTATE_TEXENV is a variant of the MCDSTATE structure that is // used to pass the texture environment state to the MCD driver // via MCDrvState. // typedef struct _MCDTEXENVSTATE { ULONG texEnvMode; MCDCOLOR texEnvColor; } MCDTEXENVSTATE; typedef struct _MCDSTATE_TEXENV { ULONG state; // must be MCD_TEXENV_STATE ULONG size; // must be sizeof(MCDSTATE_TEXENV) MCDTEXENVSTATE texEnvState; } MCDSTATE_TEXENV; // // MCDVIEWPORT is used to pass viewport state to the MCD driver // via MCDrvViewport. typedef struct _MCDVIEWPORT { MCDFLOAT xScale, xCenter; MCDFLOAT yScale, yCenter; MCDFLOAT zScale, zCenter; } MCDVIEWPORT; // // MCD surface flags: // // MCDSURFACE_HWND Currently must be set. #define MCDSURFACE_HWND 0x00000001 typedef struct _MCDSURFACE { MCDWINDOW *pWnd; // Region support SURFOBJ *pso; WNDOBJ *pwo; ULONG reserved[4]; ULONG surfaceFlags; } MCDSURFACE; #define MCDSPAN_FRONT 1 #define MCDSPAN_BACK 2 #define MCDSPAN_DEPTH 3 typedef struct _MCDSPAN { LONG x; LONG y; LONG numPixels; ULONG type; VOID *pPixels; } MCDSPAN; // // MCDBUF.bufFlags flags: // // MCDBUF_ENABLED If set, direct buffer access is enabled (i.e., the // bufOffset and bufStride values are valid and may // be used to access the buffer). // // MCDBUF_NOCLIP If set, indicates that clipping is not required // for the current state of the window. // #define MCDBUF_ENABLED 0x00000001 #define MCDBUF_NOCLIP 0x00000002 typedef struct _MCDBUF { ULONG bufFlags; LONG bufOffset; // offset relative to beginning of framebuffer LONG bufStride; } MCDBUF; typedef struct _MCDBUFFERS { MCDBUF mcdFrontBuf; MCDBUF mcdBackBuf; MCDBUF mcdDepthBuf; } MCDBUFFERS; // // MCDrvSwap flags // #define MCDSWAP_MAIN_PLANE 0x00000001 #define MCDSWAP_OVERLAY1 0x00000002 #define MCDSWAP_OVERLAY2 0x00000004 #define MCDSWAP_OVERLAY3 0x00000008 #define MCDSWAP_OVERLAY4 0x00000010 #define MCDSWAP_OVERLAY5 0x00000020 #define MCDSWAP_OVERLAY6 0x00000040 #define MCDSWAP_OVERLAY7 0x00000080 #define MCDSWAP_OVERLAY8 0x00000100 #define MCDSWAP_OVERLAY9 0x00000200 #define MCDSWAP_OVERLAY10 0x00000400 #define MCDSWAP_OVERLAY11 0x00000800 #define MCDSWAP_OVERLAY12 0x00001000 #define MCDSWAP_OVERLAY13 0x00002000 #define MCDSWAP_OVERLAY14 0x00004000 #define MCDSWAP_OVERLAY15 0x00008000 #define MCDSWAP_UNDERLAY1 0x00010000 #define MCDSWAP_UNDERLAY2 0x00020000 #define MCDSWAP_UNDERLAY3 0x00040000 #define MCDSWAP_UNDERLAY4 0x00080000 #define MCDSWAP_UNDERLAY5 0x00100000 #define MCDSWAP_UNDERLAY6 0x00200000 #define MCDSWAP_UNDERLAY7 0x00400000 #define MCDSWAP_UNDERLAY8 0x00800000 #define MCDSWAP_UNDERLAY9 0x01000000 #define MCDSWAP_UNDERLAY10 0x02000000 #define MCDSWAP_UNDERLAY11 0x04000000 #define MCDSWAP_UNDERLAY12 0x08000000 #define MCDSWAP_UNDERLAY13 0x10000000 #define MCDSWAP_UNDERLAY14 0x20000000 #define MCDSWAP_UNDERLAY15 0x40000000 // MCDDRIVER structure containing driver functions typedef LONG (*MCDRVDESCRIBEPIXELFORMATFUNC)(MCDSURFACE *pMCDSurface, LONG iPixelFormat, ULONG nBytes, MCDPIXELFORMAT *pMCDPixelFmt, ULONG flags); typedef BOOL (*MCDRVDESCRIBELAYERPLANEFUNC)(MCDSURFACE *pMCDSurface, LONG iPixelFormat, LONG iLayerPlane, ULONG nBytes, MCDLAYERPLANE *pMCDLayerPlane, ULONG flags); typedef LONG (*MCDRVSETLAYERPALETTEFUNC)(MCDSURFACE *pMCDSurface, LONG iLayerPlane, BOOL bRealize, LONG cEntries, COLORREF *pcr); typedef BOOL (*MCDRVINFOFUNC)(MCDSURFACE *pMCDSurface, MCDDRIVERINFO *pMCDDriverInfo); typedef ULONG (*MCDRVCREATECONTEXTFUNC)(MCDSURFACE *pMCDSurface, MCDRC *pRc, MCDRCINFO *pDrvRcInfo); typedef ULONG (*MCDRVDELETECONTEXTFUNC)(MCDRC *pRc, DHPDEV dhpdev); typedef ULONG (*MCDRVCREATETEXTUREFUNC)(MCDSURFACE *pMCDSurface, MCDRC *pRc, MCDTEXTURE *pTex); typedef ULONG (*MCDRVUPDATESUBTEXTUREFUNC)(MCDSURFACE *pMCDSurface, MCDRC *pRc, MCDTEXTURE *pTex, ULONG lod, RECTL *pRect); typedef ULONG (*MCDRVUPDATETEXTUREPALETTEFUNC)(MCDSURFACE *pMCDSurface, MCDRC *pRc, MCDTEXTURE *pTex, ULONG start, ULONG numEntries); typedef ULONG (*MCDRVUPDATETEXTUREPRIORITYFUNC)(MCDSURFACE *pMCDSurface, MCDRC *pRc, MCDTEXTURE *pTex); typedef ULONG (*MCDRVUPDATETEXTURESTATEFUNC)(MCDSURFACE *pMCDSurface, MCDRC *pRc, MCDTEXTURE *pTex); typedef ULONG (*MCDRVTEXTURESTATUSFUNC)(MCDSURFACE *pMCDSurface, MCDRC *pRc, MCDTEXTURE *pTex); typedef ULONG (*MCDRVDELETETEXTUREFUNC)(MCDTEXTURE *pTex, DHPDEV dhpdev); typedef ULONG (*MCDRVCREATEMEMFUNC)(MCDSURFACE *pMCDSurface, MCDMEM *pMCDMem); typedef ULONG (*MCDRVDELETEMEMFUNC)(MCDMEM *pMCDMem, DHPDEV dhpdev); typedef ULONG (*MCDRVDRAWFUNC)(MCDSURFACE *pMCDSurface, MCDRC *pRc, MCDMEM *prxExecMem, UCHAR *pStart, UCHAR *pEnd); typedef ULONG (*MCDRVCLEARFUNC)(MCDSURFACE *pMCDSurface, MCDRC *pRc, ULONG buffers); typedef ULONG (*MCDRVSWAPFUNC)(MCDSURFACE *pMCDSurface, ULONG flags); typedef ULONG (*MCDRVSTATEFUNC)(MCDSURFACE *pMCDSurface, MCDRC *pRc, MCDMEM *pMCDMem, UCHAR *pStart, LONG length, ULONG numStates); typedef ULONG (*MCDRVVIEWPORTFUNC)(MCDSURFACE *pMCDSurface, MCDRC *pRc, MCDVIEWPORT *pMCDViewport); typedef HDEV (*MCDRVGETHDEVFUNC)(MCDSURFACE *pMCDSurface); typedef ULONG (*MCDRVSPANFUNC)(MCDSURFACE *pMCDSurface, MCDRC *pRc, MCDMEM *pMCDMem, MCDSPAN *pMCDSpan, BOOL bRead); typedef VOID (*MCDRVTRACKWINDOWFUNC)(WNDOBJ *pWndObj, MCDWINDOW *pMCDWnd, ULONG flags); typedef ULONG (*MCDRVGETBUFFERSFUNC)(MCDSURFACE *pMCDSurface, MCDRC *pRc, MCDBUFFERS *pMCDBuffers); typedef ULONG (*MCDRVALLOCBUFFERSFUNC)(MCDSURFACE *pMCDSurface, MCDRC *pRc); typedef ULONG (*MCDRVBINDCONTEXTFUNC)(MCDSURFACE *pMCDSurface, MCDRC *pRc); typedef ULONG (*MCDRVSYNCFUNC)(MCDSURFACE *pMCDSurface, MCDRC *pRc); typedef ULONG (*MCDRVDRAWPIXELS)(MCDSURFACE *pMcdSurface, MCDRC *pRc, ULONG width, ULONG height, ULONG format, ULONG type, VOID *pPixels, BOOL packed); typedef ULONG (*MCDRVREADPIXELS)(MCDSURFACE *pMcdSurface, MCDRC *pRc, LONG x, LONG y, ULONG width, ULONG height, ULONG format, ULONG type, VOID *pPixels); typedef ULONG (*MCDRVCOPYPIXELS)(MCDSURFACE *pMcdSurface, MCDRC *pRc, LONG x, LONG y, ULONG width, ULONG height, ULONG type); typedef ULONG (*MCDRVPIXELMAP)(MCDSURFACE *pMcdSurface, MCDRC *pRc, ULONG mapType, ULONG mapSize, VOID *pMap); typedef struct _MCDDRIVER { ULONG ulSize; MCDRVDESCRIBEPIXELFORMATFUNC pMCDrvDescribePixelFormat; MCDRVDESCRIBELAYERPLANEFUNC pMCDrvDescribeLayerPlane; MCDRVSETLAYERPALETTEFUNC pMCDrvSetLayerPalette; MCDRVINFOFUNC pMCDrvInfo; MCDRVCREATECONTEXTFUNC pMCDrvCreateContext; MCDRVDELETECONTEXTFUNC pMCDrvDeleteContext; MCDRVBINDCONTEXTFUNC pMCDrvBindContext; MCDRVCREATETEXTUREFUNC pMCDrvCreateTexture; MCDRVDELETETEXTUREFUNC pMCDrvDeleteTexture; MCDRVUPDATESUBTEXTUREFUNC pMCDrvUpdateSubTexture; MCDRVUPDATETEXTUREPALETTEFUNC pMCDrvUpdateTexturePalette; MCDRVUPDATETEXTUREPRIORITYFUNC pMCDrvUpdateTexturePriority; MCDRVUPDATETEXTURESTATEFUNC pMCDrvUpdateTextureState; MCDRVTEXTURESTATUSFUNC pMCDrvTextureStatus; MCDRVCREATEMEMFUNC pMCDrvCreateMem; MCDRVDELETEMEMFUNC pMCDrvDeleteMem; MCDRVDRAWFUNC pMCDrvDraw; MCDRVCLEARFUNC pMCDrvClear; MCDRVSWAPFUNC pMCDrvSwap; MCDRVSTATEFUNC pMCDrvState; MCDRVVIEWPORTFUNC pMCDrvViewport; MCDRVGETHDEVFUNC pMCDrvGetHdev; MCDRVSPANFUNC pMCDrvSpan; MCDRVTRACKWINDOWFUNC pMCDrvTrackWindow; MCDRVALLOCBUFFERSFUNC pMCDrvAllocBuffers; MCDRVGETBUFFERSFUNC pMCDrvGetBuffers; MCDRVSYNCFUNC pMCDrvSync; MCDRVDRAWPIXELS pMCDrvDrawPixels; MCDRVREADPIXELS pMCDrvReadPixels; MCDRVCOPYPIXELS pMCDrvCopyPixels; MCDRVPIXELMAP pMCDrvPixelMap; } MCDDRIVER; // // Clip codes: // #define MCD_CLIP_LEFT 0x00000001 #define MCD_CLIP_RIGHT 0x00000002 #define MCD_CLIP_BOTTOM 0x00000004 #define MCD_CLIP_TOP 0x00000008 #define MCD_CLIP_NEAR 0x00000010 #define MCD_CLIP_FAR 0x00000020 #define MCD_CLIP_MASK 0x0000003f // // Vertex flags: // #define MCDVERTEX_EDGEFLAG 0x00000001 #define MCDVERTEX_FRONTFACE 0 #define MCDVERTEX_BACKFACE 1 // // Note: vertex colors are scaled to the color depths reported in the // pixel format. // typedef struct _MCDVERTEX { ULONG flags; // vertex flags MCDCOLOR *pColor; // pointer to active vertex color ULONG clipCode; // clip code MCDFLOAT fog; // fog value (0..1) MCDCOORD clipCoord; // clip-space coordinate MCDCOORD windowCoord; // window coordinate MCDCOORD texCoord; // texture coordinate MCDCOORD normal; // vertex normal MCDCOLOR colors[2]; // front and back vertex colors MCDCOORD eyeCoord; // eye coordinate } MCDVERTEX; typedef struct _MCDCOMMAND MCDCOMMAND; #define MCDCOMMAND_RESET_STIPPLE 0x00004000 #define MCDCOMMAND_RENDER_PRIMITIVE 0x00008000 #define MCDCOMMAND_SAME_COLOR 0x00040000 typedef struct _MCDCOMMAND { ULONG flags; // flags for this command MCDVERTEX *pEndVertex; ULONG reserved2; ULONG reserved3; ULONG reserved4; ULONG reserved5; MCDVERTEX *pStartVertex; ULONG reserved7; ULONG reserved8; ULONG reserved9; ULONG reserved10; ULONG reserved11; ULONG reserved12; ULONG reserved13; ULONG reserved14; ULONG command; // primitive type or command (GL_TRIANGLES, etc.) ULONG clipCodes; ULONG reserved17; ULONG reserved18; MCDCOMMAND *pNextCmd; ULONG numIndices; UCHAR *pIndices; ULONG reserved22; ULONG textureKey; } MCDCOMMAND; // Top-level (global) driver function established at DLL initialization time // through MCDEngInit(). All other driver functions are obtained through the // MCDrvGetEntryPoints funtion: typedef BOOL (*MCDRVGETENTRYPOINTSFUNC)(MCDSURFACE *pMCDSurface, MCDDRIVER *pMCDDriver); // MCD Server engine functions: #define MCDENGINITFUNCNAME "MCDEngInit" #define MCDENGESCFILTERNAME "MCDEngEscFilter" #define MCDENGSETMEMSTATUSNAME "MCDEngSetMemStatus" typedef BOOL (WINAPI *MCDENGINITFUNC)(SURFOBJ *pso, MCDRVGETENTRYPOINTSFUNC); typedef BOOL (WINAPI *MCDENGESCFILTERFUNC)(SURFOBJ *pso, ULONG iEsc, ULONG cjIn, VOID *pvIn, ULONG cjOut, VOID *pvOut, ULONG *pRetVal); typedef BOOL (WINAPI *MCDENGSETMEMSTATUSFUNC)(MCDMEM *pMCDMem, ULONG status); #endif