Leaked source code of windows server 2003
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

467 lines
14 KiB

//----------------------------------------------------------------------------
//
// 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;
}