//---------------------------------------------------------------------------- // // d3dif.cpp // // shared interface functions // // Copyright (C) Microsoft Corporation, 1997. // //---------------------------------------------------------------------------- #include "pch.cpp" #pragma hdrstop //---------------------------------------------------------------------------- // // FindOutSurfFormat // // Converts a DDPIXELFORMAT to D3DI_SPANTEX_FORMAT. // //---------------------------------------------------------------------------- HRESULT FASTCALL FindOutSurfFormat(LPDDPIXELFORMAT pDdPixFmt, D3DI_SPANTEX_FORMAT *pFmt) { if (pDdPixFmt->dwFlags & DDPF_ZBUFFER) { switch(pDdPixFmt->dwZBitMask) { default: case 0x0000FFFF: *pFmt = D3DI_SPTFMT_Z16S0; break; case 0xFFFFFF00: *pFmt = D3DI_SPTFMT_Z24S8; break; case 0x0000FFFE: *pFmt = D3DI_SPTFMT_Z15S1; break; case 0xFFFFFFFF: *pFmt = D3DI_SPTFMT_Z32S0; break; } } else if (pDdPixFmt->dwFlags & DDPF_BUMPDUDV) { UINT uFmt = pDdPixFmt->dwBumpDvBitMask; switch (uFmt) { case 0x0000ff00: switch (pDdPixFmt->dwRGBBitCount) { case 24: *pFmt = D3DI_SPTFMT_U8V8L8; break; case 16: *pFmt = D3DI_SPTFMT_U8V8; break; } break; case 0x000003e0: *pFmt = D3DI_SPTFMT_U5V5L6; break; } } else if (pDdPixFmt->dwFlags & DDPF_PALETTEINDEXED8) { *pFmt = D3DI_SPTFMT_PALETTE8; } else if (pDdPixFmt->dwFlags & DDPF_PALETTEINDEXED4) { *pFmt = D3DI_SPTFMT_PALETTE4; } else if (pDdPixFmt->dwFourCC == MAKEFOURCC('U', 'Y', 'V', 'Y')) { *pFmt = D3DI_SPTFMT_UYVY; } else if (pDdPixFmt->dwFourCC == MAKEFOURCC('Y', 'U', 'Y', '2')) { *pFmt = D3DI_SPTFMT_YUY2; } else if (pDdPixFmt->dwFourCC == MAKEFOURCC('D', 'X', 'T', '1')) { *pFmt = D3DI_SPTFMT_DXT1; } else if (pDdPixFmt->dwFourCC == MAKEFOURCC('D', 'X', 'T', '2')) { *pFmt = D3DI_SPTFMT_DXT2; } else if (pDdPixFmt->dwFourCC == MAKEFOURCC('D', 'X', 'T', '3')) { *pFmt = D3DI_SPTFMT_DXT3; } else if (pDdPixFmt->dwFourCC == MAKEFOURCC('D', 'X', 'T', '4')) { *pFmt = D3DI_SPTFMT_DXT4; } else if (pDdPixFmt->dwFourCC == MAKEFOURCC('D', 'X', 'T', '5')) { *pFmt = D3DI_SPTFMT_DXT5; } else { UINT uFmt = pDdPixFmt->dwGBitMask | pDdPixFmt->dwRBitMask; if (pDdPixFmt->dwFlags & DDPF_ALPHAPIXELS) { uFmt |= pDdPixFmt->dwRGBAlphaBitMask; } switch (uFmt) { case 0x00ffff00: switch (pDdPixFmt->dwRGBBitCount) { case 32: *pFmt = D3DI_SPTFMT_B8G8R8X8; break; case 24: *pFmt = D3DI_SPTFMT_B8G8R8; break; } break; case 0xffffff00: *pFmt = D3DI_SPTFMT_B8G8R8A8; break; case 0xffe0: if (pDdPixFmt->dwFlags & DDPF_ALPHAPIXELS) { *pFmt = D3DI_SPTFMT_B5G5R5A1; } else { *pFmt = D3DI_SPTFMT_B5G6R5; } break; case 0x07fe0: *pFmt = D3DI_SPTFMT_B5G5R5; break; case 0xff0: *pFmt = D3DI_SPTFMT_B4G4R4; break; case 0xfff0: *pFmt = D3DI_SPTFMT_B4G4R4A4; break; case 0xff: *pFmt = D3DI_SPTFMT_L8; break; case 0xffff: *pFmt = D3DI_SPTFMT_L8A8; break; case 0xfc: *pFmt = D3DI_SPTFMT_B2G3R3; break; default: *pFmt = D3DI_SPTFMT_NULL; break; } } return D3D_OK; } //---------------------------------------------------------------------------- // // ValidTextureSize // // checks for power of two texture size // //---------------------------------------------------------------------------- BOOL FASTCALL ValidTextureSize(INT16 iuSize, INT16 iuShift, INT16 ivSize, INT16 ivShift) { if (iuSize == 1) { if (ivSize == 1) { return TRUE; } else { return !(ivSize & (~(1 << ivShift))); } } else { if (ivSize == 1) { return !(iuSize & (~(1 << iuShift))); } else { return (!(iuSize & (~(1 << iuShift))) && !(iuSize & (~(1 << iuShift)))); } } } //---------------------------------------------------------------------------- // // ValidMipmapSize // // Computes size of next smallest mipmap level, clamping at 1 // //---------------------------------------------------------------------------- BOOL FASTCALL ValidMipmapSize(INT16 iPreSize, INT16 iSize) { if (iPreSize == 1) { if (iSize == 1) { return TRUE; } else { return FALSE; } } else { return ((iPreSize >> 1) == iSize); } } //---------------------------------------------------------------------------- // // TextureFormats // // Returns all the texture formats supported by our rasterizer. // Right now, it's called at device creation time to fill the driver gloabl // data. // //---------------------------------------------------------------------------- #define NUM_SUPPORTED_TEXTURE_FORMATS 22 int TextureFormats(LPDDSURFACEDESC* lplpddsd, DWORD dwVersion, SW_RAST_TYPE RastType) { int i = 0; if (RastType == SW_RAST_MMX && dwVersion < 3) { static DDSURFACEDESC mmx_ddsd[1]; /* pal8 */ mmx_ddsd[i].dwSize = sizeof(mmx_ddsd[0]); mmx_ddsd[i].dwFlags = DDSD_PIXELFORMAT | DDSD_CAPS; mmx_ddsd[i].ddsCaps.dwCaps = DDSCAPS_TEXTURE; mmx_ddsd[i].ddpfPixelFormat.dwSize = sizeof(DDPIXELFORMAT); mmx_ddsd[i].ddpfPixelFormat.dwFlags = DDPF_PALETTEINDEXED8 | DDPF_RGB; mmx_ddsd[i].ddpfPixelFormat.dwRGBBitCount = 8; i++; *lplpddsd = mmx_ddsd; return i; } static DDSURFACEDESC ddsd_RGBMMX_Dev3[NUM_SUPPORTED_TEXTURE_FORMATS]; static DDSURFACEDESC ddsd_RGBMMX_Dev2[NUM_SUPPORTED_TEXTURE_FORMATS]; DDSURFACEDESC *ddsd; if (dwVersion >= 3) { ddsd = ddsd_RGBMMX_Dev3; } else { ddsd = ddsd_RGBMMX_Dev2; } /* 888 */ ddsd[i].dwSize = sizeof(ddsd[0]); ddsd[i].dwFlags = DDSD_PIXELFORMAT | DDSD_CAPS; ddsd[i].ddsCaps.dwCaps = DDSCAPS_TEXTURE; ddsd[i].ddpfPixelFormat.dwSize = sizeof(DDPIXELFORMAT); ddsd[i].ddpfPixelFormat.dwFlags = DDPF_RGB; ddsd[i].ddpfPixelFormat.dwRGBBitCount = 32; ddsd[i].ddpfPixelFormat.dwRBitMask = 0xff0000; ddsd[i].ddpfPixelFormat.dwGBitMask = 0x00ff00; ddsd[i].ddpfPixelFormat.dwBBitMask = 0x0000ff; i++; /* 8888 */ ddsd[i].dwSize = sizeof(ddsd[0]); ddsd[i].dwFlags = DDSD_PIXELFORMAT | DDSD_CAPS; ddsd[i].ddsCaps.dwCaps = DDSCAPS_TEXTURE; ddsd[i].ddpfPixelFormat.dwSize = sizeof(DDPIXELFORMAT); ddsd[i].ddpfPixelFormat.dwFlags = DDPF_RGB | DDPF_ALPHAPIXELS; ddsd[i].ddpfPixelFormat.dwRGBBitCount = 32; ddsd[i].ddpfPixelFormat.dwRGBAlphaBitMask = 0xff000000; ddsd[i].ddpfPixelFormat.dwRBitMask = 0xff0000; ddsd[i].ddpfPixelFormat.dwGBitMask = 0x00ff00; ddsd[i].ddpfPixelFormat.dwBBitMask = 0x0000ff; i++; /* 565 */ ddsd[i].dwSize = sizeof(ddsd[0]); ddsd[i].dwFlags = DDSD_PIXELFORMAT | DDSD_CAPS; ddsd[i].ddsCaps.dwCaps = DDSCAPS_TEXTURE; ddsd[i].ddpfPixelFormat.dwSize = sizeof(DDPIXELFORMAT); ddsd[i].ddpfPixelFormat.dwFlags = DDPF_RGB; ddsd[i].ddpfPixelFormat.dwRGBBitCount = 16; ddsd[i].ddpfPixelFormat.dwRBitMask = 0xf800; ddsd[i].ddpfPixelFormat.dwGBitMask = 0x07e0; ddsd[i].ddpfPixelFormat.dwBBitMask = 0x001f; i++; /* 555 */ ddsd[i].dwSize = sizeof(ddsd[0]); ddsd[i].dwFlags = DDSD_PIXELFORMAT | DDSD_CAPS; ddsd[i].ddsCaps.dwCaps = DDSCAPS_TEXTURE; ddsd[i].ddpfPixelFormat.dwSize = sizeof(DDPIXELFORMAT); ddsd[i].ddpfPixelFormat.dwFlags = DDPF_RGB; ddsd[i].ddpfPixelFormat.dwRGBBitCount = 16; ddsd[i].ddpfPixelFormat.dwRBitMask = 0x7c00; ddsd[i].ddpfPixelFormat.dwGBitMask = 0x03e0; ddsd[i].ddpfPixelFormat.dwBBitMask = 0x001f; i++; /* pal4 */ ddsd[i].dwSize = sizeof(ddsd[0]); ddsd[i].dwFlags = DDSD_PIXELFORMAT | DDSD_CAPS; ddsd[i].ddsCaps.dwCaps = DDSCAPS_TEXTURE; ddsd[i].ddpfPixelFormat.dwSize = sizeof(DDPIXELFORMAT); ddsd[i].ddpfPixelFormat.dwFlags = DDPF_PALETTEINDEXED4 | DDPF_RGB; ddsd[i].ddpfPixelFormat.dwRGBBitCount = 4; i++; /* pal8 */ ddsd[i].dwSize = sizeof(ddsd[0]); ddsd[i].dwFlags = DDSD_PIXELFORMAT | DDSD_CAPS; ddsd[i].ddsCaps.dwCaps = DDSCAPS_TEXTURE; ddsd[i].ddpfPixelFormat.dwSize = sizeof(DDPIXELFORMAT); ddsd[i].ddpfPixelFormat.dwFlags = DDPF_PALETTEINDEXED8 | DDPF_RGB; ddsd[i].ddpfPixelFormat.dwRGBBitCount = 8; i++; if (dwVersion >= 3) { /* 1555 */ ddsd[i].dwSize = sizeof(ddsd[0]); ddsd[i].dwFlags = DDSD_PIXELFORMAT | DDSD_CAPS; ddsd[i].ddsCaps.dwCaps = DDSCAPS_TEXTURE; ddsd[i].ddpfPixelFormat.dwSize = sizeof(DDPIXELFORMAT); ddsd[i].ddpfPixelFormat.dwFlags = DDPF_RGB | DDPF_ALPHAPIXELS; ddsd[i].ddpfPixelFormat.dwRGBBitCount = 16; ddsd[i].ddpfPixelFormat.dwRGBAlphaBitMask = 0x8000; ddsd[i].ddpfPixelFormat.dwRBitMask = 0x7c00; ddsd[i].ddpfPixelFormat.dwGBitMask = 0x03e0; ddsd[i].ddpfPixelFormat.dwBBitMask = 0x001f; i++; // A formats for PC98 consistency // 4444 ARGB (it is already supported by S3 Virge) ddsd[i].dwSize = sizeof(ddsd[0]); ddsd[i].dwFlags = DDSD_PIXELFORMAT | DDSD_CAPS; ddsd[i].ddsCaps.dwCaps = DDSCAPS_TEXTURE; ddsd[i].ddpfPixelFormat.dwSize = sizeof(DDPIXELFORMAT); ddsd[i].ddpfPixelFormat.dwFlags = DDPF_RGB | DDPF_ALPHAPIXELS; ddsd[i].ddpfPixelFormat.dwRGBBitCount = 16; ddsd[i].ddpfPixelFormat.dwRGBAlphaBitMask = 0xf000; ddsd[i].ddpfPixelFormat.dwRBitMask = 0x0f00; ddsd[i].ddpfPixelFormat.dwGBitMask = 0x00f0; ddsd[i].ddpfPixelFormat.dwBBitMask = 0x000f; i++; } if ((dwVersion >= 2) && (RastType == SW_RAST_REFNULL)) { // 332 8-bit RGB ddsd[i].dwSize = sizeof(ddsd[0]); ddsd[i].dwFlags = DDSD_PIXELFORMAT | DDSD_CAPS; ddsd[i].ddsCaps.dwCaps = DDSCAPS_TEXTURE; ddsd[i].ddpfPixelFormat.dwSize = sizeof(DDPIXELFORMAT); ddsd[i].ddpfPixelFormat.dwFlags = DDPF_RGB; ddsd[i].ddpfPixelFormat.dwRGBBitCount = 8; ddsd[i].ddpfPixelFormat.dwRBitMask = 0xe0; ddsd[i].ddpfPixelFormat.dwGBitMask = 0x1c; ddsd[i].ddpfPixelFormat.dwBBitMask = 0x03; i++; } if (dwVersion >= 3) { /* 8 bit luminance-only */ ddsd[i].dwSize = sizeof(ddsd[0]); ddsd[i].dwFlags = DDSD_PIXELFORMAT | DDSD_CAPS; ddsd[i].ddsCaps.dwCaps = DDSCAPS_TEXTURE; ddsd[i].ddpfPixelFormat.dwSize = sizeof(DDPIXELFORMAT); ddsd[i].ddpfPixelFormat.dwFlags = DDPF_LUMINANCE; ddsd[i].ddpfPixelFormat.dwLuminanceBitCount = 8; ddsd[i].ddpfPixelFormat.dwLuminanceBitMask = 0xff; i++; /* 16 bit alpha-luminance */ ddsd[i].dwSize = sizeof(ddsd[0]); ddsd[i].dwFlags = DDSD_PIXELFORMAT | DDSD_CAPS; ddsd[i].ddsCaps.dwCaps = DDSCAPS_TEXTURE; ddsd[i].ddpfPixelFormat.dwSize = sizeof(DDPIXELFORMAT); ddsd[i].ddpfPixelFormat.dwFlags = DDPF_LUMINANCE | DDPF_ALPHAPIXELS; ddsd[i].ddpfPixelFormat.dwLuminanceBitCount = 16; ddsd[i].ddpfPixelFormat.dwRGBAlphaBitMask = 0xff00; ddsd[i].ddpfPixelFormat.dwLuminanceBitMask = 0xff; i++; } *lplpddsd = ddsd; return i; } //---------------------------------------------------------------------------- // // ZBufferFormats // // Must return union of all the Z buffer formats supported by all rasterizers. // CreateDevice will screen out device-specific ones (i.e. ones ramp doesnt handle) later. // Called at device creation time and by DDHEL to validate software ZBuffer // creation. // //---------------------------------------------------------------------------- #define NUM_SUPPORTED_ZBUFFER_FORMATS 4 int ZBufferFormats(DDPIXELFORMAT** ppDDPF) { static DDPIXELFORMAT DDPF[NUM_SUPPORTED_ZBUFFER_FORMATS]; int i = 0; memset(&DDPF[0],0,sizeof(DDPF)); /* 16 bit Z; no stencil */ DDPF[i].dwSize = sizeof(DDPIXELFORMAT); DDPF[i].dwFlags = DDPF_ZBUFFER; DDPF[i].dwZBufferBitDepth = 16; DDPF[i].dwStencilBitDepth = 0; DDPF[i].dwZBitMask = 0xffff; DDPF[i].dwStencilBitMask = 0x0000; i++; /* 24 bit Z; 8 bit stencil */ DDPF[i].dwSize = sizeof(DDPIXELFORMAT); DDPF[i].dwFlags = DDPF_ZBUFFER | DDPF_STENCILBUFFER; DDPF[i].dwZBufferBitDepth = 32; // ZBufferBitDepth represents the total bits. Z Bits are ZBBitDepth-StencilBitDepth DDPF[i].dwStencilBitDepth = 8; DDPF[i].dwZBitMask = 0xffffff00; DDPF[i].dwStencilBitMask = 0x000000ff; i++; *ppDDPF = DDPF; return i; }