mirror of https://github.com/PCSX2/pcsx2.git
GS/HW: Don't clear temporary copies for HDR/DS
Invalidating is enough here.
This commit is contained in:
parent
cf1d67d927
commit
568ebc6199
|
@ -3179,18 +3179,22 @@ GSState::TextureMinMaxResult GSState::GetTextureMinMax(const GIFRegTEX0& TEX0, c
|
||||||
{
|
{
|
||||||
// Optimisation aims to reduce the amount of texture loaded to only the bit which will be read
|
// Optimisation aims to reduce the amount of texture loaded to only the bit which will be read
|
||||||
GSVector4 st = m_vt.m_min.t.xyxy(m_vt.m_max.t);
|
GSVector4 st = m_vt.m_min.t.xyxy(m_vt.m_max.t);
|
||||||
|
if (linear)
|
||||||
|
st += GSVector4(-0.5f, 0.5f).xxyy();
|
||||||
|
|
||||||
// Adjust texture range when sprites get scissor clipped. Since we linearly interpolate, this
|
// Adjust texture range when sprites get scissor clipped. Since we linearly interpolate, this
|
||||||
// optimization doesn't work when perspective correction is enabled.
|
// optimization doesn't work when perspective correction is enabled.
|
||||||
if (m_vt.m_primclass == GS_SPRITE_CLASS && PRIM->FST == 1)
|
if (m_vt.m_primclass == GS_SPRITE_CLASS && PRIM->FST == 1)
|
||||||
{
|
{
|
||||||
const GSVector4i int_rc(m_vt.m_min.p.xyxy(m_vt.m_max.p));
|
// When coordinates are fractional, GS appears to draw to the right/bottom (effectively
|
||||||
|
// taking the ceiling), not to the top/left (taking the floor).
|
||||||
|
const GSVector4i int_rc(m_vt.m_min.p.ceil().xyxy(m_vt.m_max.p.floor()));
|
||||||
const GSVector4i scissored_rc(int_rc.rintersect(GSVector4i(m_context->scissor.in)));
|
const GSVector4i scissored_rc(int_rc.rintersect(GSVector4i(m_context->scissor.in)));
|
||||||
if (!int_rc.eq(scissored_rc))
|
if (!int_rc.eq(scissored_rc))
|
||||||
{
|
{
|
||||||
// draw will get scissored, adjust UVs to suit
|
// draw will get scissored, adjust UVs to suit
|
||||||
const GSVector2 pos_range(m_vt.m_max.p.x - m_vt.m_min.p.x, m_vt.m_max.p.y - m_vt.m_min.p.y);
|
const GSVector2 pos_range(m_vt.m_max.p.x - m_vt.m_min.p.x, m_vt.m_max.p.y - m_vt.m_min.p.y);
|
||||||
const GSVector2 uv_range(st.z - st.x, st.w - st.y);
|
const GSVector2 uv_range(m_vt.m_max.t.x - m_vt.m_min.t.x, m_vt.m_max.t.y - m_vt.m_min.t.y);
|
||||||
const GSVector2 grad(uv_range / pos_range);
|
const GSVector2 grad(uv_range / pos_range);
|
||||||
|
|
||||||
// we need to check that it's not going to repeat over the non-clipped part
|
// we need to check that it's not going to repeat over the non-clipped part
|
||||||
|
@ -3211,9 +3215,6 @@ GSState::TextureMinMaxResult GSState::GetTextureMinMax(const GIFRegTEX0& TEX0, c
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (linear)
|
|
||||||
st += GSVector4(-0.5f, 0.5f).xxyy();
|
|
||||||
|
|
||||||
GSVector4i uv = GSVector4i(st.floor());
|
GSVector4i uv = GSVector4i(st.floor());
|
||||||
uses_border = GSVector4::cast((uv < vr).blend32<0xc>(uv >= vr)).mask();
|
uses_border = GSVector4::cast((uv < vr).blend32<0xc>(uv >= vr)).mask();
|
||||||
|
|
||||||
|
|
|
@ -2463,7 +2463,7 @@ void GSDevice12::RenderHW(GSHWDrawConfig& config)
|
||||||
EndRenderPass();
|
EndRenderPass();
|
||||||
|
|
||||||
GL_PUSH_("HDR Render Target Setup");
|
GL_PUSH_("HDR Render Target Setup");
|
||||||
hdr_rt = static_cast<GSTexture12*>(CreateRenderTarget(rtsize.x, rtsize.y, GSTexture::Format::FloatColor));
|
hdr_rt = static_cast<GSTexture12*>(CreateRenderTarget(rtsize.x, rtsize.y, GSTexture::Format::FloatColor, false));
|
||||||
if (!hdr_rt)
|
if (!hdr_rt)
|
||||||
{
|
{
|
||||||
Console.WriteLn("Failed to allocate HDR render target, aborting draw.");
|
Console.WriteLn("Failed to allocate HDR render target, aborting draw.");
|
||||||
|
@ -2492,7 +2492,7 @@ void GSDevice12::RenderHW(GSHWDrawConfig& config)
|
||||||
else if (config.require_one_barrier)
|
else if (config.require_one_barrier)
|
||||||
{
|
{
|
||||||
// requires a copy of the RT
|
// requires a copy of the RT
|
||||||
draw_rt_clone = static_cast<GSTexture12*>(CreateTexture(rtsize.x, rtsize.y, false, GSTexture::Format::Color, true));
|
draw_rt_clone = static_cast<GSTexture12*>(CreateTexture(rtsize.x, rtsize.y, false, GSTexture::Format::Color, false));
|
||||||
if (draw_rt_clone)
|
if (draw_rt_clone)
|
||||||
{
|
{
|
||||||
EndRenderPass();
|
EndRenderPass();
|
||||||
|
@ -2510,7 +2510,7 @@ void GSDevice12::RenderHW(GSHWDrawConfig& config)
|
||||||
if (config.tex && config.tex == config.ds)
|
if (config.tex && config.tex == config.ds)
|
||||||
{
|
{
|
||||||
// requires a copy of the depth buffer. this is mainly for ico.
|
// requires a copy of the depth buffer. this is mainly for ico.
|
||||||
copy_ds = static_cast<GSTexture12*>(CreateDepthStencil(rtsize.x, rtsize.y, GSTexture::Format::DepthStencil, true));
|
copy_ds = static_cast<GSTexture12*>(CreateDepthStencil(rtsize.x, rtsize.y, GSTexture::Format::DepthStencil, false));
|
||||||
if (copy_ds)
|
if (copy_ds)
|
||||||
{
|
{
|
||||||
EndRenderPass();
|
EndRenderPass();
|
||||||
|
|
|
@ -1840,7 +1840,7 @@ void GSDeviceOGL::RenderHW(GSHWDrawConfig& config)
|
||||||
if (config.ps.hdr)
|
if (config.ps.hdr)
|
||||||
{
|
{
|
||||||
GSVector2i size = config.rt->GetSize();
|
GSVector2i size = config.rt->GetSize();
|
||||||
hdr_rt = CreateRenderTarget(size.x, size.y, GSTexture::Format::FloatColor);
|
hdr_rt = CreateRenderTarget(size.x, size.y, GSTexture::Format::FloatColor, false);
|
||||||
hdr_rt->CommitRegion(GSVector2i(config.drawarea.z, config.drawarea.w));
|
hdr_rt->CommitRegion(GSVector2i(config.drawarea.z, config.drawarea.w));
|
||||||
OMSetRenderTargets(hdr_rt, config.ds, &config.scissor);
|
OMSetRenderTargets(hdr_rt, config.ds, &config.scissor);
|
||||||
|
|
||||||
|
|
|
@ -2876,7 +2876,7 @@ void GSDeviceVK::RenderHW(GSHWDrawConfig& config)
|
||||||
EndRenderPass();
|
EndRenderPass();
|
||||||
|
|
||||||
GL_PUSH_("HDR Render Target Setup");
|
GL_PUSH_("HDR Render Target Setup");
|
||||||
hdr_rt = static_cast<GSTextureVK*>(CreateRenderTarget(rtsize.x, rtsize.y, GSTexture::Format::FloatColor));
|
hdr_rt = static_cast<GSTextureVK*>(CreateRenderTarget(rtsize.x, rtsize.y, GSTexture::Format::FloatColor, false));
|
||||||
if (!hdr_rt)
|
if (!hdr_rt)
|
||||||
{
|
{
|
||||||
Console.WriteLn("Failed to allocate HDR render target, aborting draw.");
|
Console.WriteLn("Failed to allocate HDR render target, aborting draw.");
|
||||||
|
@ -2905,7 +2905,7 @@ void GSDeviceVK::RenderHW(GSHWDrawConfig& config)
|
||||||
else if (config.require_one_barrier && !m_features.texture_barrier)
|
else if (config.require_one_barrier && !m_features.texture_barrier)
|
||||||
{
|
{
|
||||||
// requires a copy of the RT
|
// requires a copy of the RT
|
||||||
draw_rt_clone = static_cast<GSTextureVK*>(CreateTexture(rtsize.x, rtsize.y, false, GSTexture::Format::Color, true));
|
draw_rt_clone = static_cast<GSTextureVK*>(CreateTexture(rtsize.x, rtsize.y, false, GSTexture::Format::Color, false));
|
||||||
if (draw_rt_clone)
|
if (draw_rt_clone)
|
||||||
{
|
{
|
||||||
EndRenderPass();
|
EndRenderPass();
|
||||||
|
@ -2922,7 +2922,7 @@ void GSDeviceVK::RenderHW(GSHWDrawConfig& config)
|
||||||
if (config.tex && config.tex == config.ds)
|
if (config.tex && config.tex == config.ds)
|
||||||
{
|
{
|
||||||
// requires a copy of the depth buffer. this is mainly for ico.
|
// requires a copy of the depth buffer. this is mainly for ico.
|
||||||
copy_ds = static_cast<GSTextureVK*>(CreateDepthStencil(rtsize.x, rtsize.y, GSTexture::Format::DepthStencil, true));
|
copy_ds = static_cast<GSTextureVK*>(CreateDepthStencil(rtsize.x, rtsize.y, GSTexture::Format::DepthStencil, false));
|
||||||
if (copy_ds)
|
if (copy_ds)
|
||||||
{
|
{
|
||||||
EndRenderPass();
|
EndRenderPass();
|
||||||
|
|
Loading…
Reference in New Issue