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.
 
 
 
 
 
 

185 lines
5.2 KiB

/*==========================================================================;
*
* Copyright (C) 1997 Microsoft Corporation. All Rights Reserved.
*
* File: d3dmem.h
* Content: Direct3D memory access include file
*
***************************************************************************/
#ifndef _D3DMEM_H_
#define _D3DMEM_H_
class DIRECT3DDEVICEI;
/*
* Register a set of functions to be used in place of malloc, realloc
* and free for memory allocation. The functions D3DMalloc, D3DRealloc
* and D3DFree will use these functions. The default is to use the
* ANSI C library routines malloc, realloc and free.
*/
typedef LPVOID (*D3DMALLOCFUNCTION)(size_t);
typedef LPVOID (*D3DREALLOCFUNCTION)(LPVOID, size_t);
typedef VOID (*D3DFREEFUNCTION)(LPVOID);
/*
* Allocate size bytes of memory and return a pointer to it in *p_return.
* Returns D3DERR_BADALLOC with *p_return unchanged if the allocation fails.
*/
HRESULT D3DAPI D3DMalloc(LPVOID* p_return, size_t size);
/*
* Change the size of an allocated block of memory. A pointer to the
* block is passed in in *p_inout. If *p_inout is NULL then a new
* block is allocated. If the reallocation is successful, *p_inout is
* changed to point to the new block. If the allocation fails,
* *p_inout is unchanged and D3DERR_BADALLOC is returned.
*/
HRESULT D3DAPI D3DRealloc(LPVOID* p_inout, size_t size);
/*
* Free a block of memory previously allocated with D3DMalloc or
* D3DRealloc.
*/
VOID D3DAPI D3DFree(LPVOID p);
HRESULT MallocAligned(void** p_return, size_t size);
void FreeAligned(void* p);
HRESULT ReallocAligned(void** p_inout, size_t size);
/* Base class for all D3D classes to use our special allocation functions everywhere */
class CD3DAlloc
{
public:
void* operator new(size_t s)
{
void *p;
MallocAligned(&p,s);
return p;
};
void operator delete(void* p)
{
FreeAligned(p);
};
};
//---------------------------------------------------------------------
// This class manages growing buffer, aligned to 32 byte boundary
// Number if bytes should be power of 2.
// D3DMalloc is used to allocate memory
//
class CAlignedBuffer32
{
public:
CAlignedBuffer32() {size = 0; allocatedBuf = 0; alignedBuf = 0;}
~CAlignedBuffer32() {if (allocatedBuf) D3DFree(allocatedBuf);}
// Returns aligned buffer address
LPVOID GetAddress() {return alignedBuf;}
// Returns aligned buffer size
DWORD GetSize() {return size;}
HRESULT Grow(DWORD dwSize);
HRESULT CheckAndGrow(DWORD dwSize)
{
if (dwSize > size)
return Grow(dwSize + 1024);
else
return D3D_OK;
}
protected:
LPVOID allocatedBuf;
LPVOID alignedBuf;
DWORD size;
};
// Forward declarations
class DIRECT3DDEVICEI;
class CDirect3DVertexBuffer;
class CDirect3DDeviceIDP2;
//----------------------------------------------------------------------
// This class manages a growing buffer using DDraw Surfaces.
class CBufferDDS
{
protected:
LPDIRECTDRAWSURFACE allocatedBuf;
LPVOID alignedBuf;
DWORD size;
public:
CBufferDDS()
{
size = 0;
allocatedBuf = 0;
alignedBuf = 0;
}
~CBufferDDS()
{
if (allocatedBuf)
allocatedBuf->Release();
}
// Returns aligned buffer address
LPVOID GetAddress()
{
return (LPBYTE)alignedBuf;
}
// Returns aligned buffer size
DWORD GetSize()
{
return size;
}
LPDIRECTDRAWSURFACE GetDDS()
{
return allocatedBuf;
}
HRESULT CheckAndGrow(DIRECT3DDEVICEI *lpDevI, DWORD dwSize)
{
if (dwSize > size)
return Grow(lpDevI, dwSize + 1024);
else
return D3D_OK;
}
HRESULT Grow(DIRECT3DDEVICEI *lpDevI, DWORD dwSize);
// define these later on in this file after CDirect3DVertexBuffer is defined
};
//----------------------------------------------------------------------
// This class manages a growing vertex buffer.
// Allocate it in driver friendly memory.
// Do not use except for DP2 DDI
class CBufferVB
{
protected:
LPDIRECT3DVERTEXBUFFER7 allocatedBuf;
LPVOID alignedBuf;
DWORD size, base;
public:
CBufferVB()
{
size = 0;
allocatedBuf = 0;
alignedBuf = 0;
base = 0;
}
~CBufferVB()
{
if (allocatedBuf)
allocatedBuf->Release();
}
// Returns aligned buffer address
LPVOID GetAddress()
{
return (LPBYTE)alignedBuf + base;
}
// Returns aligned buffer size
DWORD GetSize() { return size - base; }
HRESULT Grow(DIRECT3DDEVICEI *lpDevI, DWORD dwSize);
DWORD& Base() { return base; }
// define these later on in this file after CDirect3DVertexBuffer is defined
inline CDirect3DVertexBuffer* GetVBI();
inline LPDIRECTDRAWSURFACE GetDDS();
HRESULT CheckAndGrow(DIRECT3DDEVICEI *lpDevI, DWORD dwSize)
{
if (dwSize > size)
return Grow(lpDevI, dwSize + 1024);
else
return D3D_OK;
}
friend CDirect3DDeviceIDP2;
};
#endif