mirror of
https://github.com/dolphin-emu/dolphin.git
synced 2025-01-25 15:31:17 +01:00
revert my last change to vertex manager as the performance difference is negligible an causes performance drop in higher definitions
git-svn-id: https://dolphin-emu.googlecode.com/svn/trunk@5658 8ced0084-cf51-0410-be5f-012b33b47a6e
This commit is contained in:
parent
b336617cbf
commit
f0d178122e
@ -22,7 +22,7 @@ static const char ID[4] = {'D', 'C', 'A', 'C'};
|
|||||||
// Update this to the current SVN revision every time you change shader generation code.
|
// Update this to the current SVN revision every time you change shader generation code.
|
||||||
// We don't automatically get this from SVN_REV because that would mean regenerating the
|
// We don't automatically get this from SVN_REV because that would mean regenerating the
|
||||||
// shader cache for every revision, graphics-related or not, which is simply annoying.
|
// shader cache for every revision, graphics-related or not, which is simply annoying.
|
||||||
const int version = 5653;
|
const int version = 5658;
|
||||||
|
|
||||||
LinearDiskCache::LinearDiskCache()
|
LinearDiskCache::LinearDiskCache()
|
||||||
: file_(NULL), num_entries_(0) {
|
: file_(NULL), num_entries_(0) {
|
||||||
|
@ -19,7 +19,6 @@
|
|||||||
#include "FileUtil.h"
|
#include "FileUtil.h"
|
||||||
|
|
||||||
#include "D3DBase.h"
|
#include "D3DBase.h"
|
||||||
#include "D3DUtil.h"
|
|
||||||
|
|
||||||
#include "Statistics.h"
|
#include "Statistics.h"
|
||||||
#include "Profiler.h"
|
#include "Profiler.h"
|
||||||
@ -293,30 +292,24 @@ void Flush()
|
|||||||
int stride = g_nativeVertexFmt->GetVertexStride();
|
int stride = g_nativeVertexFmt->GetVertexStride();
|
||||||
g_nativeVertexFmt->SetupVertexPointers();
|
g_nativeVertexFmt->SetupVertexPointers();
|
||||||
|
|
||||||
if(bpmem.dstalpha.enable && bpmem.blendmode.alphaupdate)
|
|
||||||
{
|
|
||||||
D3D::SetRenderState(D3DRS_STENCILENABLE, TRUE );
|
|
||||||
D3D::SetRenderState(D3DRS_STENCILFUNC, D3DCMP_ALWAYS );
|
|
||||||
D3D::SetRenderState(D3DRS_STENCILPASS, D3DSTENCILOP_REPLACE );
|
|
||||||
D3D::SetRenderState(D3DRS_STENCILREF, 1);
|
|
||||||
}
|
|
||||||
|
|
||||||
Draw(stride);
|
Draw(stride);
|
||||||
|
|
||||||
if (bpmem.dstalpha.enable && bpmem.blendmode.alphaupdate)
|
if (bpmem.dstalpha.enable && bpmem.blendmode.alphaupdate)
|
||||||
{
|
{
|
||||||
|
DWORD write = 0;
|
||||||
D3D::SetRenderState(D3DRS_STENCILFUNC, D3DCMP_EQUAL );
|
if (!PixelShaderCache::SetShader(true))
|
||||||
D3D::SetRenderState(D3DRS_STENCILPASS, D3DSTENCILOP_DECR );
|
{
|
||||||
|
DEBUGGER_PAUSE_LOG_AT(NEXT_ERROR,true,{printf("Fail to set pixel shader\n");});
|
||||||
|
goto shader_fail;
|
||||||
|
}
|
||||||
|
// update alpha only
|
||||||
D3D::ChangeRenderState(D3DRS_COLORWRITEENABLE, D3DCOLORWRITEENABLE_ALPHA);
|
D3D::ChangeRenderState(D3DRS_COLORWRITEENABLE, D3DCOLORWRITEENABLE_ALPHA);
|
||||||
D3D::ChangeRenderState(D3DRS_ALPHABLENDENABLE, false);
|
D3D::ChangeRenderState(D3DRS_ALPHABLENDENABLE, false);
|
||||||
D3D::ChangeRenderState(D3DRS_ZWRITEENABLE, false);
|
|
||||||
D3D::drawClearQuad((bpmem.dstalpha.hex & 0xff)<<24,0.0f,PixelShaderCache::GetClearProgram(),VertexShaderCache::GetClearVertexShader());
|
Draw(stride);
|
||||||
D3D::RefreshRenderState(D3DRS_ZWRITEENABLE);
|
|
||||||
D3D::RefreshRenderState(D3DRS_COLORWRITEENABLE);
|
D3D::RefreshRenderState(D3DRS_COLORWRITEENABLE);
|
||||||
D3D::RefreshRenderState(D3DRS_ALPHABLENDENABLE);
|
D3D::RefreshRenderState(D3DRS_ALPHABLENDENABLE);
|
||||||
D3D::SetRenderState(D3DRS_STENCILENABLE, false );
|
|
||||||
}
|
}
|
||||||
DEBUGGER_PAUSE_AT(NEXT_FLUSH,true);
|
DEBUGGER_PAUSE_AT(NEXT_FLUSH,true);
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user