Remove a bunch of freshly-obsolete code
git-svn-id: https://dolphin-emu.googlecode.com/svn/trunk@6148 8ced0084-cf51-0410-be5f-012b33b47a6e
This commit is contained in:
parent
3058a926cf
commit
4229d9e01e
|
@ -31,7 +31,7 @@ PIXELSHADERUID last_pixel_shader_uid;
|
||||||
// a unique identifier, basically containing all the bits. Yup, it's a lot ....
|
// a unique identifier, basically containing all the bits. Yup, it's a lot ....
|
||||||
// It would likely be a lot more efficient to build this incrementally as the attributes
|
// It would likely be a lot more efficient to build this incrementally as the attributes
|
||||||
// are set...
|
// are set...
|
||||||
void GetPixelShaderId(PIXELSHADERUID *uid, u32 texturemask, u32 dstAlphaEnable)
|
void GetPixelShaderId(PIXELSHADERUID *uid, u32 dstAlphaEnable)
|
||||||
{
|
{
|
||||||
u32 numstages = bpmem.genMode.numtevstages + 1;
|
u32 numstages = bpmem.genMode.numtevstages + 1;
|
||||||
u32 projtexcoords = 0;
|
u32 projtexcoords = 0;
|
||||||
|
@ -57,7 +57,7 @@ void GetPixelShaderId(PIXELSHADERUID *uid, u32 texturemask, u32 dstAlphaEnable)
|
||||||
for (int i = 0; i < 8; i += 2)
|
for (int i = 0; i < 8; i += 2)
|
||||||
((u8*)&uid->values[1])[i / 2] = (bpmem.tevksel[i].hex & 0xf) | ((bpmem.tevksel[i + 1].hex & 0xf) << 4);
|
((u8*)&uid->values[1])[i / 2] = (bpmem.tevksel[i].hex & 0xf) | ((bpmem.tevksel[i + 1].hex & 0xf) << 4);
|
||||||
|
|
||||||
uid->values[2] = texturemask;
|
uid->values[2] = 0;
|
||||||
|
|
||||||
u32 enableZTexture = (!bpmem.zcontrol.zcomploc && bpmem.zmode.testenable && bpmem.zmode.updateenable)?1:0;
|
u32 enableZTexture = (!bpmem.zcontrol.zcomploc && bpmem.zmode.testenable && bpmem.zmode.updateenable)?1:0;
|
||||||
|
|
||||||
|
@ -147,8 +147,8 @@ void GetPixelShaderId(PIXELSHADERUID *uid, u32 texturemask, u32 dstAlphaEnable)
|
||||||
// output is given by .outreg
|
// output is given by .outreg
|
||||||
// tevtemp is set according to swapmodetables and
|
// tevtemp is set according to swapmodetables and
|
||||||
|
|
||||||
static void WriteStage(char *&p, int n, u32 texture_mask, API_TYPE ApiType);
|
static void WriteStage(char *&p, int n, API_TYPE ApiType);
|
||||||
static void SampleTexture(char *&p, const char *destination, const char *texcoords, const char *texswap, int texmap, u32 texture_mask, API_TYPE ApiType);
|
static void SampleTexture(char *&p, const char *destination, const char *texcoords, const char *texswap, int texmap, API_TYPE ApiType);
|
||||||
// static void WriteAlphaCompare(char *&p, int num, int comp);
|
// static void WriteAlphaCompare(char *&p, int num, int comp);
|
||||||
static bool WriteAlphaTest(char *&p, API_TYPE ApiType);
|
static bool WriteAlphaTest(char *&p, API_TYPE ApiType);
|
||||||
static void WriteFog(char *&p);
|
static void WriteFog(char *&p);
|
||||||
|
@ -366,7 +366,7 @@ static void BuildSwapModeTable()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const char *GeneratePixelShaderCode(u32 texture_mask, bool dstAlphaEnable, API_TYPE ApiType)
|
const char *GeneratePixelShaderCode(bool dstAlphaEnable, API_TYPE ApiType)
|
||||||
{
|
{
|
||||||
setlocale(LC_NUMERIC, "C"); // Reset locale for compilation
|
setlocale(LC_NUMERIC, "C"); // Reset locale for compilation
|
||||||
text[sizeof(text) - 1] = 0x7C; // canary
|
text[sizeof(text) - 1] = 0x7C; // canary
|
||||||
|
@ -392,55 +392,33 @@ const char *GeneratePixelShaderCode(u32 texture_mask, bool dstAlphaEnable, API_T
|
||||||
}
|
}
|
||||||
DepthTextureEnable = bpmem.ztex2.op != ZTEXTURE_DISABLE && !bpmem.zcontrol.zcomploc && bpmem.zmode.testenable && bpmem.zmode.updateenable;
|
DepthTextureEnable = bpmem.ztex2.op != ZTEXTURE_DISABLE && !bpmem.zcontrol.zcomploc && bpmem.zmode.testenable && bpmem.zmode.updateenable;
|
||||||
// Declare samplers
|
// Declare samplers
|
||||||
if (texture_mask && ApiType == API_OPENGL)
|
|
||||||
{
|
|
||||||
WRITE(p, "uniform samplerRECT ");
|
|
||||||
bool bfirst = true;
|
|
||||||
for (int i = 0; i < 8; ++i)
|
|
||||||
{
|
|
||||||
if (texture_mask & (1<<i))
|
|
||||||
{
|
|
||||||
WRITE(p, "%s samp%d : register(s%d)", bfirst?"":",", i, i);
|
|
||||||
bfirst = false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
WRITE(p, ";\n");
|
|
||||||
}
|
|
||||||
|
|
||||||
if (texture_mask != 0xff)
|
if(ApiType != API_D3D11)
|
||||||
{
|
{
|
||||||
if(ApiType != API_D3D11)
|
WRITE(p, "uniform sampler2D ");
|
||||||
{
|
}
|
||||||
WRITE(p, "uniform sampler2D ");
|
else
|
||||||
}
|
{
|
||||||
else
|
WRITE(p, "sampler ");
|
||||||
{
|
}
|
||||||
WRITE(p, "sampler ");
|
|
||||||
}
|
bool bfirst = true;
|
||||||
|
for (int i = 0; i < 8; ++i)
|
||||||
bool bfirst = true;
|
{
|
||||||
|
WRITE(p, "%s samp%d : register(s%d)", bfirst?"":",", i, i);
|
||||||
|
bfirst = false;
|
||||||
|
}
|
||||||
|
WRITE(p, ";\n");
|
||||||
|
if(ApiType == API_D3D11)
|
||||||
|
{
|
||||||
|
WRITE(p, "Texture2D ");
|
||||||
|
bfirst = true;
|
||||||
for (int i = 0; i < 8; ++i)
|
for (int i = 0; i < 8; ++i)
|
||||||
{
|
{
|
||||||
if (!(texture_mask & (1<<i))) {
|
WRITE(p, "%s Tex%d : register(t%d)", bfirst?"":",", i, i);
|
||||||
WRITE(p, "%s samp%d : register(s%d)", bfirst?"":",", i, i);
|
bfirst = false;
|
||||||
bfirst = false;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
WRITE(p, ";\n");
|
WRITE(p, ";\n");
|
||||||
if(ApiType == API_D3D11)
|
|
||||||
{
|
|
||||||
WRITE(p, "Texture2D ");
|
|
||||||
bfirst = true;
|
|
||||||
for (int i = 0; i < 8; ++i)
|
|
||||||
{
|
|
||||||
if (!(texture_mask & (1<<i)))
|
|
||||||
{
|
|
||||||
WRITE(p, "%s Tex%d : register(t%d)", bfirst?"":",", i, i);
|
|
||||||
bfirst = false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
WRITE(p, ";\n");
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
WRITE(p, "\n");
|
WRITE(p, "\n");
|
||||||
|
@ -521,7 +499,7 @@ const char *GeneratePixelShaderCode(u32 texture_mask, bool dstAlphaEnable, API_T
|
||||||
|
|
||||||
char buffer[32];
|
char buffer[32];
|
||||||
sprintf(buffer, "float3 indtex%d", i);
|
sprintf(buffer, "float3 indtex%d", i);
|
||||||
SampleTexture(p, buffer, "tempcoord", "abg", bpmem.tevindref.getTexMap(i), texture_mask, ApiType);
|
SampleTexture(p, buffer, "tempcoord", "abg", bpmem.tevindref.getTexMap(i), ApiType);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -536,7 +514,7 @@ const char *GeneratePixelShaderCode(u32 texture_mask, bool dstAlphaEnable, API_T
|
||||||
}
|
}
|
||||||
|
|
||||||
for (int i = 0; i < numStages; i++)
|
for (int i = 0; i < numStages; i++)
|
||||||
WriteStage(p, i, texture_mask, ApiType); //build the equation for this stage
|
WriteStage(p, i, ApiType); //build the equation for this stage
|
||||||
|
|
||||||
if(numStages)
|
if(numStages)
|
||||||
{
|
{
|
||||||
|
@ -657,7 +635,7 @@ static const char *TEVCMPAlphaOPTable[16] =
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
static void WriteStage(char *&p, int n, u32 texture_mask, API_TYPE ApiType)
|
static void WriteStage(char *&p, int n, API_TYPE ApiType)
|
||||||
{
|
{
|
||||||
char *rasswap = swapModeTable[bpmem.combiners[n].alphaC.rswap];
|
char *rasswap = swapModeTable[bpmem.combiners[n].alphaC.rswap];
|
||||||
char *texswap = swapModeTable[bpmem.combiners[n].alphaC.tswap];
|
char *texswap = swapModeTable[bpmem.combiners[n].alphaC.tswap];
|
||||||
|
@ -764,7 +742,7 @@ static void WriteStage(char *&p, int n, u32 texture_mask, API_TYPE ApiType)
|
||||||
WRITE(p, "tevcoord.xy = float2(0.0f, 0.0f);\n");
|
WRITE(p, "tevcoord.xy = float2(0.0f, 0.0f);\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
SampleTexture(p, "textemp", "tevcoord", texswap, texmap, texture_mask, ApiType);
|
SampleTexture(p, "textemp", "tevcoord", texswap, texmap, ApiType);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
WRITE(p, "textemp = float4(1.0f, 1.0f, 1.0f, 1.0f);\n");
|
WRITE(p, "textemp = float4(1.0f, 1.0f, 1.0f, 1.0f);\n");
|
||||||
|
@ -978,41 +956,12 @@ static void WriteStage(char *&p, int n, u32 texture_mask, API_TYPE ApiType)
|
||||||
WRITE(p, ";\n\n");
|
WRITE(p, ";\n\n");
|
||||||
}
|
}
|
||||||
|
|
||||||
void SampleTexture(char *&p, const char *destination, const char *texcoords, const char *texswap, int texmap, u32 texture_mask, API_TYPE ApiType)
|
void SampleTexture(char *&p, const char *destination, const char *texcoords, const char *texswap, int texmap, API_TYPE ApiType)
|
||||||
{
|
{
|
||||||
if (texture_mask & (1<<texmap)) {// opengl only
|
if (ApiType == API_D3D11)
|
||||||
// non pow 2
|
WRITE(p, "%s=Tex%d.Sample(samp%d,%s.xy * "I_TEXDIMS"[%d].xy).%s;\n", destination, texmap,texmap, texcoords, texmap, texswap);
|
||||||
bool bwraps = (texture_mask & (0x100<<texmap)) ? true : false;
|
|
||||||
bool bwrapt = (texture_mask & (0x10000<<texmap)) ? true : false;
|
|
||||||
|
|
||||||
if (bwraps || bwrapt) {
|
|
||||||
if (bwraps) {
|
|
||||||
WRITE(p, "tempcoord.x = fmod(%s.x, "I_TEXDIMS"[%d].x);\n", texcoords, texmap);
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
WRITE(p, "tempcoord.x = %s.x;\n", texcoords);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (bwrapt) {
|
|
||||||
WRITE(p, "tempcoord.y = fmod(%s.y, "I_TEXDIMS"[%d].y);\n", texcoords, texmap);
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
WRITE(p, "tempcoord.y = %s.y;\n", texcoords);
|
|
||||||
}
|
|
||||||
WRITE(p, "%s=texRECT(samp%d,tempcoord.xy).%s;\n", destination, texmap, texswap);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
WRITE(p, "%s=texRECT(samp%d,%s.xy).%s;\n", destination, texmap, texcoords, texswap);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
else
|
||||||
{
|
WRITE(p, "%s=tex2D(samp%d,%s.xy * "I_TEXDIMS"[%d].xy).%s;\n", destination, texmap, texcoords, texmap, texswap);
|
||||||
if (ApiType == API_D3D11)
|
|
||||||
WRITE(p, "%s=Tex%d.Sample(samp%d,%s.xy * "I_TEXDIMS"[%d].xy).%s;\n", destination, texmap,texmap, texcoords, texmap, texswap);
|
|
||||||
else
|
|
||||||
WRITE(p, "%s=tex2D(samp%d,%s.xy * "I_TEXDIMS"[%d].xy).%s;\n", destination, texmap, texcoords, texmap, texswap);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static const char *tevAlphaFuncsTable[] =
|
static const char *tevAlphaFuncsTable[] =
|
||||||
|
|
|
@ -100,8 +100,8 @@ public:
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
const char *GeneratePixelShaderCode(u32 texture_mask, bool dstAlphaEnable, API_TYPE ApiType);
|
const char *GeneratePixelShaderCode(bool dstAlphaEnable, API_TYPE ApiType);
|
||||||
void GetPixelShaderId(PIXELSHADERUID *uid, u32 texturemask, u32 dstAlphaEnable);
|
void GetPixelShaderId(PIXELSHADERUID *uid, u32 dstAlphaEnable);
|
||||||
|
|
||||||
extern PIXELSHADERUID last_pixel_shader_uid;
|
extern PIXELSHADERUID last_pixel_shader_uid;
|
||||||
|
|
||||||
|
|
|
@ -41,11 +41,6 @@ static u32 lastAlpha;
|
||||||
static u32 lastTexDims[8]; // width | height << 16 | wrap_s << 28 | wrap_t << 30
|
static u32 lastTexDims[8]; // width | height << 16 | wrap_s << 28 | wrap_t << 30
|
||||||
static u32 lastZBias;
|
static u32 lastZBias;
|
||||||
|
|
||||||
// lower byte describes if a texture is nonpow2 or pow2
|
|
||||||
// next byte describes whether the repeat wrap mode is enabled for the s channel
|
|
||||||
// next byte is for t channel
|
|
||||||
static u32 s_texturemask = 0;
|
|
||||||
|
|
||||||
void PixelShaderManager::Init()
|
void PixelShaderManager::Init()
|
||||||
{
|
{
|
||||||
for (int i = 0; i < 8; i++)
|
for (int i = 0; i < 8; i++)
|
||||||
|
@ -53,7 +48,6 @@ void PixelShaderManager::Init()
|
||||||
lastAlpha = 0;
|
lastAlpha = 0;
|
||||||
memset(lastTexDims, 0, sizeof(lastTexDims));
|
memset(lastTexDims, 0, sizeof(lastTexDims));
|
||||||
lastZBias = 0;
|
lastZBias = 0;
|
||||||
s_texturemask = 0;
|
|
||||||
memset(lastRGBAfull, 0, sizeof(lastRGBAfull));
|
memset(lastRGBAfull, 0, sizeof(lastRGBAfull));
|
||||||
Dirty();
|
Dirty();
|
||||||
}
|
}
|
||||||
|
@ -223,26 +217,15 @@ void PixelShaderManager::SetConstants()
|
||||||
|
|
||||||
void PixelShaderManager::SetPSTextureDims(int texid)
|
void PixelShaderManager::SetPSTextureDims(int texid)
|
||||||
{
|
{
|
||||||
// non pow 2 textures - texdims.xy are the real texture dimensions used for wrapping
|
// texdims.xy are reciprocals of the real texture dimensions
|
||||||
// pow 2 textures - texdims.xy are reciprocals of the real texture dimensions
|
// texdims.zw are the scaled dimensions
|
||||||
// both - texdims.zw are the scaled dimensions
|
|
||||||
float fdims[4];
|
float fdims[4];
|
||||||
if (s_texturemask & (1 << texid))
|
|
||||||
{
|
TCoordInfo& tc = bpmem.texcoords[texid];
|
||||||
TCoordInfo& tc = bpmem.texcoords[texid];
|
fdims[0] = 1.0f / (float)(lastTexDims[texid] & 0xffff);
|
||||||
fdims[0] = (float)(lastTexDims[texid] & 0xffff);
|
fdims[1] = 1.0f / (float)((lastTexDims[texid] >> 16) & 0xfff);
|
||||||
fdims[1] = (float)((lastTexDims[texid] >> 16) & 0xfff);
|
fdims[2] = (float)(tc.s.scale_minus_1 + 1) * lastCustomTexScale[texid][0];
|
||||||
fdims[2] = (float)(tc.s.scale_minus_1 + 1)*lastCustomTexScale[texid][0];
|
fdims[3] = (float)(tc.t.scale_minus_1 + 1) * lastCustomTexScale[texid][1];
|
||||||
fdims[3] = (float)(tc.t.scale_minus_1 + 1)*lastCustomTexScale[texid][1];
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
TCoordInfo& tc = bpmem.texcoords[texid];
|
|
||||||
fdims[0] = 1.0f / (float)(lastTexDims[texid] & 0xffff);
|
|
||||||
fdims[1] = 1.0f / (float)((lastTexDims[texid] >> 16) & 0xfff);
|
|
||||||
fdims[2] = (float)(tc.s.scale_minus_1 + 1) * lastCustomTexScale[texid][0];
|
|
||||||
fdims[3] = (float)(tc.t.scale_minus_1 + 1) * lastCustomTexScale[texid][1];
|
|
||||||
}
|
|
||||||
|
|
||||||
PRIM_LOG("texdims%d: %f %f %f %f\n", texid, fdims[0], fdims[1], fdims[2], fdims[3]);
|
PRIM_LOG("texdims%d: %f %f %f %f\n", texid, fdims[0], fdims[1], fdims[2], fdims[3]);
|
||||||
SetPSConstant4fv(C_TEXDIMS + texid, fdims);
|
SetPSConstant4fv(C_TEXDIMS + texid, fdims);
|
||||||
|
@ -362,23 +345,6 @@ void PixelShaderManager::SetZTextureTypeChanged()
|
||||||
s_bZTextureTypeChanged = true;
|
s_bZTextureTypeChanged = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
void PixelShaderManager::SetTexturesUsed(u32 nonpow2tex)
|
|
||||||
{
|
|
||||||
if (s_texturemask != nonpow2tex)
|
|
||||||
{
|
|
||||||
for (int i = 0; i < 8; ++i)
|
|
||||||
{
|
|
||||||
if (nonpow2tex & (0x10101 << i))
|
|
||||||
{
|
|
||||||
// this check was previously implicit, but should it be here?
|
|
||||||
if (s_nTexDimsChanged)
|
|
||||||
s_nTexDimsChanged |= 1 << i;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
s_texturemask = nonpow2tex;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void PixelShaderManager::SetTexCoordChanged(u8 texmapid)
|
void PixelShaderManager::SetTexCoordChanged(u8 texmapid)
|
||||||
{
|
{
|
||||||
s_nTexDimsChanged |= 1 << texmapid;
|
s_nTexDimsChanged |= 1 << texmapid;
|
||||||
|
@ -399,8 +365,3 @@ void PixelShaderManager::SetColorMatrix(const float* pmatrix, const float* pfCon
|
||||||
SetMultiPSConstant4fv(C_COLORMATRIX,4,pmatrix);
|
SetMultiPSConstant4fv(C_COLORMATRIX,4,pmatrix);
|
||||||
SetPSConstant4fv(C_COLORMATRIX+4, pfConstAdd);
|
SetPSConstant4fv(C_COLORMATRIX+4, pfConstAdd);
|
||||||
}
|
}
|
||||||
|
|
||||||
u32 PixelShaderManager::GetTextureMask()
|
|
||||||
{
|
|
||||||
return s_texturemask;
|
|
||||||
}
|
|
||||||
|
|
|
@ -48,12 +48,10 @@ public:
|
||||||
static void SetTevKSelChanged(int id);
|
static void SetTevKSelChanged(int id);
|
||||||
static void SetZTextureTypeChanged();
|
static void SetZTextureTypeChanged();
|
||||||
static void SetIndTexScaleChanged(u8 stagemask);
|
static void SetIndTexScaleChanged(u8 stagemask);
|
||||||
static void SetTexturesUsed(u32 nonpow2tex);
|
|
||||||
static void SetTexCoordChanged(u8 texmapid);
|
static void SetTexCoordChanged(u8 texmapid);
|
||||||
static void SetFogColorChanged();
|
static void SetFogColorChanged();
|
||||||
static void SetFogParamChanged();
|
static void SetFogParamChanged();
|
||||||
static void SetColorMatrix(const float* pmatrix, const float* pfConstAdd);
|
static void SetColorMatrix(const float* pmatrix, const float* pfConstAdd);
|
||||||
static u32 GetTextureMask();
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -218,7 +218,7 @@ void PixelShaderCache::Shutdown()
|
||||||
bool PixelShaderCache::SetShader(bool dstAlpha)
|
bool PixelShaderCache::SetShader(bool dstAlpha)
|
||||||
{
|
{
|
||||||
PIXELSHADERUID uid;
|
PIXELSHADERUID uid;
|
||||||
GetPixelShaderId(&uid, PixelShaderManager::GetTextureMask(), dstAlpha);
|
GetPixelShaderId(&uid, dstAlpha);
|
||||||
|
|
||||||
// check if the shader is already set
|
// check if the shader is already set
|
||||||
if (uid == last_pixel_shader_uid && PixelShaders[uid].frameCount == frameCount)
|
if (uid == last_pixel_shader_uid && PixelShaders[uid].frameCount == frameCount)
|
||||||
|
@ -243,7 +243,7 @@ bool PixelShaderCache::SetShader(bool dstAlpha)
|
||||||
}
|
}
|
||||||
|
|
||||||
// need to compile a new shader
|
// need to compile a new shader
|
||||||
const char* code = GeneratePixelShaderCode(PixelShaderManager::GetTextureMask(), dstAlpha, API_D3D11);
|
const char* code = GeneratePixelShaderCode(dstAlpha, API_D3D11);
|
||||||
|
|
||||||
D3DBlob* pbytecode;
|
D3DBlob* pbytecode;
|
||||||
if (!D3D::CompilePixelShader(code, strlen(code), &pbytecode))
|
if (!D3D::CompilePixelShader(code, strlen(code), &pbytecode))
|
||||||
|
|
|
@ -338,7 +338,6 @@ void Flush()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
PixelShaderManager::SetTexturesUsed(0);
|
|
||||||
|
|
||||||
VertexShaderManager::SetConstants();
|
VertexShaderManager::SetConstants();
|
||||||
PixelShaderManager::SetConstants();
|
PixelShaderManager::SetConstants();
|
||||||
|
|
|
@ -277,7 +277,7 @@ void PixelShaderCache::Shutdown()
|
||||||
bool PixelShaderCache::SetShader(bool dstAlpha)
|
bool PixelShaderCache::SetShader(bool dstAlpha)
|
||||||
{
|
{
|
||||||
PIXELSHADERUID uid;
|
PIXELSHADERUID uid;
|
||||||
GetPixelShaderId(&uid, PixelShaderManager::GetTextureMask(), dstAlpha);
|
GetPixelShaderId(&uid, dstAlpha);
|
||||||
|
|
||||||
// Is the shader already set?
|
// Is the shader already set?
|
||||||
if (uid == last_pixel_shader_uid && PixelShaders[uid].frameCount == frameCount)
|
if (uid == last_pixel_shader_uid && PixelShaders[uid].frameCount == frameCount)
|
||||||
|
@ -312,7 +312,7 @@ bool PixelShaderCache::SetShader(bool dstAlpha)
|
||||||
}
|
}
|
||||||
|
|
||||||
// OK, need to generate and compile it.
|
// OK, need to generate and compile it.
|
||||||
const char *code = GeneratePixelShaderCode(PixelShaderManager::GetTextureMask(), dstAlpha, API_D3D9);
|
const char *code = GeneratePixelShaderCode(dstAlpha, API_D3D9);
|
||||||
|
|
||||||
u32 code_hash = HashAdler32((const u8 *)code, strlen(code));
|
u32 code_hash = HashAdler32((const u8 *)code, strlen(code));
|
||||||
unique_shaders.insert(code_hash);
|
unique_shaders.insert(code_hash);
|
||||||
|
|
|
@ -270,7 +270,6 @@ void Flush()
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
PixelShaderManager::SetTexturesUsed(0);
|
|
||||||
|
|
||||||
// set global constants
|
// set global constants
|
||||||
VertexShaderManager::SetConstants();
|
VertexShaderManager::SetConstants();
|
||||||
|
|
|
@ -164,7 +164,7 @@ FRAGMENTSHADER* PixelShaderCache::GetShader(bool dstAlphaEnable)
|
||||||
{
|
{
|
||||||
DVSTARTPROFILE();
|
DVSTARTPROFILE();
|
||||||
PIXELSHADERUID uid;
|
PIXELSHADERUID uid;
|
||||||
GetPixelShaderId(&uid, PixelShaderManager::GetTextureMask(), dstAlphaEnable ? 1 : 0);
|
GetPixelShaderId(&uid, dstAlphaEnable ? 1 : 0);
|
||||||
if (uid == last_pixel_shader_uid && pshaders[uid].frameCount == frameCount)
|
if (uid == last_pixel_shader_uid && pshaders[uid].frameCount == frameCount)
|
||||||
{
|
{
|
||||||
return pShaderLast;
|
return pShaderLast;
|
||||||
|
@ -189,8 +189,7 @@ FRAGMENTSHADER* PixelShaderCache::GetShader(bool dstAlphaEnable)
|
||||||
PSCacheEntry& newentry = pshaders[uid];
|
PSCacheEntry& newentry = pshaders[uid];
|
||||||
newentry.frameCount = frameCount;
|
newentry.frameCount = frameCount;
|
||||||
pShaderLast = &newentry.shader;
|
pShaderLast = &newentry.shader;
|
||||||
const char *code = GeneratePixelShaderCode(PixelShaderManager::GetTextureMask(),
|
const char *code = GeneratePixelShaderCode(dstAlphaEnable,API_OPENGL);
|
||||||
dstAlphaEnable,API_OPENGL);
|
|
||||||
|
|
||||||
#if defined(_DEBUG) || defined(DEBUGFAST)
|
#if defined(_DEBUG) || defined(DEBUGFAST)
|
||||||
if (g_ActiveConfig.iLog & CONF_SAVESHADERS && code) {
|
if (g_ActiveConfig.iLog & CONF_SAVESHADERS && code) {
|
||||||
|
|
|
@ -191,21 +191,6 @@ static const GLenum glLogicOpCodes[16] = {
|
||||||
GL_SET
|
GL_SET
|
||||||
};
|
};
|
||||||
|
|
||||||
void SetDefaultRectTexParams()
|
|
||||||
{
|
|
||||||
// Set some standard texture filter modes.
|
|
||||||
glTexParameteri(GL_TEXTURE_RECTANGLE_ARB, GL_TEXTURE_WRAP_S, GL_CLAMP_TO_EDGE);
|
|
||||||
glTexParameteri(GL_TEXTURE_RECTANGLE_ARB, GL_TEXTURE_WRAP_T, GL_CLAMP_TO_EDGE);
|
|
||||||
if (GL_REPORT_ERROR() != GL_NO_ERROR)
|
|
||||||
{
|
|
||||||
glTexParameteri(GL_TEXTURE_RECTANGLE_ARB, GL_TEXTURE_WRAP_S, GL_CLAMP);
|
|
||||||
glTexParameteri(GL_TEXTURE_RECTANGLE_ARB, GL_TEXTURE_WRAP_T, GL_CLAMP);
|
|
||||||
GL_REPORT_ERRORD();
|
|
||||||
}
|
|
||||||
glTexParameteri(GL_TEXTURE_RECTANGLE_ARB, GL_TEXTURE_MAG_FILTER, GL_LINEAR);
|
|
||||||
glTexParameteri(GL_TEXTURE_RECTANGLE_ARB, GL_TEXTURE_MIN_FILTER, GL_LINEAR);
|
|
||||||
}
|
|
||||||
|
|
||||||
#if defined HAVE_CG && HAVE_CG
|
#if defined HAVE_CG && HAVE_CG
|
||||||
void HandleCgError(CGcontext ctx, CGerror err, void* appdata)
|
void HandleCgError(CGcontext ctx, CGerror err, void* appdata)
|
||||||
{
|
{
|
||||||
|
|
|
@ -260,7 +260,6 @@ void Flush()
|
||||||
if (bpmem.tevind[i].IsActive() && bpmem.tevind[i].bt < bpmem.genMode.numindstages)
|
if (bpmem.tevind[i].IsActive() && bpmem.tevind[i].bt < bpmem.genMode.numindstages)
|
||||||
usedtextures |= 1 << bpmem.tevindref.getTexMap(bpmem.tevind[i].bt);
|
usedtextures |= 1 << bpmem.tevindref.getTexMap(bpmem.tevind[i].bt);
|
||||||
|
|
||||||
u32 nonpow2tex = 0;
|
|
||||||
for (int i = 0; i < 8; i++)
|
for (int i = 0; i < 8; i++)
|
||||||
{
|
{
|
||||||
if (usedtextures & (1 << i))
|
if (usedtextures & (1 << i))
|
||||||
|
@ -290,8 +289,6 @@ void Flush()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
PixelShaderManager::SetTexturesUsed(nonpow2tex);
|
|
||||||
|
|
||||||
FRAGMENTSHADER* ps = PixelShaderCache::GetShader(false);
|
FRAGMENTSHADER* ps = PixelShaderCache::GetShader(false);
|
||||||
VERTEXSHADER* vs = VertexShaderCache::GetShader(g_nativeVertexFmt->m_components);
|
VERTEXSHADER* vs = VertexShaderCache::GetShader(g_nativeVertexFmt->m_components);
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue