mirror of https://github.com/PCSX2/pcsx2.git
Merge pull request #1472 from PCSX2/gsdx-gta-depth-issue-1457
Gsdx gta depth issue 1457
This commit is contained in:
commit
d6383e6c21
|
@ -87,11 +87,6 @@ void GSTextureCache::RemoveAll()
|
|||
|
||||
GSTextureCache::Source* GSTextureCache::LookupDepthSource(const GIFRegTEX0& TEX0, const GIFRegTEXA& TEXA, const GSVector4i& r, bool palette)
|
||||
{
|
||||
if (!CanConvertDepth()) {
|
||||
GL_CACHE("LookupDepthSource not supported (0x%x, F:0x%x)", TEX0.TBP0, TEX0.PSM);
|
||||
throw GSDXRecoverableError();
|
||||
}
|
||||
|
||||
const GSLocalMemory::psm_t& psm_s = GSLocalMemory::m_psm[TEX0.PSM];
|
||||
|
||||
Source* src = NULL;
|
||||
|
@ -110,6 +105,17 @@ GSTextureCache::Source* GSTextureCache::LookupDepthSource(const GIFRegTEX0& TEX0
|
|||
}
|
||||
}
|
||||
|
||||
if (!CanConvertDepth()) {
|
||||
if (dst) {
|
||||
GL_CACHE("LookupDepthSource not supported (0x%x, F:0x%x)", TEX0.TBP0, TEX0.PSM);
|
||||
throw GSDXRecoverableError();
|
||||
} else {
|
||||
// LookupSource call LookupDepthSource, I'm sure it is nice testcase for formal tools ;)
|
||||
GL_CACHE("LookupDepthSource not supported let's try standard LookupSource");
|
||||
return LookupSource(TEX0, TEXA, r);
|
||||
}
|
||||
}
|
||||
|
||||
if (!dst) {
|
||||
// Retry on the render target (Silent Hill 4)
|
||||
for(auto t : m_dst[RenderTarget]) {
|
||||
|
@ -608,9 +614,6 @@ GSTextureCache::Target* GSTextureCache::LookupTarget(const GIFRegTEX0& TEX0, int
|
|||
// must invalidate the Target/Depth respectively
|
||||
void GSTextureCache::InvalidateVideoMemType(int type, uint32 bp)
|
||||
{
|
||||
if (!CanConvertDepth())
|
||||
return;
|
||||
|
||||
for(list<Target*>::iterator i = m_dst[type].begin(); i != m_dst[type].end(); i++)
|
||||
{
|
||||
Target* t = *i;
|
||||
|
|
Loading…
Reference in New Issue