Move moving things around and preparing for the next step (cached vertexloaders).
git-svn-id: https://dolphin-emu.googlecode.com/svn/trunk@957 8ced0084-cf51-0410-be5f-012b33b47a6e
This commit is contained in:
parent
bc79d22f5e
commit
2f6d41e413
|
@ -24,3 +24,6 @@ u32 arraybases[16];
|
||||||
u32 arraystrides[16];
|
u32 arraystrides[16];
|
||||||
TMatrixIndexA MatrixIndexA;
|
TMatrixIndexA MatrixIndexA;
|
||||||
TMatrixIndexB MatrixIndexB;
|
TMatrixIndexB MatrixIndexB;
|
||||||
|
TVtxDesc g_VtxDesc;
|
||||||
|
// Most games only use the first VtxAttr and simply reconfigure it all the time as needed.
|
||||||
|
VAT g_VtxAttr[8];
|
||||||
|
|
|
@ -248,4 +248,14 @@ extern u32 arraystrides[16];
|
||||||
extern TMatrixIndexA MatrixIndexA;
|
extern TMatrixIndexA MatrixIndexA;
|
||||||
extern TMatrixIndexB MatrixIndexB;
|
extern TMatrixIndexB MatrixIndexB;
|
||||||
|
|
||||||
|
struct VAT
|
||||||
|
{
|
||||||
|
UVAT_group0 g0;
|
||||||
|
UVAT_group1 g1;
|
||||||
|
UVAT_group2 g2;
|
||||||
|
};
|
||||||
|
|
||||||
|
extern TVtxDesc g_VtxDesc;
|
||||||
|
extern VAT g_VtxAttr[8];
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -55,17 +55,12 @@ enum {
|
||||||
VB_HAS_UVTEXMTXSHIFT=13,
|
VB_HAS_UVTEXMTXSHIFT=13,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
#define LOADERDECL __cdecl
|
#define LOADERDECL __cdecl
|
||||||
typedef void (LOADERDECL *TPipelineFunction)(const void *);
|
typedef void (LOADERDECL *TPipelineFunction)(const void *);
|
||||||
|
|
||||||
// This will soon be used in a cache of vertex formats, rather than used in-place.
|
|
||||||
// The implementation of this class is specific for GL/DX, so NativeVertexFormat.cpp
|
// The implementation of this class is specific for GL/DX, so NativeVertexFormat.cpp
|
||||||
// is in the respective plugin, not here in VideoCommon.
|
// is in the respective plugin, not here in VideoCommon.
|
||||||
|
|
||||||
// This class will also be split into NativeVertexFormat and VertexFormatConverter.
|
|
||||||
// VertexFormatConverters will be cached, indexed by TVtxDesc+TVtxAttr.
|
|
||||||
|
|
||||||
// Note that this class can't just invent arbitrary vertex formats out of its input -
|
// Note that this class can't just invent arbitrary vertex formats out of its input -
|
||||||
// all the data loading code must always be made compatible.
|
// all the data loading code must always be made compatible.
|
||||||
class NativeVertexFormat
|
class NativeVertexFormat
|
||||||
|
@ -84,6 +79,4 @@ public:
|
||||||
u32 m_components; // VB_HAS_X. Bitmask telling what vertex components are present.
|
u32 m_components; // VB_HAS_X. Bitmask telling what vertex components are present.
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#endif // _NATIVEVERTEXFORMAT_H
|
#endif // _NATIVEVERTEXFORMAT_H
|
||||||
|
|
|
@ -32,6 +32,9 @@ static void DoState(PointerWrap &p) {
|
||||||
p.DoArray(arraystrides, 16);
|
p.DoArray(arraystrides, 16);
|
||||||
p.Do(MatrixIndexA);
|
p.Do(MatrixIndexA);
|
||||||
p.Do(MatrixIndexB);
|
p.Do(MatrixIndexB);
|
||||||
|
p.Do(g_VtxDesc.Hex);
|
||||||
|
p.DoArray(g_VtxAttr, 8);
|
||||||
|
|
||||||
// XF Memory
|
// XF Memory
|
||||||
p.Do(xfregs);
|
p.Do(xfregs);
|
||||||
p.DoArray(xfmem, XFMEM_SIZE);
|
p.DoArray(xfmem, XFMEM_SIZE);
|
||||||
|
|
|
@ -79,7 +79,7 @@ void CVertexHandler::Shutdown()
|
||||||
void CVertexHandler::CreateDeviceObjects()
|
void CVertexHandler::CreateDeviceObjects()
|
||||||
{
|
{
|
||||||
HRESULT hr;
|
HRESULT hr;
|
||||||
if( FAILED( hr = D3D::dev->CreateVertexDeclaration( decl, &vDecl) ) )
|
if (FAILED(hr = D3D::dev->CreateVertexDeclaration(decl, &vDecl)))
|
||||||
{
|
{
|
||||||
MessageBox(0,"Failed to create vertex declaration","sdfsd",0);
|
MessageBox(0,"Failed to create vertex declaration","sdfsd",0);
|
||||||
return;
|
return;
|
||||||
|
@ -96,7 +96,7 @@ void CVertexHandler::DestroyDeviceObjects()
|
||||||
{
|
{
|
||||||
if (vDecl)
|
if (vDecl)
|
||||||
vDecl->Release();
|
vDecl->Release();
|
||||||
vDecl=0;
|
vDecl = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -139,8 +139,7 @@ bool FifoCommandRunnable()
|
||||||
{
|
{
|
||||||
iCommandSize = 1 + 2;
|
iCommandSize = 1 + 2;
|
||||||
u16 numVertices = DataPeek16(1);
|
u16 numVertices = DataPeek16(1);
|
||||||
VertexLoader& vtxLoader = g_VertexLoaders[Cmd & GX_VAT_MASK];
|
iCommandSize += numVertices * VertexLoaderManager::GetVertexSize(Cmd & GX_VAT_MASK);
|
||||||
iCommandSize += numVertices * vtxLoader.ComputeVertexSize();
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
|
|
@ -80,7 +80,6 @@ int frameCount;
|
||||||
|
|
||||||
void HandleCgError(CGcontext ctx, CGerror err, void* appdata);
|
void HandleCgError(CGcontext ctx, CGerror err, void* appdata);
|
||||||
|
|
||||||
|
|
||||||
bool Renderer::Create2()
|
bool Renderer::Create2()
|
||||||
{
|
{
|
||||||
bool bSuccess = true;
|
bool bSuccess = true;
|
||||||
|
@ -189,7 +188,7 @@ bool Renderer::Create2()
|
||||||
int nMaxMRT = 0;
|
int nMaxMRT = 0;
|
||||||
glGetIntegerv(GL_MAX_COLOR_ATTACHMENTS_EXT, (GLint *)&nMaxMRT);
|
glGetIntegerv(GL_MAX_COLOR_ATTACHMENTS_EXT, (GLint *)&nMaxMRT);
|
||||||
|
|
||||||
if( nMaxMRT > 1 ) {
|
if (nMaxMRT > 1) {
|
||||||
// create zbuffer target
|
// create zbuffer target
|
||||||
glGenTextures(1, (GLuint *)&s_ZBufferTarget);
|
glGenTextures(1, (GLuint *)&s_ZBufferTarget);
|
||||||
glBindTexture(GL_TEXTURE_RECTANGLE_ARB, s_ZBufferTarget);
|
glBindTexture(GL_TEXTURE_RECTANGLE_ARB, s_ZBufferTarget);
|
||||||
|
@ -210,11 +209,12 @@ bool Renderer::Create2()
|
||||||
glGenRenderbuffersEXT( 1, (GLuint *)&s_DepthTarget);
|
glGenRenderbuffersEXT( 1, (GLuint *)&s_DepthTarget);
|
||||||
glBindRenderbufferEXT(GL_RENDERBUFFER_EXT, s_DepthTarget);
|
glBindRenderbufferEXT(GL_RENDERBUFFER_EXT, s_DepthTarget);
|
||||||
glRenderbufferStorageEXT(GL_RENDERBUFFER_EXT, GL_DEPTH24_STENCIL8_EXT, nBackbufferWidth, nBackbufferHeight);
|
glRenderbufferStorageEXT(GL_RENDERBUFFER_EXT, GL_DEPTH24_STENCIL8_EXT, nBackbufferWidth, nBackbufferHeight);
|
||||||
if( glGetError() != GL_NO_ERROR ) {
|
if (glGetError() != GL_NO_ERROR) {
|
||||||
glRenderbufferStorageEXT(GL_RENDERBUFFER_EXT, GL_DEPTH_COMPONENT, nBackbufferWidth, nBackbufferHeight);
|
glRenderbufferStorageEXT(GL_RENDERBUFFER_EXT, GL_DEPTH_COMPONENT, nBackbufferWidth, nBackbufferHeight);
|
||||||
s_bHaveStencilBuffer = false;
|
s_bHaveStencilBuffer = false;
|
||||||
|
} else {
|
||||||
|
s_bHaveStencilBuffer = true;
|
||||||
}
|
}
|
||||||
else s_bHaveStencilBuffer = true;
|
|
||||||
|
|
||||||
GL_REPORT_ERROR();
|
GL_REPORT_ERROR();
|
||||||
|
|
||||||
|
@ -223,7 +223,7 @@ bool Renderer::Create2()
|
||||||
glFramebufferRenderbufferEXT( GL_FRAMEBUFFER_EXT, GL_DEPTH_ATTACHMENT_EXT, GL_RENDERBUFFER_EXT, s_DepthTarget );
|
glFramebufferRenderbufferEXT( GL_FRAMEBUFFER_EXT, GL_DEPTH_ATTACHMENT_EXT, GL_RENDERBUFFER_EXT, s_DepthTarget );
|
||||||
GL_REPORT_ERROR();
|
GL_REPORT_ERROR();
|
||||||
|
|
||||||
if( s_ZBufferTarget != 0 ) {
|
if (s_ZBufferTarget != 0) {
|
||||||
// test to make sure it works
|
// test to make sure it works
|
||||||
glFramebufferTexture2DEXT( GL_FRAMEBUFFER_EXT, GL_COLOR_ATTACHMENT1_EXT, GL_TEXTURE_RECTANGLE_ARB, s_ZBufferTarget, 0);
|
glFramebufferTexture2DEXT( GL_FRAMEBUFFER_EXT, GL_COLOR_ATTACHMENT1_EXT, GL_TEXTURE_RECTANGLE_ARB, s_ZBufferTarget, 0);
|
||||||
bool bFailed = glGetError() != GL_NO_ERROR || glCheckFramebufferStatusEXT(GL_FRAMEBUFFER_EXT) != GL_FRAMEBUFFER_COMPLETE_EXT;
|
bool bFailed = glGetError() != GL_NO_ERROR || glCheckFramebufferStatusEXT(GL_FRAMEBUFFER_EXT) != GL_FRAMEBUFFER_COMPLETE_EXT;
|
||||||
|
@ -235,7 +235,7 @@ bool Renderer::Create2()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if( s_ZBufferTarget == 0 )
|
if (s_ZBufferTarget == 0)
|
||||||
ERROR_LOG("disabling ztarget mrt feature (max mrt=%d)\n", nMaxMRT);
|
ERROR_LOG("disabling ztarget mrt feature (max mrt=%d)\n", nMaxMRT);
|
||||||
|
|
||||||
//glFramebufferRenderbufferEXT(GL_FRAMEBUFFER_EXT, GL_STENCIL_ATTACHMENT_EXT, GL_RENDERBUFFER_EXT, s_DepthTarget );
|
//glFramebufferRenderbufferEXT(GL_FRAMEBUFFER_EXT, GL_STENCIL_ATTACHMENT_EXT, GL_RENDERBUFFER_EXT, s_DepthTarget );
|
||||||
|
@ -244,7 +244,8 @@ bool Renderer::Create2()
|
||||||
nZBufferRender = 0;
|
nZBufferRender = 0;
|
||||||
|
|
||||||
GL_REPORT_ERROR();
|
GL_REPORT_ERROR();
|
||||||
if (err != GL_NO_ERROR) bSuccess = false;
|
if (err != GL_NO_ERROR)
|
||||||
|
bSuccess = false;
|
||||||
|
|
||||||
s_pfont = new RasterFont();
|
s_pfont = new RasterFont();
|
||||||
|
|
||||||
|
@ -290,7 +291,6 @@ bool Renderer::Create2()
|
||||||
//glEnable(GL_POLYGON_OFFSET_FILL);
|
//glEnable(GL_POLYGON_OFFSET_FILL);
|
||||||
//glEnable(GL_POLYGON_OFFSET_LINE);
|
//glEnable(GL_POLYGON_OFFSET_LINE);
|
||||||
//glPolygonOffset(0, 1);
|
//glPolygonOffset(0, 1);
|
||||||
|
|
||||||
if (!Initialize())
|
if (!Initialize())
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
|
@ -329,7 +329,7 @@ bool Renderer::Initialize()
|
||||||
glStencilFunc(GL_ALWAYS, 0, 0);
|
glStencilFunc(GL_ALWAYS, 0, 0);
|
||||||
glBlendFunc(GL_ONE, GL_ONE);
|
glBlendFunc(GL_ONE, GL_ONE);
|
||||||
|
|
||||||
glViewport(0,0,GetTargetWidth(),GetTargetHeight()); // Reset The Current Viewport
|
glViewport(0, 0, GetTargetWidth(), GetTargetHeight()); // Reset The Current Viewport
|
||||||
|
|
||||||
glMatrixMode(GL_PROJECTION);
|
glMatrixMode(GL_PROJECTION);
|
||||||
glLoadIdentity();
|
glLoadIdentity();
|
||||||
|
@ -345,10 +345,9 @@ bool Renderer::Initialize()
|
||||||
|
|
||||||
glHint(GL_PERSPECTIVE_CORRECTION_HINT, GL_NICEST); // perspective correct interpolation of colors and tex coords
|
glHint(GL_PERSPECTIVE_CORRECTION_HINT, GL_NICEST); // perspective correct interpolation of colors and tex coords
|
||||||
|
|
||||||
// setup the default vertex declaration
|
|
||||||
glDisable(GL_STENCIL_TEST);
|
glDisable(GL_STENCIL_TEST);
|
||||||
glEnable(GL_SCISSOR_TEST);
|
glEnable(GL_SCISSOR_TEST);
|
||||||
glScissor(0,0,nBackbufferWidth,nBackbufferHeight);
|
glScissor(0, 0, nBackbufferWidth, nBackbufferHeight);
|
||||||
glBlendColorEXT(0, 0, 0, 0.5f);
|
glBlendColorEXT(0, 0, 0, 0.5f);
|
||||||
glClearDepth(1.0f);
|
glClearDepth(1.0f);
|
||||||
|
|
||||||
|
@ -357,12 +356,10 @@ bool Renderer::Initialize()
|
||||||
glMatrixMode(GL_MODELVIEW);
|
glMatrixMode(GL_MODELVIEW);
|
||||||
glLoadIdentity();
|
glLoadIdentity();
|
||||||
|
|
||||||
//Renderer::SetZBufferRender();
|
// legacy multitexturing: select texture channel only.
|
||||||
|
|
||||||
// legacy multitexturing: select texture channel only
|
|
||||||
glActiveTexture(GL_TEXTURE0);
|
glActiveTexture(GL_TEXTURE0);
|
||||||
glClientActiveTexture(GL_TEXTURE0);
|
glClientActiveTexture(GL_TEXTURE0);
|
||||||
glTexEnvf( GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, GL_REPLACE );
|
glTexEnvf(GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, GL_REPLACE);
|
||||||
|
|
||||||
s_RenderMode = Renderer::RM_Normal;
|
s_RenderMode = Renderer::RM_Normal;
|
||||||
|
|
||||||
|
@ -499,7 +496,7 @@ void Renderer::SetDepthTarget(u32 targ)
|
||||||
|
|
||||||
void Renderer::SetFramebuffer(u32 fb)
|
void Renderer::SetFramebuffer(u32 fb)
|
||||||
{
|
{
|
||||||
glBindFramebufferEXT( GL_FRAMEBUFFER_EXT, fb != 0 ? fb : s_uFramebuffer );
|
glBindFramebufferEXT(GL_FRAMEBUFFER_EXT, fb != 0 ? fb : s_uFramebuffer);
|
||||||
}
|
}
|
||||||
|
|
||||||
u32 Renderer::GetRenderTarget()
|
u32 Renderer::GetRenderTarget()
|
||||||
|
@ -516,21 +513,21 @@ void Renderer::ResetGLState()
|
||||||
glDepthMask(GL_FALSE);
|
glDepthMask(GL_FALSE);
|
||||||
glColorMask(GL_TRUE, GL_TRUE, GL_TRUE, GL_TRUE);
|
glColorMask(GL_TRUE, GL_TRUE, GL_TRUE, GL_TRUE);
|
||||||
|
|
||||||
glDisable( GL_VERTEX_PROGRAM_ARB );
|
glDisable(GL_VERTEX_PROGRAM_ARB);
|
||||||
glDisable( GL_FRAGMENT_PROGRAM_ARB );
|
glDisable(GL_FRAGMENT_PROGRAM_ARB);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Renderer::RestoreGLState()
|
void Renderer::RestoreGLState()
|
||||||
{
|
{
|
||||||
glEnable(GL_SCISSOR_TEST);
|
glEnable(GL_SCISSOR_TEST);
|
||||||
|
|
||||||
if (bpmem.genMode.cullmode>0) glEnable(GL_CULL_FACE);
|
if (bpmem.genMode.cullmode > 0) glEnable(GL_CULL_FACE);
|
||||||
if (bpmem.zmode.testenable) glEnable(GL_DEPTH_TEST);
|
if (bpmem.zmode.testenable) glEnable(GL_DEPTH_TEST);
|
||||||
if (bpmem.blendmode.blendenable) glEnable(GL_BLEND);
|
if (bpmem.blendmode.blendenable) glEnable(GL_BLEND);
|
||||||
if(bpmem.zmode.updateenable) glDepthMask(GL_TRUE);
|
if(bpmem.zmode.updateenable) glDepthMask(GL_TRUE);
|
||||||
|
|
||||||
glEnable( GL_VERTEX_PROGRAM_ARB );
|
glEnable(GL_VERTEX_PROGRAM_ARB);
|
||||||
glEnable( GL_FRAGMENT_PROGRAM_ARB );
|
glEnable(GL_FRAGMENT_PROGRAM_ARB);
|
||||||
SetColorMask();
|
SetColorMask();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -547,9 +544,12 @@ bool Renderer::HaveStencilBuffer()
|
||||||
void Renderer::SetZBufferRender()
|
void Renderer::SetZBufferRender()
|
||||||
{
|
{
|
||||||
nZBufferRender = 10; // give it 10 frames
|
nZBufferRender = 10; // give it 10 frames
|
||||||
GLenum s_drawbuffers[2] = {GL_COLOR_ATTACHMENT0_EXT, GL_COLOR_ATTACHMENT1_EXT};
|
GLenum s_drawbuffers[2] = {
|
||||||
|
GL_COLOR_ATTACHMENT0_EXT,
|
||||||
|
GL_COLOR_ATTACHMENT1_EXT
|
||||||
|
};
|
||||||
glDrawBuffers(2, s_drawbuffers);
|
glDrawBuffers(2, s_drawbuffers);
|
||||||
glFramebufferTexture2DEXT( GL_FRAMEBUFFER_EXT, GL_COLOR_ATTACHMENT1_EXT, GL_TEXTURE_RECTANGLE_ARB, s_ZBufferTarget, 0);
|
glFramebufferTexture2DEXT(GL_FRAMEBUFFER_EXT, GL_COLOR_ATTACHMENT1_EXT, GL_TEXTURE_RECTANGLE_ARB, s_ZBufferTarget, 0);
|
||||||
_assert_(glCheckFramebufferStatusEXT(GL_FRAMEBUFFER_EXT) == GL_FRAMEBUFFER_COMPLETE_EXT);
|
_assert_(glCheckFramebufferStatusEXT(GL_FRAMEBUFFER_EXT) == GL_FRAMEBUFFER_COMPLETE_EXT);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -568,7 +568,8 @@ void Renderer::FlushZBufferAlphaToTarget()
|
||||||
glBindTexture(GL_TEXTURE_RECTANGLE_ARB, s_ZBufferTarget);
|
glBindTexture(GL_TEXTURE_RECTANGLE_ARB, s_ZBufferTarget);
|
||||||
TextureMngr::EnableTexRECT(0);
|
TextureMngr::EnableTexRECT(0);
|
||||||
// disable all other stages
|
// disable all other stages
|
||||||
for(int i = 1; i < 8; ++i) TextureMngr::DisableStage(i);
|
for(int i = 1; i < 8; ++i)
|
||||||
|
TextureMngr::DisableStage(i);
|
||||||
GL_REPORT_ERRORD();
|
GL_REPORT_ERRORD();
|
||||||
|
|
||||||
if(g_Config.bStretchToFit)
|
if(g_Config.bStretchToFit)
|
||||||
|
@ -612,13 +613,13 @@ void Renderer::FlushZBufferAlphaToTarget()
|
||||||
|
|
||||||
void Renderer::SetRenderMode(RenderMode mode)
|
void Renderer::SetRenderMode(RenderMode mode)
|
||||||
{
|
{
|
||||||
if( !s_bHaveStencilBuffer && mode == RM_ZBufferAlpha )
|
if (!s_bHaveStencilBuffer && mode == RM_ZBufferAlpha)
|
||||||
mode = RM_ZBufferOnly;
|
mode = RM_ZBufferOnly;
|
||||||
|
|
||||||
if( s_RenderMode == mode )
|
if (s_RenderMode == mode)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if( mode == RM_Normal ) {
|
if (mode == RM_Normal) {
|
||||||
// flush buffers
|
// flush buffers
|
||||||
if( s_RenderMode == RM_ZBufferAlpha ) {
|
if( s_RenderMode == RM_ZBufferAlpha ) {
|
||||||
FlushZBufferAlphaToTarget();
|
FlushZBufferAlphaToTarget();
|
||||||
|
@ -629,7 +630,7 @@ void Renderer::SetRenderMode(RenderMode mode)
|
||||||
SetZBufferRender();
|
SetZBufferRender();
|
||||||
GL_REPORT_ERRORD();
|
GL_REPORT_ERRORD();
|
||||||
}
|
}
|
||||||
else if( s_RenderMode == RM_Normal ) {
|
else if (s_RenderMode == RM_Normal) {
|
||||||
// setup buffers
|
// setup buffers
|
||||||
_assert_(GetZBufferTarget() && bpmem.zmode.updateenable);
|
_assert_(GetZBufferTarget() && bpmem.zmode.updateenable);
|
||||||
|
|
||||||
|
@ -741,16 +742,12 @@ void Renderer::SwapBuffers()
|
||||||
fpscount = 0;
|
fpscount = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// ---------------------------------------------------------------------------------------
|
|
||||||
// Write logging data to debugger
|
// Write logging data to debugger
|
||||||
// -----------------
|
|
||||||
if(m_frame)
|
if(m_frame)
|
||||||
{
|
{
|
||||||
Logging(0);
|
Logging(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
if (g_Config.bOverlayStats) {
|
if (g_Config.bOverlayStats) {
|
||||||
char st[2048];
|
char st[2048];
|
||||||
char *p = st;
|
char *p = st;
|
||||||
|
@ -822,15 +819,12 @@ void Renderer::SwapBuffers()
|
||||||
|
|
||||||
glBindFramebufferEXT( GL_FRAMEBUFFER_EXT, s_uFramebuffer );
|
glBindFramebufferEXT( GL_FRAMEBUFFER_EXT, s_uFramebuffer );
|
||||||
|
|
||||||
// s_nCurTarget = !s_nCurTarget;
|
if (nZBufferRender > 0) {
|
||||||
// SetRenderTarget(0);
|
if (--nZBufferRender == 0) {
|
||||||
|
|
||||||
if( nZBufferRender > 0 ) {
|
|
||||||
if( --nZBufferRender == 0 ) {
|
|
||||||
// turn off
|
// turn off
|
||||||
nZBufferRender = 0;
|
nZBufferRender = 0;
|
||||||
glDrawBuffer(GL_COLOR_ATTACHMENT0_EXT);
|
glDrawBuffer(GL_COLOR_ATTACHMENT0_EXT);
|
||||||
glFramebufferTexture2DEXT( GL_FRAMEBUFFER_EXT, GL_COLOR_ATTACHMENT1_EXT, GL_TEXTURE_RECTANGLE_ARB, 0, 0);
|
glFramebufferTexture2DEXT(GL_FRAMEBUFFER_EXT, GL_COLOR_ATTACHMENT1_EXT, GL_TEXTURE_RECTANGLE_ARB, 0, 0);
|
||||||
Renderer::SetRenderMode(RM_Normal); // turn off any zwrites
|
Renderer::SetRenderMode(RM_Normal); // turn off any zwrites
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -839,7 +833,7 @@ void Renderer::SwapBuffers()
|
||||||
bool Renderer::SaveRenderTarget(const char* filename, int jpeg)
|
bool Renderer::SaveRenderTarget(const char* filename, int jpeg)
|
||||||
{
|
{
|
||||||
bool bflip = true;
|
bool bflip = true;
|
||||||
std::vector<u32> data(nBackbufferWidth*nBackbufferHeight);
|
std::vector<u32> data(nBackbufferWidth * nBackbufferHeight);
|
||||||
glReadPixels(0, 0, nBackbufferWidth, nBackbufferHeight, GL_BGRA, GL_UNSIGNED_BYTE, &data[0]);
|
glReadPixels(0, 0, nBackbufferWidth, nBackbufferHeight, GL_BGRA, GL_UNSIGNED_BYTE, &data[0]);
|
||||||
if (glGetError() != GL_NO_ERROR)
|
if (glGetError() != GL_NO_ERROR)
|
||||||
return false;
|
return false;
|
||||||
|
@ -865,8 +859,9 @@ void Renderer::SetCgErrorOutput(bool bOutput)
|
||||||
void HandleGLError()
|
void HandleGLError()
|
||||||
{
|
{
|
||||||
const GLubyte* pstr = glGetString(GL_PROGRAM_ERROR_STRING_ARB);
|
const GLubyte* pstr = glGetString(GL_PROGRAM_ERROR_STRING_ARB);
|
||||||
if (pstr != NULL && pstr[0] != 0 ) {
|
if (pstr != NULL && pstr[0] != 0)
|
||||||
GLint loc=0;
|
{
|
||||||
|
GLint loc = 0;
|
||||||
glGetIntegerv(GL_PROGRAM_ERROR_POSITION_ARB, &loc);
|
glGetIntegerv(GL_PROGRAM_ERROR_POSITION_ARB, &loc);
|
||||||
ERROR_LOG("program error at %d: ", loc);
|
ERROR_LOG("program error at %d: ", loc);
|
||||||
ERROR_LOG((char*)pstr);
|
ERROR_LOG((char*)pstr);
|
||||||
|
@ -877,12 +872,14 @@ void HandleGLError()
|
||||||
GLenum error = glCheckFramebufferStatusEXT(GL_FRAMEBUFFER_EXT);
|
GLenum error = glCheckFramebufferStatusEXT(GL_FRAMEBUFFER_EXT);
|
||||||
|
|
||||||
// if error != GL_FRAMEBUFFER_COMPLETE_EXT, there's an error of some sort
|
// if error != GL_FRAMEBUFFER_COMPLETE_EXT, there's an error of some sort
|
||||||
if (error != 0) {
|
if (!error)
|
||||||
int w, h;
|
return;
|
||||||
GLint fmt;
|
|
||||||
glGetRenderbufferParameterivEXT(GL_COLOR_ATTACHMENT0_EXT, GL_RENDERBUFFER_INTERNAL_FORMAT_EXT, &fmt);
|
// int w, h;
|
||||||
glGetRenderbufferParameterivEXT(GL_COLOR_ATTACHMENT0_EXT, GL_RENDERBUFFER_WIDTH_EXT, (GLint *)&w);
|
// GLint fmt;
|
||||||
glGetRenderbufferParameterivEXT(GL_COLOR_ATTACHMENT0_EXT, GL_RENDERBUFFER_HEIGHT_EXT, (GLint *)&h);
|
// glGetRenderbufferParameterivEXT(GL_COLOR_ATTACHMENT0_EXT, GL_RENDERBUFFER_INTERNAL_FORMAT_EXT, &fmt);
|
||||||
|
// glGetRenderbufferParameterivEXT(GL_COLOR_ATTACHMENT0_EXT, GL_RENDERBUFFER_WIDTH_EXT, (GLint *)&w);
|
||||||
|
// glGetRenderbufferParameterivEXT(GL_COLOR_ATTACHMENT0_EXT, GL_RENDERBUFFER_HEIGHT_EXT, (GLint *)&h);
|
||||||
|
|
||||||
switch(error)
|
switch(error)
|
||||||
{
|
{
|
||||||
|
@ -916,12 +913,12 @@ void HandleGLError()
|
||||||
ERROR_LOG("*UNKNOWN ERROR* reported from glCheckFramebufferStatusEXT()!\n");
|
ERROR_LOG("*UNKNOWN ERROR* reported from glCheckFramebufferStatusEXT()!\n");
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void HandleCgError(CGcontext ctx, CGerror err, void* appdata)
|
void HandleCgError(CGcontext ctx, CGerror err, void* appdata)
|
||||||
{
|
{
|
||||||
if( s_bOutputCgErrors ) {
|
if (s_bOutputCgErrors)
|
||||||
|
{
|
||||||
ERROR_LOG("Cg error: %s\n", cgGetErrorString(err));
|
ERROR_LOG("Cg error: %s\n", cgGetErrorString(err));
|
||||||
const char* listing = cgGetLastListing(g_cgcontext);
|
const char* listing = cgGetLastListing(g_cgcontext);
|
||||||
if (listing != NULL) {
|
if (listing != NULL) {
|
||||||
|
|
|
@ -110,8 +110,6 @@ void LOADERDECL TexMtx_Write_Short3(const void *_p)
|
||||||
#include "VertexLoader_Color.h"
|
#include "VertexLoader_Color.h"
|
||||||
#include "VertexLoader_TextCoord.h"
|
#include "VertexLoader_TextCoord.h"
|
||||||
|
|
||||||
VertexLoader g_VertexLoaders[8];
|
|
||||||
|
|
||||||
VertexLoader::VertexLoader()
|
VertexLoader::VertexLoader()
|
||||||
{
|
{
|
||||||
m_VertexSize = 0;
|
m_VertexSize = 0;
|
||||||
|
@ -128,15 +126,15 @@ int VertexLoader::ComputeVertexSize()
|
||||||
{
|
{
|
||||||
if (m_AttrDirty == AD_CLEAN) {
|
if (m_AttrDirty == AD_CLEAN) {
|
||||||
// Compare the 33 desc bits.
|
// Compare the 33 desc bits.
|
||||||
if (m_VtxDesc.Hex0 == GetVtxDesc().Hex0 &&
|
if (m_VtxDesc.Hex0 == g_VtxDesc.Hex0 &&
|
||||||
(m_VtxDesc.Hex1 & 1) == (GetVtxDesc().Hex1 & 1))
|
(m_VtxDesc.Hex1 & 1) == (g_VtxDesc.Hex1 & 1))
|
||||||
return m_VertexSize;
|
return m_VertexSize;
|
||||||
|
|
||||||
m_VtxDesc.Hex = GetVtxDesc().Hex;
|
m_VtxDesc.Hex = g_VtxDesc.Hex;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
// Attributes are dirty so we have to recompute everything anyway.
|
// Attributes are dirty so we have to recompute everything anyway.
|
||||||
m_VtxDesc.Hex = GetVtxDesc().Hex;
|
m_VtxDesc.Hex = g_VtxDesc.Hex;
|
||||||
}
|
}
|
||||||
|
|
||||||
m_AttrDirty = AD_DIRTY;
|
m_AttrDirty = AD_DIRTY;
|
||||||
|
@ -245,13 +243,13 @@ int VertexLoader::ComputeVertexSize()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void VertexLoader::PrepareForVertexFormat()
|
void VertexLoader::CompileVertexTranslator()
|
||||||
{
|
{
|
||||||
if (m_AttrDirty == AD_CLEAN)
|
if (m_AttrDirty == AD_CLEAN)
|
||||||
{
|
{
|
||||||
// Check if local cached desc (in this VL) matches global desc
|
// Check if local cached desc (in this VL) matches global desc
|
||||||
if (m_VtxDesc.Hex0 == GetVtxDesc().Hex0 &&
|
if (m_VtxDesc.Hex0 == g_VtxDesc.Hex0 &&
|
||||||
(m_VtxDesc.Hex1 & 1) == (GetVtxDesc().Hex1 & 1))
|
(m_VtxDesc.Hex1 & 1) == (g_VtxDesc.Hex1 & 1))
|
||||||
{
|
{
|
||||||
return; // same
|
return; // same
|
||||||
}
|
}
|
||||||
|
@ -261,7 +259,7 @@ void VertexLoader::PrepareForVertexFormat()
|
||||||
m_AttrDirty = AD_CLEAN;
|
m_AttrDirty = AD_CLEAN;
|
||||||
}
|
}
|
||||||
|
|
||||||
m_VtxDesc.Hex = GetVtxDesc().Hex;
|
m_VtxDesc.Hex = g_VtxDesc.Hex;
|
||||||
|
|
||||||
// Reset pipeline
|
// Reset pipeline
|
||||||
m_numPipelineStages = 0;
|
m_numPipelineStages = 0;
|
||||||
|
@ -525,9 +523,9 @@ void VertexLoader::RunVertices(int primitive, int count)
|
||||||
if (g_nativeVertexFmt != NULL && g_nativeVertexFmt != &m_NativeFmt)
|
if (g_nativeVertexFmt != NULL && g_nativeVertexFmt != &m_NativeFmt)
|
||||||
{
|
{
|
||||||
VertexManager::Flush();
|
VertexManager::Flush();
|
||||||
|
|
||||||
// Also move the Set() here?
|
// Also move the Set() here?
|
||||||
}
|
}
|
||||||
|
g_nativeVertexFmt = &m_NativeFmt;
|
||||||
|
|
||||||
// This has dirty handling - won't actually recompute unless necessary.
|
// This has dirty handling - won't actually recompute unless necessary.
|
||||||
ComputeVertexSize();
|
ComputeVertexSize();
|
||||||
|
@ -540,9 +538,7 @@ void VertexLoader::RunVertices(int primitive, int count)
|
||||||
}
|
}
|
||||||
|
|
||||||
// This has dirty handling - won't actually recompute unless necessary.
|
// This has dirty handling - won't actually recompute unless necessary.
|
||||||
PrepareForVertexFormat();
|
CompileVertexTranslator();
|
||||||
|
|
||||||
g_nativeVertexFmt = &m_NativeFmt;
|
|
||||||
|
|
||||||
VertexManager::EnableComponents(m_NativeFmt.m_components);
|
VertexManager::EnableComponents(m_NativeFmt.m_components);
|
||||||
|
|
||||||
|
@ -646,3 +642,66 @@ void VertexLoader::RunPipelineOnce() const
|
||||||
for (int i = 0; i < m_numPipelineStages; i++)
|
for (int i = 0; i < m_numPipelineStages; i++)
|
||||||
m_PipelineStages[i](&m_VtxAttr);
|
m_PipelineStages[i](&m_VtxAttr);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void VertexLoader::SetVAT_group0(u32 _group0)
|
||||||
|
{
|
||||||
|
// ignore frac bits - we don't need to recompute if all that's changed was the frac bits.
|
||||||
|
if ((m_group0.Hex & ~VAT_0_FRACBITS) != (_group0 & ~VAT_0_FRACBITS)) {
|
||||||
|
m_AttrDirty = AD_VAT_DIRTY;
|
||||||
|
}
|
||||||
|
m_group0.Hex = _group0;
|
||||||
|
|
||||||
|
m_VtxAttr.PosElements = m_group0.PosElements;
|
||||||
|
m_VtxAttr.PosFormat = m_group0.PosFormat;
|
||||||
|
m_VtxAttr.PosFrac = m_group0.PosFrac;
|
||||||
|
m_VtxAttr.NormalElements = m_group0.NormalElements;
|
||||||
|
m_VtxAttr.NormalFormat = m_group0.NormalFormat;
|
||||||
|
m_VtxAttr.color[0].Elements = m_group0.Color0Elements;
|
||||||
|
m_VtxAttr.color[0].Comp = m_group0.Color0Comp;
|
||||||
|
m_VtxAttr.color[1].Elements = m_group0.Color1Elements;
|
||||||
|
m_VtxAttr.color[1].Comp = m_group0.Color1Comp;
|
||||||
|
m_VtxAttr.texCoord[0].Elements = m_group0.Tex0CoordElements;
|
||||||
|
m_VtxAttr.texCoord[0].Format = m_group0.Tex0CoordFormat;
|
||||||
|
m_VtxAttr.texCoord[0].Frac = m_group0.Tex0Frac;
|
||||||
|
m_VtxAttr.ByteDequant = m_group0.ByteDequant;
|
||||||
|
m_VtxAttr.NormalIndex3 = m_group0.NormalIndex3;
|
||||||
|
};
|
||||||
|
|
||||||
|
void VertexLoader::SetVAT_group1(u32 _group1)
|
||||||
|
{
|
||||||
|
if ((m_group1.Hex & ~VAT_1_FRACBITS) != (_group1 & ~VAT_1_FRACBITS)) {
|
||||||
|
m_AttrDirty = AD_VAT_DIRTY;
|
||||||
|
}
|
||||||
|
m_group1.Hex = _group1;
|
||||||
|
|
||||||
|
m_VtxAttr.texCoord[1].Elements = m_group1.Tex1CoordElements;
|
||||||
|
m_VtxAttr.texCoord[1].Format = m_group1.Tex1CoordFormat;
|
||||||
|
m_VtxAttr.texCoord[1].Frac = m_group1.Tex1Frac;
|
||||||
|
m_VtxAttr.texCoord[2].Elements = m_group1.Tex2CoordElements;
|
||||||
|
m_VtxAttr.texCoord[2].Format = m_group1.Tex2CoordFormat;
|
||||||
|
m_VtxAttr.texCoord[2].Frac = m_group1.Tex2Frac;
|
||||||
|
m_VtxAttr.texCoord[3].Elements = m_group1.Tex3CoordElements;
|
||||||
|
m_VtxAttr.texCoord[3].Format = m_group1.Tex3CoordFormat;
|
||||||
|
m_VtxAttr.texCoord[3].Frac = m_group1.Tex3Frac;
|
||||||
|
m_VtxAttr.texCoord[4].Elements = m_group1.Tex4CoordElements;
|
||||||
|
m_VtxAttr.texCoord[4].Format = m_group1.Tex4CoordFormat;
|
||||||
|
};
|
||||||
|
|
||||||
|
void VertexLoader::SetVAT_group2(u32 _group2)
|
||||||
|
{
|
||||||
|
if ((m_group2.Hex & ~VAT_2_FRACBITS) != (_group2 & ~VAT_2_FRACBITS)) {
|
||||||
|
m_AttrDirty = AD_VAT_DIRTY;
|
||||||
|
}
|
||||||
|
m_group2.Hex = _group2;
|
||||||
|
|
||||||
|
m_VtxAttr.texCoord[4].Frac = m_group2.Tex4Frac;
|
||||||
|
m_VtxAttr.texCoord[5].Elements = m_group2.Tex5CoordElements;
|
||||||
|
m_VtxAttr.texCoord[5].Format = m_group2.Tex5CoordFormat;
|
||||||
|
m_VtxAttr.texCoord[5].Frac = m_group2.Tex5Frac;
|
||||||
|
m_VtxAttr.texCoord[6].Elements = m_group2.Tex6CoordElements;
|
||||||
|
m_VtxAttr.texCoord[6].Format = m_group2.Tex6CoordFormat;
|
||||||
|
m_VtxAttr.texCoord[6].Frac = m_group2.Tex6Frac;
|
||||||
|
m_VtxAttr.texCoord[7].Elements = m_group2.Tex7CoordElements;
|
||||||
|
m_VtxAttr.texCoord[7].Format = m_group2.Tex7CoordFormat;
|
||||||
|
m_VtxAttr.texCoord[7].Frac = m_group2.Tex7Frac;
|
||||||
|
};
|
||||||
|
|
|
@ -23,9 +23,6 @@
|
||||||
|
|
||||||
#include "NativeVertexFormat.h"
|
#include "NativeVertexFormat.h"
|
||||||
|
|
||||||
// There are 8 of these. Most games only use the first, and just reconfigure it all the time
|
|
||||||
// as needed, unfortunately.
|
|
||||||
// TODO - clarify the role of this class. It seems to have taken on some irrelevant stuff.
|
|
||||||
class VertexLoader
|
class VertexLoader
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
@ -44,19 +41,20 @@ private:
|
||||||
AD_VAT_DIRTY = 2,
|
AD_VAT_DIRTY = 2,
|
||||||
} m_AttrDirty;
|
} m_AttrDirty;
|
||||||
|
|
||||||
// Flipper vertex format =============
|
|
||||||
int m_VertexSize; // number of bytes of a raw GC vertex
|
int m_VertexSize; // number of bytes of a raw GC vertex
|
||||||
|
|
||||||
|
// Flipper vertex format
|
||||||
|
|
||||||
// Raw VAttr
|
// Raw VAttr
|
||||||
UVAT_group0 m_group0;
|
UVAT_group0 m_group0;
|
||||||
UVAT_group1 m_group1;
|
UVAT_group1 m_group1;
|
||||||
UVAT_group2 m_group2;
|
UVAT_group2 m_group2;
|
||||||
TVtxAttr m_VtxAttr; // Decoded into easy format
|
TVtxAttr m_VtxAttr; // Decoded into easy format
|
||||||
|
|
||||||
// Common for all loaders (? then why is it here?)
|
// Vtx desc
|
||||||
TVtxDesc m_VtxDesc;
|
TVtxDesc m_VtxDesc;
|
||||||
|
|
||||||
// PC vertex format, + converter ======
|
// PC vertex format, + converter
|
||||||
NativeVertexFormat m_NativeFmt;
|
NativeVertexFormat m_NativeFmt;
|
||||||
|
|
||||||
// Pipeline. To be JIT compiled in the future.
|
// Pipeline. To be JIT compiled in the future.
|
||||||
|
@ -73,7 +71,7 @@ public:
|
||||||
~VertexLoader();
|
~VertexLoader();
|
||||||
|
|
||||||
// run the pipeline
|
// run the pipeline
|
||||||
void PrepareForVertexFormat();
|
void CompileVertexTranslator();
|
||||||
void RunVertices(int primitive, int count);
|
void RunVertices(int primitive, int count);
|
||||||
void WriteCall(TPipelineFunction);
|
void WriteCall(TPipelineFunction);
|
||||||
|
|
||||||
|
@ -82,70 +80,9 @@ public:
|
||||||
|
|
||||||
int ComputeVertexSize();
|
int ComputeVertexSize();
|
||||||
|
|
||||||
void SetVAT_group0(u32 _group0)
|
void SetVAT_group0(u32 _group0);
|
||||||
{
|
void SetVAT_group1(u32 _group1);
|
||||||
// ignore frac bits - we don't need to recompute if all that's changed was the frac bits.
|
void SetVAT_group2(u32 _group2);
|
||||||
if ((m_group0.Hex & ~VAT_0_FRACBITS) != (_group0 & ~VAT_0_FRACBITS)) {
|
|
||||||
m_AttrDirty = AD_VAT_DIRTY;
|
|
||||||
}
|
|
||||||
m_group0.Hex = _group0;
|
|
||||||
|
|
||||||
m_VtxAttr.PosElements = m_group0.PosElements;
|
|
||||||
m_VtxAttr.PosFormat = m_group0.PosFormat;
|
|
||||||
m_VtxAttr.PosFrac = m_group0.PosFrac;
|
|
||||||
m_VtxAttr.NormalElements = m_group0.NormalElements;
|
|
||||||
m_VtxAttr.NormalFormat = m_group0.NormalFormat;
|
|
||||||
m_VtxAttr.color[0].Elements = m_group0.Color0Elements;
|
|
||||||
m_VtxAttr.color[0].Comp = m_group0.Color0Comp;
|
|
||||||
m_VtxAttr.color[1].Elements = m_group0.Color1Elements;
|
|
||||||
m_VtxAttr.color[1].Comp = m_group0.Color1Comp;
|
|
||||||
m_VtxAttr.texCoord[0].Elements = m_group0.Tex0CoordElements;
|
|
||||||
m_VtxAttr.texCoord[0].Format = m_group0.Tex0CoordFormat;
|
|
||||||
m_VtxAttr.texCoord[0].Frac = m_group0.Tex0Frac;
|
|
||||||
m_VtxAttr.ByteDequant = m_group0.ByteDequant;
|
|
||||||
m_VtxAttr.NormalIndex3 = m_group0.NormalIndex3;
|
|
||||||
};
|
|
||||||
|
|
||||||
void SetVAT_group1(u32 _group1)
|
|
||||||
{
|
|
||||||
if ((m_group1.Hex & ~VAT_1_FRACBITS) != (_group1 & ~VAT_1_FRACBITS)) {
|
|
||||||
m_AttrDirty = AD_VAT_DIRTY;
|
|
||||||
}
|
|
||||||
m_group1.Hex = _group1;
|
|
||||||
|
|
||||||
m_VtxAttr.texCoord[1].Elements = m_group1.Tex1CoordElements;
|
|
||||||
m_VtxAttr.texCoord[1].Format = m_group1.Tex1CoordFormat;
|
|
||||||
m_VtxAttr.texCoord[1].Frac = m_group1.Tex1Frac;
|
|
||||||
m_VtxAttr.texCoord[2].Elements = m_group1.Tex2CoordElements;
|
|
||||||
m_VtxAttr.texCoord[2].Format = m_group1.Tex2CoordFormat;
|
|
||||||
m_VtxAttr.texCoord[2].Frac = m_group1.Tex2Frac;
|
|
||||||
m_VtxAttr.texCoord[3].Elements = m_group1.Tex3CoordElements;
|
|
||||||
m_VtxAttr.texCoord[3].Format = m_group1.Tex3CoordFormat;
|
|
||||||
m_VtxAttr.texCoord[3].Frac = m_group1.Tex3Frac;
|
|
||||||
m_VtxAttr.texCoord[4].Elements = m_group1.Tex4CoordElements;
|
|
||||||
m_VtxAttr.texCoord[4].Format = m_group1.Tex4CoordFormat;
|
|
||||||
};
|
|
||||||
|
|
||||||
void SetVAT_group2(u32 _group2)
|
|
||||||
{
|
|
||||||
if ((m_group2.Hex & ~VAT_2_FRACBITS) != (_group2 & ~VAT_2_FRACBITS)) {
|
|
||||||
m_AttrDirty = AD_VAT_DIRTY;
|
|
||||||
}
|
|
||||||
m_group2.Hex = _group2;
|
|
||||||
|
|
||||||
m_VtxAttr.texCoord[4].Frac = m_group2.Tex4Frac;
|
|
||||||
m_VtxAttr.texCoord[5].Elements = m_group2.Tex5CoordElements;
|
|
||||||
m_VtxAttr.texCoord[5].Format = m_group2.Tex5CoordFormat;
|
|
||||||
m_VtxAttr.texCoord[5].Frac = m_group2.Tex5Frac;
|
|
||||||
m_VtxAttr.texCoord[6].Elements = m_group2.Tex6CoordElements;
|
|
||||||
m_VtxAttr.texCoord[6].Format = m_group2.Tex6CoordFormat;
|
|
||||||
m_VtxAttr.texCoord[6].Frac = m_group2.Tex6Frac;
|
|
||||||
m_VtxAttr.texCoord[7].Elements = m_group2.Tex7CoordElements;
|
|
||||||
m_VtxAttr.texCoord[7].Format = m_group2.Tex7CoordFormat;
|
|
||||||
m_VtxAttr.texCoord[7].Frac = m_group2.Tex7Frac;
|
|
||||||
};
|
|
||||||
};
|
};
|
||||||
|
|
||||||
extern VertexLoader g_VertexLoaders[8];
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -19,22 +19,24 @@
|
||||||
#include "VertexLoader.h"
|
#include "VertexLoader.h"
|
||||||
#include "VertexLoaderManager.h"
|
#include "VertexLoaderManager.h"
|
||||||
|
|
||||||
// The one and only vtx_desc
|
static bool s_desc_dirty;
|
||||||
TVtxDesc g_vtx_desc;
|
static bool s_attr_dirty[8];
|
||||||
// There are 8 vtx_attr structures. They will soon live here.
|
|
||||||
|
|
||||||
const TVtxDesc &GetVtxDesc()
|
// TODO - change into array of pointers. Keep a map of all seen so far.
|
||||||
|
static VertexLoader g_VertexLoaders[8];
|
||||||
|
|
||||||
|
namespace VertexLoaderManager
|
||||||
{
|
{
|
||||||
return g_vtx_desc;
|
|
||||||
|
void Init()
|
||||||
|
{
|
||||||
|
s_desc_dirty = false;
|
||||||
|
for (int i = 0; i < 8; i++)
|
||||||
|
s_attr_dirty[i] = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
namespace VertexLoaderManager {
|
void Shutdown()
|
||||||
|
{
|
||||||
void Init() {
|
|
||||||
g_vtx_desc.Hex = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
void Shutdown() {
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -42,12 +44,17 @@ void RunVertices(int vtx_attr_group, int primitive, int count)
|
||||||
{
|
{
|
||||||
if (!count)
|
if (!count)
|
||||||
return;
|
return;
|
||||||
// TODO - grab load the correct vertex loader if anything is dirty.
|
// TODO - grab & load the correct vertex loader if anything is dirty.
|
||||||
g_VertexLoaders[vtx_attr_group].RunVertices(primitive, count);
|
g_VertexLoaders[vtx_attr_group].RunVertices(primitive, count);
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace
|
int GetVertexSize(int vtx_attr_group)
|
||||||
|
{
|
||||||
|
// The vertex loaders will soon cache the vertex size.
|
||||||
|
return g_VertexLoaders[vtx_attr_group].ComputeVertexSize();
|
||||||
|
}
|
||||||
|
|
||||||
|
} // namespace
|
||||||
|
|
||||||
void LoadCPReg(u32 sub_cmd, u32 value)
|
void LoadCPReg(u32 sub_cmd, u32 value)
|
||||||
{
|
{
|
||||||
|
@ -56,24 +63,51 @@ void LoadCPReg(u32 sub_cmd, u32 value)
|
||||||
case 0x30:
|
case 0x30:
|
||||||
VertexShaderMngr::SetTexMatrixChangedA(value);
|
VertexShaderMngr::SetTexMatrixChangedA(value);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 0x40:
|
case 0x40:
|
||||||
VertexShaderMngr::SetTexMatrixChangedB(value);
|
VertexShaderMngr::SetTexMatrixChangedB(value);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 0x50:
|
case 0x50:
|
||||||
g_vtx_desc.Hex &= ~0x1FFFF; // keep the Upper bits
|
g_VtxDesc.Hex &= ~0x1FFFF; // keep the Upper bits
|
||||||
g_vtx_desc.Hex |= value;
|
g_VtxDesc.Hex |= value;
|
||||||
|
s_desc_dirty = true;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 0x60:
|
case 0x60:
|
||||||
g_vtx_desc.Hex &= 0x1FFFF; // keep the lower 17Bits
|
g_VtxDesc.Hex &= 0x1FFFF; // keep the lower 17Bits
|
||||||
g_vtx_desc.Hex |= (u64)value << 17;
|
g_VtxDesc.Hex |= (u64)value << 17;
|
||||||
|
s_desc_dirty = true;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case 0x70: g_VertexLoaders[sub_cmd & 7].SetVAT_group0(value); _assert_((sub_cmd & 0x0F) < 8); break;
|
case 0x70:
|
||||||
case 0x80: g_VertexLoaders[sub_cmd & 7].SetVAT_group1(value); _assert_((sub_cmd & 0x0F) < 8); break;
|
_assert_((sub_cmd & 0x0F) < 8);
|
||||||
case 0x90: g_VertexLoaders[sub_cmd & 7].SetVAT_group2(value); _assert_((sub_cmd & 0x0F) < 8); break;
|
g_VtxAttr[sub_cmd & 7].g0.Hex = value;
|
||||||
|
g_VertexLoaders[sub_cmd & 7].SetVAT_group0(value);
|
||||||
|
s_attr_dirty[sub_cmd & 7] = true;
|
||||||
|
break;
|
||||||
|
|
||||||
case 0xA0: arraybases[sub_cmd & 0xF] = value & 0xFFFFFFFF; break;
|
case 0x80:
|
||||||
case 0xB0: arraystrides[sub_cmd & 0xF] = value & 0xFF; break;
|
_assert_((sub_cmd & 0x0F) < 8);
|
||||||
|
g_VtxAttr[sub_cmd & 7].g1.Hex = value;
|
||||||
|
g_VertexLoaders[sub_cmd & 7].SetVAT_group1(value);
|
||||||
|
s_attr_dirty[sub_cmd & 7] = true;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 0x90:
|
||||||
|
_assert_((sub_cmd & 0x0F) < 8);
|
||||||
|
g_VtxAttr[sub_cmd & 7].g2.Hex = value;
|
||||||
|
g_VertexLoaders[sub_cmd & 7].SetVAT_group2(value);
|
||||||
|
s_attr_dirty[sub_cmd & 7] = true;
|
||||||
|
break;
|
||||||
|
|
||||||
|
// Pointers to vertex arrays in GC RAM
|
||||||
|
case 0xA0:
|
||||||
|
arraybases[sub_cmd & 0xF] = value & 0xFFFFFFFF; // huh, why the mask?
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 0xB0:
|
||||||
|
arraystrides[sub_cmd & 0xF] = value & 0xFF;
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -24,15 +24,14 @@ namespace VertexLoaderManager
|
||||||
{
|
{
|
||||||
void Init();
|
void Init();
|
||||||
void Shutdown();
|
void Shutdown();
|
||||||
|
|
||||||
|
int GetVertexSize(int vtx_attr_group);
|
||||||
void RunVertices(int vtx_attr_group, int primitive, int count);
|
void RunVertices(int vtx_attr_group, int primitive, int count);
|
||||||
|
|
||||||
// TODO - don't expose these like this.
|
// TODO - don't expose these like this.
|
||||||
static u8* s_pCurBufferPointer;
|
static u8* s_pCurBufferPointer;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
const TVtxDesc &GetVtxDesc();
|
|
||||||
|
|
||||||
// Might move this into its own file later.
|
// Might move this into its own file later.
|
||||||
void LoadCPReg(u32 SubCmd, u32 Value);
|
void LoadCPReg(u32 SubCmd, u32 Value);
|
||||||
|
|
||||||
|
|
|
@ -33,7 +33,6 @@ static u32 s_prevcomponents; // previous state set
|
||||||
|
|
||||||
u8* s_pCurBufferPointer = NULL;
|
u8* s_pCurBufferPointer = NULL;
|
||||||
|
|
||||||
TVtxDesc s_GlobalVtxDesc;
|
|
||||||
|
|
||||||
static const GLenum c_primitiveType[8] =
|
static const GLenum c_primitiveType[8] =
|
||||||
{
|
{
|
||||||
|
|
|
@ -37,6 +37,7 @@
|
||||||
#include "TextureMngr.h"
|
#include "TextureMngr.h"
|
||||||
#include "BPStructs.h"
|
#include "BPStructs.h"
|
||||||
#include "VertexLoader.h"
|
#include "VertexLoader.h"
|
||||||
|
#include "VertexLoaderManager.h"
|
||||||
#include "VertexManager.h"
|
#include "VertexManager.h"
|
||||||
#include "PixelShaderManager.h"
|
#include "PixelShaderManager.h"
|
||||||
#include "VertexShaderManager.h"
|
#include "VertexShaderManager.h"
|
||||||
|
@ -222,10 +223,12 @@ void Video_Prepare(void)
|
||||||
VertexShaderMngr::Init();
|
VertexShaderMngr::Init();
|
||||||
PixelShaderMngr::Init();
|
PixelShaderMngr::Init();
|
||||||
GL_REPORT_ERRORD();
|
GL_REPORT_ERRORD();
|
||||||
|
VertexLoaderManager::Init();
|
||||||
}
|
}
|
||||||
|
|
||||||
void Video_Shutdown(void)
|
void Video_Shutdown(void)
|
||||||
{
|
{
|
||||||
|
VertexLoaderManager::Shutdown();
|
||||||
VertexShaderMngr::Shutdown();
|
VertexShaderMngr::Shutdown();
|
||||||
PixelShaderMngr::Shutdown();
|
PixelShaderMngr::Shutdown();
|
||||||
Fifo_Shutdown();
|
Fifo_Shutdown();
|
||||||
|
|
Loading…
Reference in New Issue