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)
|
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];
|
const GSLocalMemory::psm_t& psm_s = GSLocalMemory::m_psm[TEX0.PSM];
|
||||||
|
|
||||||
Source* src = NULL;
|
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) {
|
if (!dst) {
|
||||||
// Retry on the render target (Silent Hill 4)
|
// Retry on the render target (Silent Hill 4)
|
||||||
for(auto t : m_dst[RenderTarget]) {
|
for(auto t : m_dst[RenderTarget]) {
|
||||||
|
@ -608,9 +614,6 @@ GSTextureCache::Target* GSTextureCache::LookupTarget(const GIFRegTEX0& TEX0, int
|
||||||
// must invalidate the Target/Depth respectively
|
// must invalidate the Target/Depth respectively
|
||||||
void GSTextureCache::InvalidateVideoMemType(int type, uint32 bp)
|
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++)
|
for(list<Target*>::iterator i = m_dst[type].begin(); i != m_dst[type].end(); i++)
|
||||||
{
|
{
|
||||||
Target* t = *i;
|
Target* t = *i;
|
||||||
|
|
Loading…
Reference in New Issue