mirror of https://github.com/PCSX2/pcsx2.git
gsdx ogl: plug the new depth sampling in the renderer
Note: When source format is depth, integral texture coordinate must be used => depth_fmt 1/2/3
This commit is contained in:
parent
fda511a949
commit
de38963904
|
@ -415,7 +415,7 @@ void GSRendererHW::Draw()
|
||||||
|
|
||||||
GetTextureMinMax(r, context->TEX0, context->CLAMP, m_vt.IsLinear());
|
GetTextureMinMax(r, context->TEX0, context->CLAMP, m_vt.IsLinear());
|
||||||
|
|
||||||
tex = m_tc->LookupSource(context->TEX0, env.TEXA, r);
|
tex = tex_psm.depth ? m_tc->LookupDepthSource(context->TEX0, env.TEXA, r) : m_tc->LookupSource(context->TEX0, env.TEXA, r);
|
||||||
|
|
||||||
if(!tex) {
|
if(!tex) {
|
||||||
GL_POP();
|
GL_POP();
|
||||||
|
|
|
@ -876,13 +876,16 @@ void GSRendererOGL::DrawPrims(GSTexture* rt, GSTexture* ds, GSTextureCache::Sour
|
||||||
const GSLocalMemory::psm_t &psm = GSLocalMemory::m_psm[m_context->TEX0.PSM];
|
const GSLocalMemory::psm_t &psm = GSLocalMemory::m_psm[m_context->TEX0.PSM];
|
||||||
const GSLocalMemory::psm_t &cpsm = psm.pal > 0 ? GSLocalMemory::m_psm[m_context->TEX0.CPSM] : psm;
|
const GSLocalMemory::psm_t &cpsm = psm.pal > 0 ? GSLocalMemory::m_psm[m_context->TEX0.CPSM] : psm;
|
||||||
bool bilinear = m_filter == 2 ? m_vt.IsLinear() : m_filter != 0;
|
bool bilinear = m_filter == 2 ? m_vt.IsLinear() : m_filter != 0;
|
||||||
bool simple_sample = !tex->m_palette && cpsm.fmt == 0 && m_context->CLAMP.WMS < 2 && m_context->CLAMP.WMT < 2;
|
bool simple_sample = !tex->m_palette && cpsm.fmt == 0 && m_context->CLAMP.WMS < 2 && m_context->CLAMP.WMT < 2 && !psm.depth;
|
||||||
// Don't force extra filtering on sprite (it creates various upscaling issue)
|
// Don't force extra filtering on sprite (it creates various upscaling issue)
|
||||||
bilinear &= !((m_vt.m_primclass == GS_SPRITE_CLASS) && m_userhacks_round_sprite_offset && !m_vt.IsLinear());
|
bilinear &= !((m_vt.m_primclass == GS_SPRITE_CLASS) && m_userhacks_round_sprite_offset && !m_vt.IsLinear());
|
||||||
|
|
||||||
ps_sel.wms = m_context->CLAMP.WMS;
|
ps_sel.wms = m_context->CLAMP.WMS;
|
||||||
ps_sel.wmt = m_context->CLAMP.WMT;
|
ps_sel.wmt = m_context->CLAMP.WMT;
|
||||||
|
|
||||||
|
// Depth + bilinear filtering isn't done yet (And I'm not sure we need it anyway but a game will prove me wrong)
|
||||||
|
ASSERT(!(psm.depth && m_vt.IsLinear()));
|
||||||
|
|
||||||
// Performance note:
|
// Performance note:
|
||||||
// 1/ Don't set 0 as it is the default value
|
// 1/ Don't set 0 as it is the default value
|
||||||
// 2/ Only keep aem when it is useful (avoid useless shader permutation)
|
// 2/ Only keep aem when it is useful (avoid useless shader permutation)
|
||||||
|
@ -892,6 +895,11 @@ void GSRendererOGL::DrawPrims(GSTexture* rt, GSTexture* ds, GSTextureCache::Sour
|
||||||
ps_sel.aem = m_env.TEXA.AEM;
|
ps_sel.aem = m_env.TEXA.AEM;
|
||||||
ASSERT(tex->m_target);
|
ASSERT(tex->m_target);
|
||||||
|
|
||||||
|
// Require a float conversion if the texure is a depth otherwise uses Integral scaling
|
||||||
|
if (psm.depth) {
|
||||||
|
ps_sel.depth_fmt = (tex->m_texture->GetType() != GSTexture::DepthStencil) ? 3 : 1;
|
||||||
|
}
|
||||||
|
|
||||||
// Shuffle is a 16 bits format, so aem is always required
|
// Shuffle is a 16 bits format, so aem is always required
|
||||||
GSVector4 ta(m_env.TEXA & GSVector4i::x000000ff());
|
GSVector4 ta(m_env.TEXA & GSVector4i::x000000ff());
|
||||||
ta /= 255.0f;
|
ta /= 255.0f;
|
||||||
|
@ -899,8 +907,8 @@ void GSRendererOGL::DrawPrims(GSTexture* rt, GSTexture* ds, GSTextureCache::Sour
|
||||||
ps_cb.TA_Af.x = ta.x;
|
ps_cb.TA_Af.x = ta.x;
|
||||||
ps_cb.TA_Af.y = ta.y;
|
ps_cb.TA_Af.y = ta.y;
|
||||||
|
|
||||||
// FIXME: it is likely a bad idea to do the bilinear interpolation here
|
// The purpose of texture shuffle is to move color channel. Extra interpolation is likely a bad idea.
|
||||||
// bilinear &= m_vt.IsLinear();
|
bilinear &= m_vt.IsLinear();
|
||||||
|
|
||||||
} else if (tex->m_target) {
|
} else if (tex->m_target) {
|
||||||
// Use an old target. AEM and index aren't resolved it must be done
|
// Use an old target. AEM and index aren't resolved it must be done
|
||||||
|
@ -935,6 +943,15 @@ void GSRendererOGL::DrawPrims(GSTexture* rt, GSTexture* ds, GSTextureCache::Sour
|
||||||
bilinear &= m_vt.IsLinear();
|
bilinear &= m_vt.IsLinear();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Depth format
|
||||||
|
if (psm.depth) {
|
||||||
|
// Require a float conversion if the texure is a depth otherwise uses Integral scaling
|
||||||
|
ps_sel.depth_fmt = (tex->m_texture->GetType() != GSTexture::DepthStencil) ? 3 :
|
||||||
|
(psm.bpp == 16) ? 2 : 1;
|
||||||
|
// Don't force interpolation on depth format
|
||||||
|
bilinear &= m_vt.IsLinear();
|
||||||
|
}
|
||||||
|
|
||||||
} else if (tex->m_palette) {
|
} else if (tex->m_palette) {
|
||||||
// Use a standard 8 bits texture. AEM is already done on the CLUT
|
// Use a standard 8 bits texture. AEM is already done on the CLUT
|
||||||
// Therefore you only need to set the index
|
// Therefore you only need to set the index
|
||||||
|
|
Loading…
Reference in New Issue