mirror of https://github.com/PCSX2/pcsx2.git
GS/HW: Avoid corrections on new targets.
This commit is contained in:
parent
500e86c43c
commit
6a5ac4fe54
|
@ -3122,6 +3122,9 @@ void GSRendererHW::Draw()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (rt)
|
||||||
|
rt->m_last_draw = s_n;
|
||||||
|
|
||||||
#ifdef DISABLE_HW_TEXTURE_CACHE
|
#ifdef DISABLE_HW_TEXTURE_CACHE
|
||||||
if (rt)
|
if (rt)
|
||||||
g_texture_cache->Read(rt, m_r);
|
g_texture_cache->Read(rt, m_r);
|
||||||
|
@ -5307,10 +5310,15 @@ __ri void GSRendererHW::DrawPrims(GSTextureCache::Target* rt, GSTextureCache::Ta
|
||||||
const bool rta_decorrection = m_channel_shuffle || m_texture_shuffle || std::max(blend_alpha_max, rt->m_alpha_max) > 128 || m_conf.ps.fbmask || m_conf.ps.tex_is_fb;
|
const bool rta_decorrection = m_channel_shuffle || m_texture_shuffle || std::max(blend_alpha_max, rt->m_alpha_max) > 128 || m_conf.ps.fbmask || m_conf.ps.tex_is_fb;
|
||||||
|
|
||||||
if (rta_decorrection)
|
if (rta_decorrection)
|
||||||
|
{
|
||||||
|
if (rt->m_last_draw == s_n)
|
||||||
|
rt->m_rt_alpha_scale = false;
|
||||||
|
else
|
||||||
{
|
{
|
||||||
rt->RTADecorrect(rt);
|
rt->RTADecorrect(rt);
|
||||||
m_conf.rt = rt->m_texture;
|
m_conf.rt = rt->m_texture;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
m_conf.ps.rta_correction = rt->m_rt_alpha_scale;
|
m_conf.ps.rta_correction = rt->m_rt_alpha_scale;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1690,7 +1690,7 @@ GSTextureCache::Source* GSTextureCache::LookupSource(const bool is_color, const
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if (dst && dst->m_rt_alpha_scale)
|
if (dst && dst->m_rt_alpha_scale && (GSUtil::GetChannelMask(TEX0.PSM) & 0x8))
|
||||||
dst->RTADecorrect(dst);
|
dst->RTADecorrect(dst);
|
||||||
|
|
||||||
src = CreateSource(TEX0, TEXA, dst, half_right, x_offset, y_offset, lod, &r, gpu_clut, region);
|
src = CreateSource(TEX0, TEXA, dst, half_right, x_offset, y_offset, lod, &r, gpu_clut, region);
|
||||||
|
@ -2350,6 +2350,11 @@ GSTextureCache::Target* GSTextureCache::CreateTarget(GIFRegTEX0 TEX0, const GSVe
|
||||||
|
|
||||||
dst->readbacks_since_draw = 0;
|
dst->readbacks_since_draw = 0;
|
||||||
|
|
||||||
|
dst->m_last_draw = GSState::s_n;
|
||||||
|
|
||||||
|
if (dst->m_dirty.empty())
|
||||||
|
dst->m_rt_alpha_scale = true;
|
||||||
|
|
||||||
pxAssert(dst && dst->m_texture && dst->m_scale == scale);
|
pxAssert(dst && dst->m_texture && dst->m_scale == scale);
|
||||||
return dst;
|
return dst;
|
||||||
}
|
}
|
||||||
|
|
|
@ -217,6 +217,7 @@ public:
|
||||||
bool m_valid_alpha_high = false;
|
bool m_valid_alpha_high = false;
|
||||||
bool m_valid_rgb = false;
|
bool m_valid_rgb = false;
|
||||||
bool m_rt_alpha_scale = false;
|
bool m_rt_alpha_scale = false;
|
||||||
|
int m_last_draw = 0;
|
||||||
|
|
||||||
bool m_is_frame = false;
|
bool m_is_frame = false;
|
||||||
bool m_used = false;
|
bool m_used = false;
|
||||||
|
|
Loading…
Reference in New Issue