GS/HW: Don't attempt to colour copy into depth target

This commit is contained in:
Stenzek 2023-04-15 22:48:57 +10:00 committed by refractionpcsx2
parent 8bd00e2433
commit 53c9021455
1 changed files with 3 additions and 4 deletions

View File

@ -4934,16 +4934,15 @@ void GSRendererHW::OI_DoubleHalfClear(GSTextureCache::Target*& rt, GSTextureCach
clear_depth ? "depth" : "target", base << 5, half << 5, w_pages, h_pages, m_cached_ctx.FRAME.FBW, color); clear_depth ? "depth" : "target", base << 5, half << 5, w_pages, h_pages, m_cached_ctx.FRAME.FBW, color);
// If some of the channels are masked, we need to keep them. // If some of the channels are masked, we need to keep them.
if (m_cached_ctx.FRAME.FBMSK != 0) if (!clear_depth && m_cached_ctx.FRAME.FBMSK != 0)
{ {
GSTexture* tex = nullptr; GSTexture* tex = nullptr;
GSTextureCache::Target* target = clear_depth ? ds : rt; GSTextureCache::Target* target = clear_depth ? ds : rt;
const GSVector2 size = GSVector2(static_cast<float>(target->GetUnscaledWidth()) * target->m_scale, static_cast<float>(target->GetUnscaledHeight()) * target->m_scale); const GSVector2 size = GSVector2(static_cast<float>(target->GetUnscaledWidth()) * target->m_scale, static_cast<float>(target->GetUnscaledHeight()) * target->m_scale);
pxAssert(!target->m_texture->IsDepthStencil());
try try
{ {
tex = target->m_texture->IsDepthStencil() ? tex = g_gs_device->CreateRenderTarget(size.x, size.y, target->m_texture->GetFormat(), false);
g_gs_device->CreateDepthStencil(size.x, size.y, target->m_texture->GetFormat(), true) :
g_gs_device->CreateRenderTarget(size.x, size.y, target->m_texture->GetFormat(), true);
} }
catch (const std::bad_alloc&) catch (const std::bad_alloc&)
{ {